primeng 16.6.0 → 16.7.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/animate/animate.d.ts +3 -2
- package/animateonscroll/animateonscroll.d.ts +73 -0
- package/animateonscroll/index.d.ts +5 -0
- package/animateonscroll/public_api.d.ts +1 -0
- package/api/primengconfig.d.ts +1 -0
- package/autocomplete/autocomplete.d.ts +177 -54
- package/autocomplete/autocomplete.interface.d.ts +30 -0
- package/cascadeselect/cascadeselect.d.ts +188 -68
- package/cascadeselect/cascadeselect.interface.d.ts +19 -0
- package/checkbox/checkbox.d.ts +1 -4
- package/chips/chips.d.ts +21 -5
- package/colorpicker/colorpicker.d.ts +5 -5
- package/contextmenu/contextmenu.d.ts +1 -0
- package/dialog/dialog.d.ts +1 -2
- package/dom/domhandler.d.ts +4 -1
- package/dropdown/dropdown.d.ts +115 -37
- package/esm2022/accordion/accordion.mjs +11 -7
- package/esm2022/animate/animate.mjs +4 -1
- package/esm2022/animateonscroll/animateonscroll.mjs +185 -0
- package/esm2022/animateonscroll/primeng-animateonscroll.mjs +5 -0
- package/esm2022/animateonscroll/public_api.mjs +2 -0
- package/esm2022/api/primengconfig.mjs +2 -1
- package/esm2022/autocomplete/autocomplete.interface.mjs +1 -1
- package/esm2022/autocomplete/autocomplete.mjs +893 -617
- package/esm2022/carousel/carousel.mjs +5 -1
- package/esm2022/cascadeselect/cascadeselect.interface.mjs +1 -1
- package/esm2022/cascadeselect/cascadeselect.mjs +921 -482
- package/esm2022/checkbox/checkbox.mjs +90 -73
- package/esm2022/chips/chips.mjs +197 -53
- package/esm2022/colorpicker/colorpicker.mjs +56 -37
- package/esm2022/contextmenu/contextmenu.mjs +10 -1
- package/esm2022/dialog/dialog.mjs +6 -11
- package/esm2022/dom/domhandler.mjs +26 -8
- package/esm2022/dropdown/dropdown.mjs +707 -588
- package/esm2022/inputmask/inputmask.mjs +22 -9
- package/esm2022/inputnumber/inputnumber.mjs +142 -83
- package/esm2022/inputswitch/inputswitch.mjs +55 -49
- package/esm2022/knob/knob.mjs +92 -5
- package/esm2022/listbox/listbox.interface.mjs +1 -1
- package/esm2022/listbox/listbox.mjs +996 -454
- package/esm2022/multiselect/multiselect.mjs +1022 -604
- package/esm2022/overlaypanel/overlaypanel.mjs +2 -2
- package/esm2022/paginator/paginator.mjs +2 -2
- package/esm2022/password/password.mjs +29 -28
- package/esm2022/radiobutton/radiobutton.mjs +46 -33
- package/esm2022/rating/rating.mjs +172 -80
- package/esm2022/selectbutton/selectbutton.mjs +105 -34
- package/esm2022/slider/slider.mjs +151 -66
- package/esm2022/table/table.mjs +3 -3
- package/esm2022/togglebutton/togglebutton.mjs +47 -10
- package/esm2022/tristatecheckbox/tristatecheckbox.mjs +53 -35
- package/fesm2022/primeng-accordion.mjs +10 -6
- package/fesm2022/primeng-accordion.mjs.map +1 -1
- package/fesm2022/primeng-animate.mjs +3 -0
- package/fesm2022/primeng-animate.mjs.map +1 -1
- package/fesm2022/primeng-animateonscroll.mjs +190 -0
- package/fesm2022/primeng-animateonscroll.mjs.map +1 -0
- package/fesm2022/primeng-api.mjs +1 -0
- package/fesm2022/primeng-api.mjs.map +1 -1
- package/fesm2022/primeng-autocomplete.mjs +893 -617
- package/fesm2022/primeng-autocomplete.mjs.map +1 -1
- package/fesm2022/primeng-carousel.mjs +4 -0
- package/fesm2022/primeng-carousel.mjs.map +1 -1
- package/fesm2022/primeng-cascadeselect.mjs +920 -481
- package/fesm2022/primeng-cascadeselect.mjs.map +1 -1
- package/fesm2022/primeng-checkbox.mjs +89 -72
- package/fesm2022/primeng-checkbox.mjs.map +1 -1
- package/fesm2022/primeng-chips.mjs +195 -51
- package/fesm2022/primeng-chips.mjs.map +1 -1
- package/fesm2022/primeng-colorpicker.mjs +55 -36
- package/fesm2022/primeng-colorpicker.mjs.map +1 -1
- package/fesm2022/primeng-contextmenu.mjs +9 -0
- package/fesm2022/primeng-contextmenu.mjs.map +1 -1
- package/fesm2022/primeng-dialog.mjs +5 -10
- package/fesm2022/primeng-dialog.mjs.map +1 -1
- package/fesm2022/primeng-dom.mjs +25 -7
- package/fesm2022/primeng-dom.mjs.map +1 -1
- package/fesm2022/primeng-dropdown.mjs +707 -588
- package/fesm2022/primeng-dropdown.mjs.map +1 -1
- package/fesm2022/primeng-inputmask.mjs +20 -7
- package/fesm2022/primeng-inputmask.mjs.map +1 -1
- package/fesm2022/primeng-inputnumber.mjs +140 -81
- package/fesm2022/primeng-inputnumber.mjs.map +1 -1
- package/fesm2022/primeng-inputswitch.mjs +55 -49
- package/fesm2022/primeng-inputswitch.mjs.map +1 -1
- package/fesm2022/primeng-knob.mjs +92 -5
- package/fesm2022/primeng-knob.mjs.map +1 -1
- package/fesm2022/primeng-listbox.mjs +995 -453
- package/fesm2022/primeng-listbox.mjs.map +1 -1
- package/fesm2022/primeng-multiselect.mjs +1021 -603
- package/fesm2022/primeng-multiselect.mjs.map +1 -1
- package/fesm2022/primeng-overlaypanel.mjs +1 -1
- package/fesm2022/primeng-overlaypanel.mjs.map +1 -1
- package/fesm2022/primeng-paginator.mjs +1 -1
- package/fesm2022/primeng-paginator.mjs.map +1 -1
- package/fesm2022/primeng-password.mjs +27 -26
- package/fesm2022/primeng-password.mjs.map +1 -1
- package/fesm2022/primeng-radiobutton.mjs +46 -33
- package/fesm2022/primeng-radiobutton.mjs.map +1 -1
- package/fesm2022/primeng-rating.mjs +171 -79
- package/fesm2022/primeng-rating.mjs.map +1 -1
- package/fesm2022/primeng-selectbutton.mjs +104 -33
- package/fesm2022/primeng-selectbutton.mjs.map +1 -1
- package/fesm2022/primeng-slider.mjs +150 -65
- package/fesm2022/primeng-slider.mjs.map +1 -1
- package/fesm2022/primeng-table.mjs +2 -2
- package/fesm2022/primeng-table.mjs.map +1 -1
- package/fesm2022/primeng-togglebutton.mjs +46 -9
- package/fesm2022/primeng-togglebutton.mjs.map +1 -1
- package/fesm2022/primeng-tristatecheckbox.mjs +53 -35
- package/fesm2022/primeng-tristatecheckbox.mjs.map +1 -1
- package/inputmask/inputmask.d.ts +6 -1
- package/inputnumber/inputnumber.d.ts +6 -1
- package/inputswitch/inputswitch.d.ts +6 -9
- package/knob/knob.d.ts +20 -3
- package/listbox/listbox.d.ts +208 -39
- package/listbox/listbox.interface.d.ts +15 -0
- package/multiselect/multiselect.d.ts +171 -60
- package/package.json +126 -120
- package/password/password.d.ts +3 -4
- package/radiobutton/radiobutton.d.ts +1 -2
- package/rating/rating.d.ts +29 -7
- package/resources/components/dropdown/dropdown.css +16 -2
- package/resources/themes/arya-blue/theme.css +106 -84
- package/resources/themes/arya-green/theme.css +106 -84
- package/resources/themes/arya-orange/theme.css +106 -84
- package/resources/themes/arya-purple/theme.css +106 -84
- package/resources/themes/bootstrap4-dark-blue/theme.css +110 -88
- package/resources/themes/bootstrap4-dark-purple/theme.css +110 -88
- package/resources/themes/bootstrap4-light-blue/theme.css +110 -88
- package/resources/themes/bootstrap4-light-purple/theme.css +110 -88
- package/resources/themes/fluent-light/theme.css +103 -81
- package/resources/themes/lara-dark-blue/theme.css +106 -84
- package/resources/themes/lara-dark-indigo/theme.css +106 -84
- package/resources/themes/lara-dark-purple/theme.css +106 -84
- package/resources/themes/lara-dark-teal/theme.css +106 -84
- package/resources/themes/lara-light-blue/theme.css +109 -87
- package/resources/themes/lara-light-indigo/theme.css +109 -87
- package/resources/themes/lara-light-purple/theme.css +109 -87
- package/resources/themes/lara-light-teal/theme.css +109 -87
- package/resources/themes/luna-amber/theme.css +110 -88
- package/resources/themes/luna-blue/theme.css +110 -88
- package/resources/themes/luna-green/theme.css +110 -88
- package/resources/themes/luna-pink/theme.css +110 -88
- package/resources/themes/md-dark-deeppurple/theme.css +117 -95
- package/resources/themes/md-dark-indigo/theme.css +117 -95
- package/resources/themes/md-light-deeppurple/theme.css +117 -95
- package/resources/themes/md-light-indigo/theme.css +117 -95
- package/resources/themes/mdc-dark-deeppurple/theme.css +117 -95
- package/resources/themes/mdc-dark-indigo/theme.css +117 -95
- package/resources/themes/mdc-light-deeppurple/theme.css +117 -95
- package/resources/themes/mdc-light-indigo/theme.css +117 -95
- package/resources/themes/mira/theme.css +107 -85
- package/resources/themes/nano/theme.css +109 -87
- package/resources/themes/nova/theme.css +110 -88
- package/resources/themes/nova-accent/theme.css +109 -87
- package/resources/themes/nova-alt/theme.css +110 -88
- package/resources/themes/rhea/theme.css +109 -87
- package/resources/themes/saga-blue/theme.css +106 -84
- package/resources/themes/saga-green/theme.css +106 -84
- package/resources/themes/saga-orange/theme.css +106 -84
- package/resources/themes/saga-purple/theme.css +106 -84
- package/resources/themes/soho-dark/theme.css +109 -87
- package/resources/themes/soho-light/theme.css +109 -87
- package/resources/themes/tailwind-light/theme.css +110 -88
- package/resources/themes/vela-blue/theme.css +106 -84
- package/resources/themes/vela-green/theme.css +106 -84
- package/resources/themes/vela-orange/theme.css +106 -84
- package/resources/themes/vela-purple/theme.css +106 -84
- package/resources/themes/viva-dark/theme.css +109 -87
- package/resources/themes/viva-light/theme.css +109 -87
- package/selectbutton/selectbutton.d.ts +15 -3
- package/slider/slider.d.ts +12 -6
- package/togglebutton/togglebutton.d.ts +7 -1
- package/tristatecheckbox/tristatecheckbox.d.ts +8 -4
@@ -1,7 +1,7 @@
|
|
1
1
|
import { CommonModule, DOCUMENT } from '@angular/common';
|
2
|
-
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, forwardRef, Inject, Input, NgModule, Output, ViewChild, ViewEncapsulation } from '@angular/core';
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, ContentChildren, EventEmitter, forwardRef, Inject, Input, NgModule, Output, signal, ViewChild, ViewEncapsulation } from '@angular/core';
|
3
3
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
4
|
-
import { PrimeTemplate, SharedModule
|
4
|
+
import { PrimeTemplate, SharedModule } from 'primeng/api';
|
5
5
|
import { AutoFocusModule } from 'primeng/autofocus';
|
6
6
|
import { ButtonModule } from 'primeng/button';
|
7
7
|
import { DomHandler } from 'primeng/dom';
|
@@ -36,7 +36,6 @@ class AutoComplete {
|
|
36
36
|
el;
|
37
37
|
renderer;
|
38
38
|
cd;
|
39
|
-
differs;
|
40
39
|
config;
|
41
40
|
overlayService;
|
42
41
|
zone;
|
@@ -165,24 +164,16 @@ class AutoComplete {
|
|
165
164
|
* @group Props
|
166
165
|
*/
|
167
166
|
type = 'text';
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
_baseZIndex;
|
179
|
-
get baseZIndex() {
|
180
|
-
return this._baseZIndex;
|
181
|
-
}
|
182
|
-
set baseZIndex(val) {
|
183
|
-
this._baseZIndex = val;
|
184
|
-
console.warn('The baseZIndex property is deprecated since v14.2.0, use overlayOptions property instead.');
|
185
|
-
}
|
167
|
+
/**
|
168
|
+
* Whether to automatically manage layering.
|
169
|
+
* @group Props
|
170
|
+
*/
|
171
|
+
autoZIndex = true;
|
172
|
+
/**
|
173
|
+
* Base zIndex value to use in layering.
|
174
|
+
* @group Props
|
175
|
+
*/
|
176
|
+
baseZIndex = 0;
|
186
177
|
/**
|
187
178
|
* Defines a string that labels the input for accessibility.
|
188
179
|
* @group Props
|
@@ -226,6 +217,7 @@ class AutoComplete {
|
|
226
217
|
/**
|
227
218
|
* Field of a suggested object to resolve and display.
|
228
219
|
* @group Props
|
220
|
+
* @deprecated use optionLabel property instead
|
229
221
|
*/
|
230
222
|
field;
|
231
223
|
/**
|
@@ -287,12 +279,12 @@ class AutoComplete {
|
|
287
279
|
* Name of the options field of an option group.
|
288
280
|
* @group Props
|
289
281
|
*/
|
290
|
-
optionGroupChildren;
|
282
|
+
optionGroupChildren = 'items';
|
291
283
|
/**
|
292
284
|
* Name of the label field of an option group.
|
293
285
|
* @group Props
|
294
286
|
*/
|
295
|
-
optionGroupLabel;
|
287
|
+
optionGroupLabel = 'label';
|
296
288
|
/**
|
297
289
|
* Options for the overlay element.
|
298
290
|
* @group Props
|
@@ -303,10 +295,10 @@ class AutoComplete {
|
|
303
295
|
* @group Props
|
304
296
|
*/
|
305
297
|
get suggestions() {
|
306
|
-
return this._suggestions;
|
298
|
+
return this._suggestions();
|
307
299
|
}
|
308
300
|
set suggestions(value) {
|
309
|
-
this._suggestions
|
301
|
+
this._suggestions.set(value);
|
310
302
|
this.handleSuggestionsChange();
|
311
303
|
}
|
312
304
|
/**
|
@@ -321,6 +313,59 @@ class AutoComplete {
|
|
321
313
|
this._itemSize = val;
|
322
314
|
console.warn('The itemSize property is deprecated, use virtualScrollItemSize property instead.');
|
323
315
|
}
|
316
|
+
/**
|
317
|
+
* Property name or getter function to use as the label of an option.
|
318
|
+
* @group Props
|
319
|
+
*/
|
320
|
+
optionLabel;
|
321
|
+
/**
|
322
|
+
* Unique identifier of the component.
|
323
|
+
* @group Props
|
324
|
+
*/
|
325
|
+
id;
|
326
|
+
/**
|
327
|
+
* Text to display when the search is active. Defaults to global value in i18n translation configuration.
|
328
|
+
* @group Props
|
329
|
+
* @defaultValue '{0} results are available'
|
330
|
+
*/
|
331
|
+
searchMessage;
|
332
|
+
/**
|
333
|
+
* Text to display when filtering does not return any results. Defaults to global value in i18n translation configuration.
|
334
|
+
* @group Props
|
335
|
+
* @defaultValue 'No selected item'
|
336
|
+
*/
|
337
|
+
emptySelectionMessage;
|
338
|
+
/**
|
339
|
+
* Text to be displayed in hidden accessible field when options are selected. Defaults to global value in i18n translation configuration.
|
340
|
+
* @group Props
|
341
|
+
* @defaultValue '{0} items selected'
|
342
|
+
*/
|
343
|
+
selectionMessage;
|
344
|
+
/**
|
345
|
+
* Whether to focus on the first visible or selected element when the overlay panel is shown.
|
346
|
+
* @group Props
|
347
|
+
*/
|
348
|
+
autoOptionFocus = true;
|
349
|
+
/**
|
350
|
+
* When enabled, the focused option is selected.
|
351
|
+
* @group Props
|
352
|
+
*/
|
353
|
+
selectOnFocus;
|
354
|
+
/**
|
355
|
+
* Locale to use in searching. The default locale is the host environment's current locale.
|
356
|
+
* @group Props
|
357
|
+
*/
|
358
|
+
searchLocale;
|
359
|
+
/**
|
360
|
+
* Property name or getter function to use as the disabled flag of an option, defaults to false when not defined.
|
361
|
+
* @group Props
|
362
|
+
*/
|
363
|
+
optionDisabled;
|
364
|
+
/**
|
365
|
+
* When enabled, the hovered option will be focused.
|
366
|
+
* @group Props
|
367
|
+
*/
|
368
|
+
focusOnHover;
|
324
369
|
/**
|
325
370
|
* Callback to invoke to search for suggestions.
|
326
371
|
* @param {AutoCompleteCompleteEvent} event - Custom complete event.
|
@@ -329,13 +374,13 @@ class AutoComplete {
|
|
329
374
|
completeMethod = new EventEmitter();
|
330
375
|
/**
|
331
376
|
* Callback to invoke when a suggestion is selected.
|
332
|
-
* @param {
|
377
|
+
* @param {AutoCompleteOnSelectEvent} event - custom select event.
|
333
378
|
* @group Emits
|
334
379
|
*/
|
335
380
|
onSelect = new EventEmitter();
|
336
381
|
/**
|
337
382
|
* Callback to invoke when a selected value is removed.
|
338
|
-
* @param {
|
383
|
+
* @param {AutoCompleteUnselectEvent} event - custom unselect event.
|
339
384
|
* @group Emits
|
340
385
|
*/
|
341
386
|
onUnselect = new EventEmitter();
|
@@ -410,40 +455,112 @@ class AutoComplete {
|
|
410
455
|
clearIconTemplate;
|
411
456
|
dropdownIconTemplate;
|
412
457
|
value;
|
413
|
-
_suggestions;
|
458
|
+
_suggestions = signal(null);
|
414
459
|
onModelChange = () => { };
|
415
460
|
onModelTouched = () => { };
|
416
461
|
timeout;
|
417
|
-
overlayVisible
|
462
|
+
overlayVisible;
|
418
463
|
suggestionsUpdated;
|
419
464
|
highlightOption;
|
420
465
|
highlightOptionChanged;
|
421
|
-
|
466
|
+
focused = false;
|
422
467
|
filled;
|
423
|
-
inputClick;
|
424
|
-
inputKeyDown;
|
425
|
-
noResults;
|
426
|
-
differ;
|
427
|
-
inputFieldValue = null;
|
428
468
|
loading;
|
429
469
|
scrollHandler;
|
430
|
-
documentResizeListener;
|
431
|
-
forceSelectionUpdateModelTimeout;
|
432
470
|
listId;
|
433
|
-
|
434
|
-
|
435
|
-
|
436
|
-
|
471
|
+
searchTimeout;
|
472
|
+
dirty = false;
|
473
|
+
modelValue = signal(null);
|
474
|
+
focusedMultipleOptionIndex = signal(-1);
|
475
|
+
focusedOptionIndex = signal(-1);
|
476
|
+
visibleOptions = computed(() => {
|
477
|
+
return this.group ? this.flatOptions(this._suggestions()) : this._suggestions() || [];
|
478
|
+
});
|
479
|
+
inputValue = computed(() => {
|
480
|
+
const modelValue = this.modelValue();
|
481
|
+
this.filled = ObjectUtils.isNotEmpty(this.modelValue());
|
482
|
+
if (modelValue) {
|
483
|
+
if (typeof modelValue === 'object') {
|
484
|
+
const label = this.getOptionLabel(modelValue);
|
485
|
+
return label != null ? label : modelValue;
|
486
|
+
}
|
487
|
+
else {
|
488
|
+
return modelValue;
|
489
|
+
}
|
490
|
+
}
|
491
|
+
else {
|
492
|
+
return '';
|
493
|
+
}
|
494
|
+
});
|
495
|
+
get focusedMultipleOptionId() {
|
496
|
+
return this.focusedMultipleOptionIndex() !== -1 ? `${this.id}_multiple_option_${this.focusedMultipleOptionIndex()}` : null;
|
497
|
+
}
|
498
|
+
get focusedOptionId() {
|
499
|
+
return this.focusedOptionIndex() !== -1 ? `${this.id}_${this.focusedOptionIndex()}` : null;
|
500
|
+
}
|
501
|
+
get containerClass() {
|
502
|
+
return {
|
503
|
+
'p-autocomplete p-component p-inputwrapper': true,
|
504
|
+
'p-disabled': this.disabled,
|
505
|
+
'p-focus': this.focused,
|
506
|
+
'p-autocomplete-dd': this.dropdown,
|
507
|
+
'p-autocomplete-multiple': this.multiple,
|
508
|
+
'p-inputwrapper-filled': this.modelValue() || ObjectUtils.isNotEmpty(this.inputValue),
|
509
|
+
'p-inputwrapper-focus': this.focused,
|
510
|
+
'p-overlay-open': this.overlayVisible
|
511
|
+
};
|
512
|
+
}
|
513
|
+
get multiContainerClass() {
|
514
|
+
return 'p-autocomplete-multiple-container p-component p-inputtext';
|
515
|
+
}
|
516
|
+
get panelClass() {
|
517
|
+
return {
|
518
|
+
'p-autocomplete-panel p-component': true,
|
519
|
+
'p-input-filled': this.config.inputStyle === 'filled',
|
520
|
+
'p-ripple-disabled': this.config.ripple === false
|
521
|
+
};
|
522
|
+
}
|
523
|
+
get inputClass() {
|
524
|
+
return {
|
525
|
+
'p-autocomplete-input p-inputtext p-component': !this.multiple,
|
526
|
+
'p-autocomplete-dd-input': this.dropdown
|
527
|
+
};
|
528
|
+
}
|
529
|
+
get searchResultMessageText() {
|
530
|
+
return ObjectUtils.isNotEmpty(this.visibleOptions()) && this.overlayVisible ? this.searchMessageText.replaceAll('{0}', this.visibleOptions().length) : this.emptySearchMessageText;
|
531
|
+
}
|
532
|
+
get searchMessageText() {
|
533
|
+
return this.searchMessage || this.config.translation.searchMessage || '';
|
534
|
+
}
|
535
|
+
get emptySearchMessageText() {
|
536
|
+
return this.emptyMessage || this.config.translation.emptySearchMessage || '';
|
537
|
+
}
|
538
|
+
get selectionMessageText() {
|
539
|
+
return this.selectionMessage || this.config.translation.selectionMessage || '';
|
540
|
+
}
|
541
|
+
get emptySelectionMessageText() {
|
542
|
+
return this.emptySelectionMessage || this.config.translation.emptySelectionMessage || '';
|
543
|
+
}
|
544
|
+
get selectedMessageText() {
|
545
|
+
return this.hasSelectedOption() ? this.selectionMessageText.replaceAll('{0}', this.multiple ? this.modelValue().length : '1') : this.emptySelectionMessageText;
|
546
|
+
}
|
547
|
+
get ariaSetSize() {
|
548
|
+
return this.visibleOptions().filter((option) => !this.isOptionGroup(option)).length;
|
549
|
+
}
|
550
|
+
get virtualScrollerDisabled() {
|
551
|
+
return !this.virtualScroll;
|
552
|
+
}
|
553
|
+
constructor(document, el, renderer, cd, config, overlayService, zone) {
|
437
554
|
this.document = document;
|
438
555
|
this.el = el;
|
439
556
|
this.renderer = renderer;
|
440
557
|
this.cd = cd;
|
441
|
-
this.differs = differs;
|
442
558
|
this.config = config;
|
443
559
|
this.overlayService = overlayService;
|
444
560
|
this.zone = zone;
|
445
|
-
|
446
|
-
|
561
|
+
}
|
562
|
+
ngOnInit() {
|
563
|
+
this.id = this.id || UniqueComponentId();
|
447
564
|
}
|
448
565
|
ngAfterViewChecked() {
|
449
566
|
//Use timeouts as since Angular 4.2, AfterViewChecked is broken and not called after panel is updated
|
@@ -457,44 +574,6 @@ class AutoComplete {
|
|
457
574
|
this.suggestionsUpdated = false;
|
458
575
|
});
|
459
576
|
}
|
460
|
-
if (this.highlightOptionChanged) {
|
461
|
-
this.zone.runOutsideAngular(() => {
|
462
|
-
setTimeout(() => {
|
463
|
-
if (this.overlayViewChild && this.itemsWrapper) {
|
464
|
-
let listItem = DomHandler.findSingle(this.overlayViewChild.overlayViewChild.nativeElement, 'li.p-highlight');
|
465
|
-
if (listItem) {
|
466
|
-
DomHandler.scrollInView(this.itemsWrapper, listItem);
|
467
|
-
}
|
468
|
-
}
|
469
|
-
}, 1);
|
470
|
-
this.highlightOptionChanged = false;
|
471
|
-
});
|
472
|
-
}
|
473
|
-
}
|
474
|
-
handleSuggestionsChange() {
|
475
|
-
if (this._suggestions != null && this.loading) {
|
476
|
-
this.highlightOption = null;
|
477
|
-
if (this._suggestions.length) {
|
478
|
-
this.noResults = false;
|
479
|
-
this.show();
|
480
|
-
this.suggestionsUpdated = true;
|
481
|
-
if (this.autoHighlight) {
|
482
|
-
this.highlightOption = this._suggestions[0];
|
483
|
-
}
|
484
|
-
}
|
485
|
-
else {
|
486
|
-
this.noResults = true;
|
487
|
-
if (this.showEmptyMessage) {
|
488
|
-
this.show();
|
489
|
-
this.suggestionsUpdated = true;
|
490
|
-
}
|
491
|
-
else {
|
492
|
-
this.hide();
|
493
|
-
}
|
494
|
-
}
|
495
|
-
this.loading = false;
|
496
|
-
this.isSearching = false;
|
497
|
-
}
|
498
577
|
}
|
499
578
|
ngAfterContentInit() {
|
500
579
|
this.templates.forEach((item) => {
|
@@ -538,518 +617,664 @@ class AutoComplete {
|
|
538
617
|
}
|
539
618
|
});
|
540
619
|
}
|
541
|
-
|
542
|
-
this.
|
543
|
-
|
544
|
-
|
545
|
-
|
620
|
+
handleSuggestionsChange() {
|
621
|
+
if (this.loading) {
|
622
|
+
this._suggestions() ? this.show() : !!this.emptyTemplate ? this.show() : this.hide();
|
623
|
+
const focusedOptionIndex = this.overlayVisible && this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;
|
624
|
+
this.focusedOptionIndex.set(focusedOptionIndex);
|
625
|
+
this.suggestionsUpdated = true;
|
626
|
+
this.loading = false;
|
627
|
+
this.cd.markForCheck();
|
628
|
+
}
|
546
629
|
}
|
547
|
-
|
548
|
-
return
|
630
|
+
flatOptions(options) {
|
631
|
+
return (options || []).reduce((result, option, index) => {
|
632
|
+
result.push({ optionGroup: option, group: true, index });
|
633
|
+
const optionGroupChildren = this.getOptionGroupChildren(option);
|
634
|
+
optionGroupChildren && optionGroupChildren.forEach((o) => result.push(o));
|
635
|
+
return result;
|
636
|
+
}, []);
|
549
637
|
}
|
550
|
-
|
551
|
-
return this.optionGroupLabel
|
638
|
+
isOptionGroup(option) {
|
639
|
+
return this.optionGroupLabel && option.optionGroup && option.group;
|
552
640
|
}
|
553
|
-
|
554
|
-
this.
|
641
|
+
findFirstOptionIndex() {
|
642
|
+
return this.visibleOptions().findIndex((option) => this.isValidOption(option));
|
555
643
|
}
|
556
|
-
|
557
|
-
this.
|
644
|
+
findLastOptionIndex() {
|
645
|
+
return ObjectUtils.findLastIndex(this.visibleOptions(), (option) => this.isValidOption(option));
|
558
646
|
}
|
559
|
-
|
560
|
-
|
561
|
-
this.
|
647
|
+
findFirstFocusedOptionIndex() {
|
648
|
+
const selectedIndex = this.findSelectedOptionIndex();
|
649
|
+
return selectedIndex < 0 ? this.findFirstOptionIndex() : selectedIndex;
|
562
650
|
}
|
563
|
-
|
564
|
-
|
565
|
-
|
651
|
+
findLastFocusedOptionIndex() {
|
652
|
+
const selectedIndex = this.findSelectedOptionIndex();
|
653
|
+
return selectedIndex < 0 ? this.findLastOptionIndex() : selectedIndex;
|
654
|
+
}
|
655
|
+
findSelectedOptionIndex() {
|
656
|
+
return this.hasSelectedOption() ? this.visibleOptions().findIndex((option) => this.isValidSelectedOption(option)) : -1;
|
657
|
+
}
|
658
|
+
findNextOptionIndex(index) {
|
659
|
+
const matchedOptionIndex = index < this.visibleOptions().length - 1
|
660
|
+
? this.visibleOptions()
|
661
|
+
.slice(index + 1)
|
662
|
+
.findIndex((option) => this.isValidOption(option))
|
663
|
+
: -1;
|
664
|
+
return matchedOptionIndex > -1 ? matchedOptionIndex + index + 1 : index;
|
665
|
+
}
|
666
|
+
findPrevOptionIndex(index) {
|
667
|
+
const matchedOptionIndex = index > 0 ? ObjectUtils.findLastIndex(this.visibleOptions().slice(0, index), (option) => this.isValidOption(option)) : -1;
|
668
|
+
return matchedOptionIndex > -1 ? matchedOptionIndex : index;
|
669
|
+
}
|
670
|
+
isValidSelectedOption(option) {
|
671
|
+
return this.isValidOption(option) && this.isSelected(option);
|
672
|
+
}
|
673
|
+
isValidOption(option) {
|
674
|
+
return option && !(this.isOptionDisabled(option) || this.isOptionGroup(option));
|
675
|
+
}
|
676
|
+
isOptionDisabled(option) {
|
677
|
+
return this.optionDisabled ? ObjectUtils.resolveFieldData(option, this.optionDisabled) : false;
|
678
|
+
}
|
679
|
+
isSelected(option) {
|
680
|
+
return ObjectUtils.equals(this.modelValue(), this.getOptionValue(option), this.equalityKey());
|
681
|
+
}
|
682
|
+
isOptionMatched(option, value) {
|
683
|
+
return this.isValidOption(option) && this.getOptionLabel(option).toLocaleLowerCase(this.searchLocale) === value.toLocaleLowerCase(this.searchLocale);
|
684
|
+
}
|
685
|
+
isInputClicked(event) {
|
686
|
+
if (this.multiple)
|
687
|
+
return event.target === this.multiContainerEL.nativeElement || this.multiContainerEL.nativeElement.contains(event.target);
|
688
|
+
else
|
689
|
+
return event.target === this.inputEL.nativeElement;
|
690
|
+
}
|
691
|
+
isDropdownClicked(event) {
|
692
|
+
return this.dropdownButton?.nativeElement ? event.target === this.dropdownButton.nativeElement || this.dropdownButton.nativeElement.contains(event.target) : false;
|
693
|
+
}
|
694
|
+
equalityKey() {
|
695
|
+
return this.dataKey; // TODO: The 'optionValue' properties can be added.
|
696
|
+
}
|
697
|
+
onContainerClick(event) {
|
698
|
+
if (this.disabled || this.loading || this.isInputClicked(event) || this.isDropdownClicked(event)) {
|
566
699
|
return;
|
567
700
|
}
|
568
|
-
if (this.
|
569
|
-
|
701
|
+
if (!this.overlayViewChild || !this.overlayViewChild.overlayViewChild.nativeElement.contains(event.target)) {
|
702
|
+
DomHandler.focus(this.inputEL.nativeElement);
|
703
|
+
}
|
704
|
+
}
|
705
|
+
handleDropdownClick(event) {
|
706
|
+
let query = undefined;
|
707
|
+
if (this.overlayVisible) {
|
708
|
+
this.hide(true);
|
570
709
|
}
|
571
|
-
|
572
|
-
|
573
|
-
|
574
|
-
this.
|
710
|
+
else {
|
711
|
+
DomHandler.focus(this.inputEL.nativeElement);
|
712
|
+
query = this.inputEL.nativeElement.value;
|
713
|
+
if (this.dropdownMode === 'blank')
|
714
|
+
this.search(event, '', 'dropdown');
|
715
|
+
else if (this.dropdownMode === 'current')
|
716
|
+
this.search(event, query, 'dropdown');
|
575
717
|
}
|
576
|
-
|
577
|
-
|
578
|
-
|
579
|
-
|
580
|
-
this.
|
718
|
+
this.onDropdownClick.emit({ originalEvent: event, query });
|
719
|
+
}
|
720
|
+
onInput(event) {
|
721
|
+
if (this.searchTimeout) {
|
722
|
+
clearTimeout(this.searchTimeout);
|
581
723
|
}
|
582
|
-
|
583
|
-
|
584
|
-
|
585
|
-
}, this.delay);
|
724
|
+
let query = event.target.value;
|
725
|
+
if (!this.multiple) {
|
726
|
+
this.updateModel(query);
|
586
727
|
}
|
587
|
-
|
728
|
+
if (query.length === 0) {
|
588
729
|
this.hide();
|
730
|
+
this.onClear.emit();
|
589
731
|
}
|
590
|
-
|
591
|
-
|
592
|
-
|
593
|
-
|
594
|
-
|
595
|
-
|
596
|
-
|
597
|
-
|
598
|
-
|
599
|
-
|
600
|
-
this.completeMethod.emit({
|
601
|
-
originalEvent: event,
|
602
|
-
query: query
|
603
|
-
});
|
604
|
-
setTimeout(() => {
|
605
|
-
this.isSearching = false;
|
606
|
-
}, 100);
|
732
|
+
else {
|
733
|
+
if (query.length >= this.minLength) {
|
734
|
+
this.focusedOptionIndex.set(-1);
|
735
|
+
this.searchTimeout = setTimeout(() => {
|
736
|
+
this.search(event, query, 'input');
|
737
|
+
}, this.delay);
|
738
|
+
}
|
739
|
+
else {
|
740
|
+
this.hide();
|
741
|
+
}
|
607
742
|
}
|
608
743
|
}
|
609
|
-
|
610
|
-
if (this.
|
611
|
-
|
612
|
-
this.
|
613
|
-
|
614
|
-
|
615
|
-
|
616
|
-
|
617
|
-
|
618
|
-
|
619
|
-
|
744
|
+
onInputChange(event) {
|
745
|
+
if (this.forceSelection) {
|
746
|
+
let valid = false;
|
747
|
+
if (this.visibleOptions()) {
|
748
|
+
const matchedValue = this.visibleOptions().find((option) => this.isOptionMatched(option, this.inputEL.nativeElement.value || ''));
|
749
|
+
if (matchedValue !== undefined) {
|
750
|
+
valid = true;
|
751
|
+
!this.isSelected(matchedValue) && this.onOptionSelect(event, matchedValue);
|
752
|
+
}
|
753
|
+
}
|
754
|
+
if (!valid) {
|
755
|
+
this.inputEL.nativeElement.value = '';
|
756
|
+
!this.multiple && this.updateModel(null);
|
620
757
|
}
|
621
758
|
}
|
622
|
-
|
623
|
-
|
624
|
-
|
625
|
-
|
759
|
+
}
|
760
|
+
onInputFocus(event) {
|
761
|
+
if (this.disabled) {
|
762
|
+
// For ScreenReaders
|
763
|
+
return;
|
626
764
|
}
|
627
|
-
this.
|
628
|
-
|
629
|
-
if (focus) {
|
630
|
-
this.itemClicked = true;
|
631
|
-
this.focusInput();
|
765
|
+
if (!this.dirty && this.completeOnFocus) {
|
766
|
+
this.search(event, event.target.value, 'focus');
|
632
767
|
}
|
633
|
-
this.
|
768
|
+
this.dirty = true;
|
769
|
+
this.focused = true;
|
770
|
+
const focusedOptionIndex = this.focusedOptionIndex() !== -1 ? this.focusedOptionIndex() : this.overlayVisible && this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;
|
771
|
+
this.focusedOptionIndex.set(focusedOptionIndex);
|
772
|
+
this.overlayVisible && this.scrollInView(this.focusedOptionIndex());
|
773
|
+
this.onFocus.emit(event);
|
634
774
|
}
|
635
|
-
|
636
|
-
if (this.
|
637
|
-
|
638
|
-
|
639
|
-
this.overlayVisible = true;
|
640
|
-
}
|
775
|
+
onMultipleContainerFocus(event) {
|
776
|
+
if (this.disabled) {
|
777
|
+
// For ScreenReaders
|
778
|
+
return;
|
641
779
|
}
|
642
|
-
this.
|
643
|
-
this.cd.markForCheck();
|
780
|
+
this.focused = true;
|
644
781
|
}
|
645
|
-
|
646
|
-
this.
|
647
|
-
this.
|
648
|
-
|
649
|
-
|
782
|
+
onMultipleContainerBlur(event) {
|
783
|
+
this.focusedMultipleOptionIndex.set(-1);
|
784
|
+
this.focused = false;
|
785
|
+
}
|
786
|
+
onMultipleContainerKeyDown(event) {
|
787
|
+
if (this.disabled) {
|
788
|
+
event.preventDefault();
|
789
|
+
return;
|
650
790
|
}
|
651
|
-
|
652
|
-
|
653
|
-
|
791
|
+
switch (event.code) {
|
792
|
+
case 'ArrowLeft':
|
793
|
+
this.onArrowLeftKeyOnMultiple(event);
|
794
|
+
break;
|
795
|
+
case 'ArrowRight':
|
796
|
+
this.onArrowRightKeyOnMultiple(event);
|
797
|
+
break;
|
798
|
+
case 'Backspace':
|
799
|
+
this.onBackspaceKeyOnMultiple(event);
|
800
|
+
break;
|
801
|
+
default:
|
802
|
+
break;
|
654
803
|
}
|
655
|
-
this.updateFilledState();
|
656
|
-
this.onModelChange(this.value);
|
657
|
-
this.onClear.emit();
|
658
804
|
}
|
659
|
-
|
660
|
-
|
661
|
-
|
662
|
-
|
663
|
-
|
805
|
+
onInputBlur(event) {
|
806
|
+
this.dirty = false;
|
807
|
+
this.focused = false;
|
808
|
+
this.focusedOptionIndex.set(-1);
|
809
|
+
this.onModelTouched();
|
810
|
+
this.onBlur.emit(event);
|
664
811
|
}
|
665
|
-
|
666
|
-
|
667
|
-
return data !== (null || undefined) ? data : '';
|
812
|
+
onInputPaste(event) {
|
813
|
+
this.onKeyDown(event);
|
668
814
|
}
|
669
|
-
|
670
|
-
this.
|
671
|
-
this.onHide.emit(event);
|
672
|
-
this.cd.markForCheck();
|
815
|
+
onInputKeyUp(event) {
|
816
|
+
this.onKeyUp.emit(event);
|
673
817
|
}
|
674
|
-
|
818
|
+
onKeyDown(event) {
|
819
|
+
if (this.disabled) {
|
820
|
+
event.preventDefault();
|
821
|
+
return;
|
822
|
+
}
|
823
|
+
switch (event.code) {
|
824
|
+
case 'ArrowDown':
|
825
|
+
this.onArrowDownKey(event);
|
826
|
+
break;
|
827
|
+
case 'ArrowUp':
|
828
|
+
this.onArrowUpKey(event);
|
829
|
+
break;
|
830
|
+
case 'ArrowLeft':
|
831
|
+
this.onArrowLeftKey(event);
|
832
|
+
break;
|
833
|
+
case 'ArrowRight':
|
834
|
+
this.onArrowRightKey(event);
|
835
|
+
break;
|
836
|
+
case 'Home':
|
837
|
+
this.onHomeKey(event);
|
838
|
+
break;
|
839
|
+
case 'End':
|
840
|
+
this.onEndKey(event);
|
841
|
+
break;
|
842
|
+
case 'PageDown':
|
843
|
+
this.onPageDownKey(event);
|
844
|
+
break;
|
845
|
+
case 'PageUp':
|
846
|
+
this.onPageUpKey(event);
|
847
|
+
break;
|
848
|
+
case 'Enter':
|
849
|
+
case 'NumpadEnter':
|
850
|
+
this.onEnterKey(event);
|
851
|
+
break;
|
852
|
+
case 'Escape':
|
853
|
+
this.onEscapeKey(event);
|
854
|
+
break;
|
855
|
+
case 'Tab':
|
856
|
+
this.onTabKey(event);
|
857
|
+
break;
|
858
|
+
case 'Backspace':
|
859
|
+
this.onBackspaceKey(event);
|
860
|
+
break;
|
861
|
+
case 'ShiftLeft':
|
862
|
+
case 'ShiftRight':
|
863
|
+
//NOOP
|
864
|
+
break;
|
865
|
+
default:
|
866
|
+
break;
|
867
|
+
}
|
868
|
+
}
|
869
|
+
onArrowDownKey(event) {
|
675
870
|
if (!this.overlayVisible) {
|
676
|
-
|
677
|
-
|
678
|
-
|
679
|
-
|
680
|
-
|
681
|
-
|
682
|
-
|
683
|
-
|
684
|
-
|
685
|
-
|
686
|
-
|
687
|
-
|
688
|
-
|
689
|
-
});
|
690
|
-
this.search(event, queryValue);
|
871
|
+
return;
|
872
|
+
}
|
873
|
+
const optionIndex = this.focusedOptionIndex() !== -1 ? this.findNextOptionIndex(this.focusedOptionIndex()) : this.findFirstFocusedOptionIndex();
|
874
|
+
this.changeFocusedOptionIndex(event, optionIndex);
|
875
|
+
event.preventDefault();
|
876
|
+
}
|
877
|
+
onArrowUpKey(event) {
|
878
|
+
if (!this.overlayVisible) {
|
879
|
+
return;
|
880
|
+
}
|
881
|
+
if (event.altKey) {
|
882
|
+
if (this.focusedOptionIndex() !== -1) {
|
883
|
+
this.onOptionSelect(event, this.visibleOptions()[this.focusedOptionIndex()]);
|
691
884
|
}
|
885
|
+
this.overlayVisible && this.hide();
|
886
|
+
event.preventDefault();
|
692
887
|
}
|
693
888
|
else {
|
694
|
-
this.
|
889
|
+
const optionIndex = this.focusedOptionIndex() !== -1 ? this.findPrevOptionIndex(this.focusedOptionIndex()) : this.findLastFocusedOptionIndex();
|
890
|
+
this.changeFocusedOptionIndex(event, optionIndex);
|
891
|
+
event.preventDefault();
|
695
892
|
}
|
696
893
|
}
|
697
|
-
|
698
|
-
|
699
|
-
|
700
|
-
|
701
|
-
this.
|
894
|
+
onArrowLeftKey(event) {
|
895
|
+
const target = event.currentTarget;
|
896
|
+
this.focusedOptionIndex.set(-1);
|
897
|
+
if (this.multiple) {
|
898
|
+
if (ObjectUtils.isEmpty(target.value) && this.hasSelectedOption()) {
|
899
|
+
DomHandler.focus(this.multiContainerEL.nativeElement);
|
900
|
+
this.focusedMultipleOptionIndex.set(this.modelValue().length);
|
901
|
+
}
|
902
|
+
else {
|
903
|
+
event.stopPropagation(); // To prevent onArrowLeftKeyOnMultiple method
|
904
|
+
}
|
905
|
+
}
|
702
906
|
}
|
703
|
-
|
704
|
-
|
907
|
+
onArrowRightKey(event) {
|
908
|
+
this.focusedOptionIndex.set(-1);
|
909
|
+
this.multiple && event.stopPropagation(); // To prevent onArrowRightKeyOnMultiple method
|
705
910
|
}
|
706
|
-
|
707
|
-
|
708
|
-
|
709
|
-
|
710
|
-
this.
|
711
|
-
|
712
|
-
this.onUnselect.emit(removedValue);
|
911
|
+
onHomeKey(event) {
|
912
|
+
const { currentTarget } = event;
|
913
|
+
const len = currentTarget.value.length;
|
914
|
+
currentTarget.setSelectionRange(0, event.shiftKey ? len : 0);
|
915
|
+
this.focusedOptionIndex.set(-1);
|
916
|
+
event.preventDefault();
|
713
917
|
}
|
714
|
-
|
715
|
-
|
716
|
-
|
717
|
-
|
718
|
-
|
719
|
-
|
720
|
-
|
721
|
-
|
722
|
-
|
723
|
-
|
724
|
-
|
725
|
-
|
726
|
-
|
727
|
-
|
728
|
-
|
729
|
-
|
730
|
-
|
731
|
-
|
732
|
-
else {
|
733
|
-
this.highlightOption = this.getOptionGroupChildren(this.suggestions[0])[0];
|
734
|
-
}
|
735
|
-
}
|
736
|
-
else {
|
737
|
-
let highlightItemIndex = this.findOptionIndex(this.highlightOption, this.suggestions);
|
738
|
-
if (highlightItemIndex != -1) {
|
739
|
-
var nextItemIndex = highlightItemIndex + 1;
|
740
|
-
if (nextItemIndex != this.suggestions.length) {
|
741
|
-
this.highlightOption = this.suggestions[nextItemIndex];
|
742
|
-
this.highlightOptionChanged = true;
|
743
|
-
}
|
744
|
-
}
|
745
|
-
else {
|
746
|
-
this.highlightOption = this.suggestions[0];
|
747
|
-
}
|
748
|
-
}
|
749
|
-
event.preventDefault();
|
750
|
-
break;
|
751
|
-
//up
|
752
|
-
case 38:
|
753
|
-
if (this.group) {
|
754
|
-
let highlightItemIndex = this.findOptionGroupIndex(this.highlightOption, this.suggestions);
|
755
|
-
if (highlightItemIndex !== -1) {
|
756
|
-
let prevItemIndex = highlightItemIndex.itemIndex - 1;
|
757
|
-
if (prevItemIndex >= 0) {
|
758
|
-
this.highlightOption = this.getOptionGroupChildren(this.suggestions[highlightItemIndex.groupIndex])[prevItemIndex];
|
759
|
-
this.highlightOptionChanged = true;
|
760
|
-
}
|
761
|
-
else if (prevItemIndex < 0) {
|
762
|
-
let prevGroup = this.suggestions[highlightItemIndex.groupIndex - 1];
|
763
|
-
if (prevGroup) {
|
764
|
-
this.highlightOption = this.getOptionGroupChildren(prevGroup)[this.getOptionGroupChildren(prevGroup).length - 1];
|
765
|
-
this.highlightOptionChanged = true;
|
766
|
-
}
|
767
|
-
}
|
768
|
-
}
|
769
|
-
}
|
770
|
-
else {
|
771
|
-
let highlightItemIndex = this.findOptionIndex(this.highlightOption, this.suggestions);
|
772
|
-
if (highlightItemIndex > 0) {
|
773
|
-
let prevItemIndex = highlightItemIndex - 1;
|
774
|
-
this.highlightOption = this.suggestions[prevItemIndex];
|
775
|
-
this.highlightOptionChanged = true;
|
776
|
-
}
|
777
|
-
}
|
778
|
-
event.preventDefault();
|
779
|
-
break;
|
780
|
-
//enter
|
781
|
-
case 13:
|
782
|
-
if (this.highlightOption) {
|
783
|
-
this.selectItem(this.highlightOption);
|
784
|
-
this.hide();
|
785
|
-
}
|
786
|
-
event.preventDefault();
|
787
|
-
break;
|
788
|
-
//escape
|
789
|
-
case 27:
|
790
|
-
this.hide();
|
791
|
-
event.preventDefault();
|
792
|
-
break;
|
793
|
-
//tab
|
794
|
-
case 9:
|
795
|
-
if (this.highlightOption) {
|
796
|
-
this.selectItem(this.highlightOption);
|
797
|
-
}
|
798
|
-
this.hide();
|
799
|
-
break;
|
800
|
-
}
|
918
|
+
onEndKey(event) {
|
919
|
+
const { currentTarget } = event;
|
920
|
+
const len = currentTarget.value.length;
|
921
|
+
currentTarget.setSelectionRange(event.shiftKey ? 0 : len, len);
|
922
|
+
this.focusedOptionIndex.set(-1);
|
923
|
+
event.preventDefault();
|
924
|
+
}
|
925
|
+
onPageDownKey(event) {
|
926
|
+
this.scrollInView(this.visibleOptions().length - 1);
|
927
|
+
event.preventDefault();
|
928
|
+
}
|
929
|
+
onPageUpKey(event) {
|
930
|
+
this.scrollInView(0);
|
931
|
+
event.preventDefault();
|
932
|
+
}
|
933
|
+
onEnterKey(event) {
|
934
|
+
if (!this.overlayVisible) {
|
935
|
+
this.onArrowDownKey(event);
|
801
936
|
}
|
802
937
|
else {
|
803
|
-
if (
|
804
|
-
this.
|
805
|
-
}
|
806
|
-
else if (event.ctrlKey && event.key === 'z' && !this.multiple) {
|
807
|
-
this.inputEL.nativeElement.value = this.resolveFieldData(null);
|
808
|
-
this.value = '';
|
809
|
-
this.onModelChange(this.value);
|
938
|
+
if (this.focusedOptionIndex() !== -1) {
|
939
|
+
this.onOptionSelect(event, this.visibleOptions()[this.focusedOptionIndex()]);
|
810
940
|
}
|
811
|
-
|
812
|
-
|
813
|
-
|
814
|
-
|
941
|
+
this.hide();
|
942
|
+
}
|
943
|
+
event.preventDefault();
|
944
|
+
}
|
945
|
+
onEscapeKey(event) {
|
946
|
+
this.overlayVisible && this.hide(true);
|
947
|
+
event.preventDefault();
|
948
|
+
}
|
949
|
+
onTabKey(event) {
|
950
|
+
if (this.focusedOptionIndex() !== -1) {
|
951
|
+
this.onOptionSelect(event, this.visibleOptions()[this.focusedOptionIndex()]);
|
952
|
+
}
|
953
|
+
this.overlayVisible && this.hide();
|
954
|
+
}
|
955
|
+
onBackspaceKey(event) {
|
956
|
+
if (this.multiple) {
|
957
|
+
if (ObjectUtils.isNotEmpty(this.modelValue()) && !this.inputEL.nativeElement.value) {
|
958
|
+
const removedValue = this.modelValue()[this.modelValue().length - 1];
|
959
|
+
const newValue = this.modelValue().slice(0, -1);
|
960
|
+
this.updateModel(newValue);
|
961
|
+
this.onUnselect.emit({ originalEvent: event, value: removedValue });
|
815
962
|
}
|
963
|
+
event.stopPropagation(); // To prevent onBackspaceKeyOnMultiple method
|
964
|
+
}
|
965
|
+
}
|
966
|
+
onArrowLeftKeyOnMultiple(event) {
|
967
|
+
const optionIndex = this.focusedMultipleOptionIndex() < 1 ? 0 : this.focusedMultipleOptionIndex() - 1;
|
968
|
+
this.focusedMultipleOptionIndex.set(optionIndex);
|
969
|
+
}
|
970
|
+
onArrowRightKeyOnMultiple(event) {
|
971
|
+
let optionIndex = this.focusedMultipleOptionIndex();
|
972
|
+
optionIndex++;
|
973
|
+
this.focusedMultipleOptionIndex.set(optionIndex);
|
974
|
+
if (optionIndex > this.modelValue().length - 1) {
|
975
|
+
this.focusedMultipleOptionIndex.set(-1);
|
976
|
+
DomHandler.focus(this.inputEL.nativeElement);
|
977
|
+
}
|
978
|
+
}
|
979
|
+
onBackspaceKeyOnMultiple(event) {
|
980
|
+
if (this.focusedMultipleOptionIndex() !== -1) {
|
981
|
+
this.removeOption(event, this.focusedMultipleOptionIndex());
|
816
982
|
}
|
983
|
+
}
|
984
|
+
onOptionSelect(event, option, isHide = true) {
|
985
|
+
const value = this.getOptionValue(option);
|
817
986
|
if (this.multiple) {
|
818
|
-
|
819
|
-
|
820
|
-
|
821
|
-
if (this.value && this.value.length && !this.multiInputEl?.nativeElement.value) {
|
822
|
-
this.value = [...this.value];
|
823
|
-
const removedValue = this.value.pop();
|
824
|
-
this.onModelChange(this.value);
|
825
|
-
this.updateFilledState();
|
826
|
-
this.onUnselect.emit(removedValue);
|
827
|
-
}
|
828
|
-
break;
|
987
|
+
this.inputEL.nativeElement.value = '';
|
988
|
+
if (!this.isSelected(option)) {
|
989
|
+
this.updateModel([...(this.modelValue() || []), value]);
|
829
990
|
}
|
830
991
|
}
|
831
|
-
|
992
|
+
else {
|
993
|
+
this.updateModel(value);
|
994
|
+
}
|
995
|
+
this.onSelect.emit({ originalEvent: event, value: option });
|
996
|
+
isHide && this.hide(true);
|
832
997
|
}
|
833
|
-
|
834
|
-
this.
|
998
|
+
onOptionMouseEnter(event, index) {
|
999
|
+
if (this.focusOnHover) {
|
1000
|
+
this.changeFocusedOptionIndex(event, index);
|
1001
|
+
}
|
835
1002
|
}
|
836
|
-
|
837
|
-
|
838
|
-
|
839
|
-
|
1003
|
+
search(event, query, source) {
|
1004
|
+
//allow empty string but not undefined or null
|
1005
|
+
if (query === undefined || query === null) {
|
1006
|
+
return;
|
840
1007
|
}
|
841
|
-
|
842
|
-
|
843
|
-
|
1008
|
+
//do not search blank values on input change
|
1009
|
+
if (source === 'input' && query.trim().length === 0) {
|
1010
|
+
return;
|
1011
|
+
}
|
1012
|
+
this.loading = true;
|
1013
|
+
this.completeMethod.emit({ originalEvent: event, query });
|
844
1014
|
}
|
845
|
-
|
846
|
-
|
847
|
-
this.
|
848
|
-
|
1015
|
+
removeOption(event, index) {
|
1016
|
+
const removedOption = this.modelValue()[index];
|
1017
|
+
const value = this.modelValue()
|
1018
|
+
.filter((_, i) => i !== index)
|
1019
|
+
.map((option) => this.getOptionValue(option));
|
1020
|
+
this.updateModel(value);
|
1021
|
+
this.onUnselect.emit({ originalEvent: event, value: removedOption });
|
1022
|
+
DomHandler.focus(this.inputEL.nativeElement);
|
849
1023
|
}
|
850
|
-
|
851
|
-
|
852
|
-
|
853
|
-
|
854
|
-
|
855
|
-
|
856
|
-
|
857
|
-
|
858
|
-
|
859
|
-
|
860
|
-
|
861
|
-
for (let suggestion of suggestions) {
|
862
|
-
let itemValue = this.field ? ObjectUtils.resolveFieldData(suggestion, this.field) : suggestion;
|
863
|
-
if (itemValue && inputValue.toLowerCase() === itemValue.toLowerCase().trim()) {
|
864
|
-
valid = true;
|
865
|
-
this.forceSelectionUpdateModelTimeout = setTimeout(() => {
|
866
|
-
this.selectItem(suggestion, false);
|
867
|
-
}, 250);
|
868
|
-
break;
|
869
|
-
}
|
870
|
-
}
|
1024
|
+
updateModel(value) {
|
1025
|
+
this.value = value;
|
1026
|
+
this.modelValue.set(value);
|
1027
|
+
this.onModelChange(value);
|
1028
|
+
this.updateInputValue();
|
1029
|
+
this.cd.markForCheck();
|
1030
|
+
}
|
1031
|
+
updateInputValue() {
|
1032
|
+
if (this.value && this.inputEL && this.inputEL.nativeElement) {
|
1033
|
+
if (!this.multiple) {
|
1034
|
+
this.inputEL.nativeElement.value = this.inputValue();
|
871
1035
|
}
|
872
|
-
|
873
|
-
|
874
|
-
this.multiInputEl.nativeElement.value = '';
|
875
|
-
}
|
876
|
-
else {
|
877
|
-
this.value = null;
|
878
|
-
this.inputEL.nativeElement.value = '';
|
879
|
-
}
|
880
|
-
this.onClear.emit(event);
|
881
|
-
this.onModelChange(this.value);
|
882
|
-
this.updateFilledState();
|
1036
|
+
else {
|
1037
|
+
this.inputEL.nativeElement.value = '';
|
883
1038
|
}
|
884
1039
|
}
|
885
1040
|
}
|
886
|
-
|
887
|
-
this.
|
888
|
-
|
889
|
-
|
890
|
-
|
891
|
-
if (this.value && this.value.length) {
|
892
|
-
for (let i = 0; i < this.value.length; i++) {
|
893
|
-
if (ObjectUtils.equals(this.value[i], val, this.dataKey)) {
|
894
|
-
selected = true;
|
895
|
-
break;
|
896
|
-
}
|
897
|
-
}
|
1041
|
+
autoUpdateModel() {
|
1042
|
+
if ((this.selectOnFocus || this.autoHighlight) && this.autoOptionFocus && !this.hasSelectedOption()) {
|
1043
|
+
const focusedOptionIndex = this.findFirstFocusedOptionIndex();
|
1044
|
+
this.focusedOptionIndex.set(focusedOptionIndex);
|
1045
|
+
this.onOptionSelect(null, this.visibleOptions()[this.focusedOptionIndex()], false);
|
898
1046
|
}
|
899
|
-
|
900
|
-
|
901
|
-
|
902
|
-
|
903
|
-
|
904
|
-
|
905
|
-
|
906
|
-
index = i;
|
907
|
-
break;
|
908
|
-
}
|
1047
|
+
}
|
1048
|
+
scrollInView(index = -1) {
|
1049
|
+
const id = index !== -1 ? `${this.id}_${index}` : this.focusedOptionId;
|
1050
|
+
if (this.itemsViewChild && this.itemsViewChild.nativeElement) {
|
1051
|
+
const element = DomHandler.findSingle(this.itemsViewChild.nativeElement, `li[id="${id}"]`);
|
1052
|
+
if (element) {
|
1053
|
+
element.scrollIntoView && element.scrollIntoView({ block: 'nearest', inline: 'nearest' });
|
909
1054
|
}
|
910
|
-
|
911
|
-
|
912
|
-
|
913
|
-
|
914
|
-
let groupIndex, itemIndex;
|
915
|
-
if (opts) {
|
916
|
-
for (let i = 0; i < opts.length; i++) {
|
917
|
-
groupIndex = i;
|
918
|
-
itemIndex = this.findOptionIndex(val, this.getOptionGroupChildren(opts[i]));
|
919
|
-
if (itemIndex !== -1) {
|
920
|
-
break;
|
921
|
-
}
|
1055
|
+
else if (!this.virtualScrollerDisabled) {
|
1056
|
+
setTimeout(() => {
|
1057
|
+
this.virtualScroll && this.scroller?.scrollToIndex(index !== -1 ? index : this.focusedOptionIndex());
|
1058
|
+
}, 0);
|
922
1059
|
}
|
923
1060
|
}
|
924
|
-
|
925
|
-
|
1061
|
+
}
|
1062
|
+
changeFocusedOptionIndex(event, index) {
|
1063
|
+
if (this.focusedOptionIndex() !== index) {
|
1064
|
+
this.focusedOptionIndex.set(index);
|
1065
|
+
this.scrollInView();
|
1066
|
+
if (this.selectOnFocus || this.autoHighlight) {
|
1067
|
+
this.onOptionSelect(event, this.visibleOptions()[index], false);
|
1068
|
+
}
|
926
1069
|
}
|
927
|
-
|
928
|
-
|
1070
|
+
}
|
1071
|
+
show(isFocus = false) {
|
1072
|
+
this.dirty = true;
|
1073
|
+
this.overlayVisible = true;
|
1074
|
+
const focusedOptionIndex = this.focusedOptionIndex() !== -1 ? this.focusedOptionIndex() : this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;
|
1075
|
+
this.focusedOptionIndex.set(focusedOptionIndex);
|
1076
|
+
isFocus && DomHandler.focus(this.inputEL.nativeElement);
|
1077
|
+
if (isFocus) {
|
1078
|
+
DomHandler.focus(this.inputEL.nativeElement);
|
929
1079
|
}
|
1080
|
+
this.onShow.emit();
|
1081
|
+
this.cd.markForCheck();
|
930
1082
|
}
|
931
|
-
|
932
|
-
|
933
|
-
this.
|
934
|
-
|
935
|
-
this.
|
1083
|
+
hide(isFocus = false) {
|
1084
|
+
const _hide = () => {
|
1085
|
+
this.dirty = isFocus;
|
1086
|
+
this.overlayVisible = false;
|
1087
|
+
this.focusedOptionIndex.set(-1);
|
1088
|
+
isFocus && DomHandler.focus(this.inputEL.nativeElement);
|
1089
|
+
this.onHide.emit();
|
1090
|
+
this.cd.markForCheck();
|
1091
|
+
};
|
1092
|
+
setTimeout(() => {
|
1093
|
+
_hide();
|
1094
|
+
}, 0); // For ScreenReaders
|
936
1095
|
}
|
937
|
-
|
938
|
-
|
939
|
-
this.
|
940
|
-
|
941
|
-
|
1096
|
+
clear() {
|
1097
|
+
this.updateModel(null);
|
1098
|
+
this.inputEL.nativeElement.value = '';
|
1099
|
+
this.onClear.emit();
|
1100
|
+
}
|
1101
|
+
writeValue(value) {
|
1102
|
+
this.value = value;
|
1103
|
+
this.filled = this.value && this.value.length ? true : false;
|
1104
|
+
this.updateModel(value);
|
1105
|
+
this.cd.markForCheck();
|
1106
|
+
}
|
1107
|
+
hasSelectedOption() {
|
1108
|
+
return ObjectUtils.isNotEmpty(this.modelValue());
|
1109
|
+
}
|
1110
|
+
getAriaPosInset(index) {
|
1111
|
+
return ((this.optionGroupLabel
|
1112
|
+
? index -
|
1113
|
+
this.visibleOptions()
|
1114
|
+
.slice(0, index)
|
1115
|
+
.filter((option) => this.isOptionGroup(option)).length
|
1116
|
+
: index) + 1);
|
1117
|
+
}
|
1118
|
+
getOptionLabel(option) {
|
1119
|
+
return this.field || this.optionLabel ? ObjectUtils.resolveFieldData(option, this.field || this.optionLabel) : option && option.label != undefined ? option.label : option;
|
1120
|
+
}
|
1121
|
+
getOptionValue(option) {
|
1122
|
+
return option; // TODO: The 'optionValue' properties can be added.
|
1123
|
+
}
|
1124
|
+
getOptionIndex(index, scrollerOptions) {
|
1125
|
+
return this.virtualScrollerDisabled ? index : scrollerOptions && scrollerOptions.getItemOptions(index)['index'];
|
1126
|
+
}
|
1127
|
+
getOptionGroupLabel(optionGroup) {
|
1128
|
+
return this.optionGroupLabel ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupLabel) : optionGroup && optionGroup.label != undefined ? optionGroup.label : optionGroup;
|
1129
|
+
}
|
1130
|
+
getOptionGroupChildren(optionGroup) {
|
1131
|
+
return this.optionGroupChildren ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupChildren) : optionGroup.items;
|
1132
|
+
}
|
1133
|
+
registerOnChange(fn) {
|
1134
|
+
this.onModelChange = fn;
|
1135
|
+
}
|
1136
|
+
registerOnTouched(fn) {
|
1137
|
+
this.onModelTouched = fn;
|
1138
|
+
}
|
1139
|
+
setDisabledState(val) {
|
1140
|
+
this.disabled = val;
|
1141
|
+
this.cd.markForCheck();
|
1142
|
+
}
|
1143
|
+
onOverlayAnimationStart(event) {
|
1144
|
+
if (event.toState === 'visible') {
|
1145
|
+
this.itemsWrapper = DomHandler.findSingle(this.overlayViewChild.overlayViewChild?.nativeElement, this.virtualScroll ? '.p-scroller' : '.p-autocomplete-panel');
|
1146
|
+
this.virtualScroll && this.scroller?.setContentEl(this.itemsViewChild?.nativeElement);
|
942
1147
|
}
|
943
|
-
this.updateFilledState();
|
944
1148
|
}
|
945
1149
|
ngOnDestroy() {
|
946
|
-
if (this.forceSelectionUpdateModelTimeout) {
|
947
|
-
clearTimeout(this.forceSelectionUpdateModelTimeout);
|
948
|
-
this.forceSelectionUpdateModelTimeout = null;
|
949
|
-
}
|
950
1150
|
if (this.scrollHandler) {
|
951
1151
|
this.scrollHandler.destroy();
|
952
1152
|
this.scrollHandler = null;
|
953
1153
|
}
|
954
1154
|
}
|
955
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: AutoComplete, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token:
|
956
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: AutoComplete, selector: "p-autoComplete", inputs: { minLength: "minLength", delay: "delay", style: "style", panelStyle: "panelStyle", styleClass: "styleClass", panelStyleClass: "panelStyleClass", inputStyle: "inputStyle", inputId: "inputId", inputStyleClass: "inputStyleClass", placeholder: "placeholder", readonly: "readonly", disabled: "disabled", scrollHeight: "scrollHeight", lazy: "lazy", virtualScroll: "virtualScroll", virtualScrollItemSize: "virtualScrollItemSize", virtualScrollOptions: "virtualScrollOptions", maxlength: "maxlength", name: "name", required: "required", size: "size", appendTo: "appendTo", autoHighlight: "autoHighlight", forceSelection: "forceSelection", type: "type", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", ariaLabel: "ariaLabel", dropdownAriaLabel: "dropdownAriaLabel", ariaLabelledBy: "ariaLabelledBy", dropdownIcon: "dropdownIcon", unique: "unique", group: "group", completeOnFocus: "completeOnFocus", showClear: "showClear", field: "field", dropdown: "dropdown", showEmptyMessage: "showEmptyMessage", dropdownMode: "dropdownMode", multiple: "multiple", tabindex: "tabindex", dataKey: "dataKey", emptyMessage: "emptyMessage", showTransitionOptions: "showTransitionOptions", hideTransitionOptions: "hideTransitionOptions", autofocus: "autofocus", autocomplete: "autocomplete", optionGroupChildren: "optionGroupChildren", optionGroupLabel: "optionGroupLabel", overlayOptions: "overlayOptions", suggestions: "suggestions", itemSize: "itemSize" }, outputs: { completeMethod: "completeMethod", onSelect: "onSelect", onUnselect: "onUnselect", onFocus: "onFocus", onBlur: "onBlur", onDropdownClick: "onDropdownClick", onClear: "onClear", onKeyUp: "onKeyUp", onShow: "onShow", onHide: "onHide", onLazyLoad: "onLazyLoad" }, host: { properties: { "class.p-inputwrapper-filled": "filled", "class.p-inputwrapper-focus": "((
|
957
|
-
<
|
1155
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: AutoComplete, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i1.PrimeNGConfig }, { token: i1.OverlayService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
1156
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: AutoComplete, selector: "p-autoComplete", inputs: { minLength: "minLength", delay: "delay", style: "style", panelStyle: "panelStyle", styleClass: "styleClass", panelStyleClass: "panelStyleClass", inputStyle: "inputStyle", inputId: "inputId", inputStyleClass: "inputStyleClass", placeholder: "placeholder", readonly: "readonly", disabled: "disabled", scrollHeight: "scrollHeight", lazy: "lazy", virtualScroll: "virtualScroll", virtualScrollItemSize: "virtualScrollItemSize", virtualScrollOptions: "virtualScrollOptions", maxlength: "maxlength", name: "name", required: "required", size: "size", appendTo: "appendTo", autoHighlight: "autoHighlight", forceSelection: "forceSelection", type: "type", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", ariaLabel: "ariaLabel", dropdownAriaLabel: "dropdownAriaLabel", ariaLabelledBy: "ariaLabelledBy", dropdownIcon: "dropdownIcon", unique: "unique", group: "group", completeOnFocus: "completeOnFocus", showClear: "showClear", field: "field", dropdown: "dropdown", showEmptyMessage: "showEmptyMessage", dropdownMode: "dropdownMode", multiple: "multiple", tabindex: "tabindex", dataKey: "dataKey", emptyMessage: "emptyMessage", showTransitionOptions: "showTransitionOptions", hideTransitionOptions: "hideTransitionOptions", autofocus: "autofocus", autocomplete: "autocomplete", optionGroupChildren: "optionGroupChildren", optionGroupLabel: "optionGroupLabel", overlayOptions: "overlayOptions", suggestions: "suggestions", itemSize: "itemSize", optionLabel: "optionLabel", id: "id", searchMessage: "searchMessage", emptySelectionMessage: "emptySelectionMessage", selectionMessage: "selectionMessage", autoOptionFocus: "autoOptionFocus", selectOnFocus: "selectOnFocus", searchLocale: "searchLocale", optionDisabled: "optionDisabled", focusOnHover: "focusOnHover" }, outputs: { completeMethod: "completeMethod", onSelect: "onSelect", onUnselect: "onUnselect", onFocus: "onFocus", onBlur: "onBlur", onDropdownClick: "onDropdownClick", onClear: "onClear", onKeyUp: "onKeyUp", onShow: "onShow", onHide: "onHide", onLazyLoad: "onLazyLoad" }, host: { properties: { "class.p-inputwrapper-filled": "filled", "class.p-inputwrapper-focus": "((focused && !disabled) || autofocus) || overlayVisible", "class.p-autocomplete-clearable": "showClear && !disabled" }, classAttribute: "p-element p-inputwrapper" }, providers: [AUTOCOMPLETE_VALUE_ACCESSOR], queries: [{ propertyName: "templates", predicate: PrimeTemplate }], viewQueries: [{ propertyName: "containerEL", first: true, predicate: ["container"], descendants: true }, { propertyName: "inputEL", first: true, predicate: ["focusInput"], descendants: true }, { propertyName: "multiInputEl", first: true, predicate: ["multiIn"], descendants: true }, { propertyName: "multiContainerEL", first: true, predicate: ["multiContainer"], descendants: true }, { propertyName: "dropdownButton", first: true, predicate: ["ddBtn"], descendants: true }, { propertyName: "itemsViewChild", first: true, predicate: ["items"], descendants: true }, { propertyName: "scroller", first: true, predicate: ["scroller"], descendants: true }, { propertyName: "overlayViewChild", first: true, predicate: ["overlay"], descendants: true }], ngImport: i0, template: `
|
1157
|
+
<div #container [ngClass]="containerClass" [ngStyle]="style" [class]="styleClass" (click)="onContainerClick($event)">
|
958
1158
|
<input
|
1159
|
+
*ngIf="!multiple"
|
1160
|
+
#focusInput
|
959
1161
|
pAutoFocus
|
960
1162
|
[autofocus]="autofocus"
|
961
|
-
|
962
|
-
#in
|
963
|
-
[attr.type]="type"
|
964
|
-
[attr.id]="inputId"
|
1163
|
+
[ngClass]="inputClass"
|
965
1164
|
[ngStyle]="inputStyle"
|
966
1165
|
[class]="inputStyleClass"
|
1166
|
+
[type]="type"
|
1167
|
+
[attr.value]="inputValue()"
|
1168
|
+
[attr.id]="inputId"
|
967
1169
|
[autocomplete]="autocomplete"
|
968
|
-
[
|
969
|
-
[
|
970
|
-
class="p-autocomplete-input p-inputtext p-component"
|
971
|
-
[ngClass]="{ 'p-autocomplete-dd-input': dropdown, 'p-disabled': disabled }"
|
972
|
-
[value]="inputFieldValue"
|
1170
|
+
[required]="required"
|
1171
|
+
[name]="name"
|
973
1172
|
aria-autocomplete="list"
|
974
|
-
role="
|
975
|
-
(click)="onInputClick($event)"
|
976
|
-
(input)="onInput($event)"
|
977
|
-
(keydown)="onKeydown($event)"
|
978
|
-
(keyup)="onKeyup($event)"
|
979
|
-
(focus)="onInputFocus($event)"
|
980
|
-
(blur)="onInputBlur($event)"
|
981
|
-
(change)="onInputChange($event)"
|
982
|
-
(paste)="onInputPaste($event)"
|
1173
|
+
role="combobox"
|
983
1174
|
[attr.placeholder]="placeholder"
|
984
1175
|
[attr.size]="size"
|
985
|
-
[
|
986
|
-
[
|
1176
|
+
[maxlength]="maxlength"
|
1177
|
+
[tabindex]="!disabled ? tabindex : -1"
|
987
1178
|
[readonly]="readonly"
|
988
1179
|
[disabled]="disabled"
|
989
1180
|
[attr.aria-label]="ariaLabel"
|
990
1181
|
[attr.aria-labelledby]="ariaLabelledBy"
|
991
1182
|
[attr.aria-required]="required"
|
1183
|
+
[attr.aria-expanded]="overlayVisible"
|
1184
|
+
[attr.aria-controls]="id + '_list'"
|
1185
|
+
[attr.aria-aria-activedescendant]="focused ? focusedOptionId : undefined"
|
1186
|
+
(input)="onInput($event)"
|
1187
|
+
(keydown)="onKeyDown($event)"
|
1188
|
+
(change)="onInputChange($event)"
|
1189
|
+
(focus)="onInputFocus($event)"
|
1190
|
+
(blur)="onInputBlur($event)"
|
1191
|
+
(paste)="onInputPaste($event)"
|
1192
|
+
(keyup)="onInputKeyUp($event)"
|
992
1193
|
/>
|
993
1194
|
<ng-container *ngIf="filled && !disabled && showClear && !loading">
|
994
|
-
<TimesIcon *ngIf="!clearIconTemplate" [styleClass]="'p-autocomplete-clear-icon'" (click)="clear()" />
|
995
|
-
<span *ngIf="clearIconTemplate" class="p-autocomplete-clear-icon" (click)="clear()">
|
1195
|
+
<TimesIcon *ngIf="!clearIconTemplate" [styleClass]="'p-autocomplete-clear-icon'" (click)="clear()" [attr.aria-hidden]="true" />
|
1196
|
+
<span *ngIf="clearIconTemplate" class="p-autocomplete-clear-icon" (click)="clear()" [attr.aria-hidden]="true">
|
996
1197
|
<ng-template *ngTemplateOutlet="clearIconTemplate"></ng-template>
|
997
1198
|
</span>
|
998
1199
|
</ng-container>
|
999
|
-
|
1000
|
-
|
1001
|
-
|
1002
|
-
|
1003
|
-
|
1004
|
-
|
1005
|
-
|
1200
|
+
|
1201
|
+
<ul
|
1202
|
+
*ngIf="multiple"
|
1203
|
+
#multiContainer
|
1204
|
+
[class]="multiContainerClass"
|
1205
|
+
[tabindex]="-1"
|
1206
|
+
role="listbox"
|
1207
|
+
[attr.aria-orientation]="'horizontal'"
|
1208
|
+
[attr.aria-activedescendant]="focused ? focusedMultipleOptionId : undefined"
|
1209
|
+
(focus)="onMultipleContainerFocus($event)"
|
1210
|
+
(blur)="onMultipleContainerBlur($event)"
|
1211
|
+
(keydown)="onMultipleContainerKeyDown($event)"
|
1212
|
+
>
|
1213
|
+
<li
|
1214
|
+
#token
|
1215
|
+
*ngFor="let option of modelValue(); let i = index"
|
1216
|
+
[ngClass]="{ 'p-autocomplete-token': true, 'p-focus': focusedMultipleOptionIndex() === i }"
|
1217
|
+
[attr.id]="id + '_multiple_option_' + i"
|
1218
|
+
role="option"
|
1219
|
+
[attr.aria-label]="getOptionLabel(option)"
|
1220
|
+
[attr.aria-setsize]="modelValue().length"
|
1221
|
+
[attr.aria-posinset]="i + 1"
|
1222
|
+
[attr.aria-selected]="true"
|
1223
|
+
>
|
1224
|
+
<ng-container *ngTemplateOutlet="selectedItemTemplate; context: { $implicit: option }"></ng-container>
|
1225
|
+
<span *ngIf="!selectedItemTemplate" class="p-autocomplete-token-label">{{ getOptionLabel(option) }}</span>
|
1226
|
+
<span class="p-autocomplete-token-icon" (click)="removeOption($event, i)">
|
1227
|
+
<TimesCircleIcon [styleClass]="'p-autocomplete-token-icon'" *ngIf="!removeIconTemplate" [attr.aria-hidden]="true" />
|
1228
|
+
<span *ngIf="removeIconTemplate" class="p-autocomplete-token-icon" [attr.aria-hidden]="true">
|
1006
1229
|
<ng-template *ngTemplateOutlet="removeIconTemplate"></ng-template>
|
1007
1230
|
</span>
|
1008
1231
|
</span>
|
1009
1232
|
</li>
|
1010
|
-
<li class="p-autocomplete-input-token">
|
1233
|
+
<li class="p-autocomplete-input-token" role="option">
|
1011
1234
|
<input
|
1235
|
+
#focusInput
|
1012
1236
|
pAutoFocus
|
1013
1237
|
[autofocus]="autofocus"
|
1014
|
-
|
1238
|
+
[ngClass]="inputClass"
|
1239
|
+
[ngStyle]="inputStyle"
|
1240
|
+
[class]="inputStyleClass"
|
1015
1241
|
[attr.type]="type"
|
1016
1242
|
[attr.id]="inputId"
|
1017
|
-
[disabled]="disabled"
|
1018
|
-
[attr.placeholder]="value && value.length ? null : placeholder"
|
1019
|
-
[attr.tabindex]="tabindex"
|
1020
|
-
[attr.maxlength]="maxlength"
|
1021
|
-
(input)="onInput($event)"
|
1022
|
-
(click)="onInputClick($event)"
|
1023
|
-
(keydown)="onKeydown($event)"
|
1024
|
-
[readonly]="readonly"
|
1025
|
-
(keyup)="onKeyup($event)"
|
1026
|
-
(focus)="onInputFocus($event)"
|
1027
|
-
(blur)="onInputBlur($event)"
|
1028
|
-
(change)="onInputChange($event)"
|
1029
|
-
(paste)="onInputPaste($event)"
|
1030
1243
|
[autocomplete]="autocomplete"
|
1031
|
-
[
|
1032
|
-
[
|
1244
|
+
[required]="required"
|
1245
|
+
[attr.name]="name"
|
1246
|
+
role="combobox"
|
1247
|
+
[attr.placeholder]="placeholder"
|
1248
|
+
[attr.size]="size"
|
1249
|
+
aria-autocomplete="list"
|
1250
|
+
[maxlength]="maxlength"
|
1251
|
+
[tabindex]="!disabled ? tabindex : -1"
|
1252
|
+
[readonly]="readonly"
|
1253
|
+
[disabled]="disabled"
|
1033
1254
|
[attr.aria-label]="ariaLabel"
|
1034
1255
|
[attr.aria-labelledby]="ariaLabelledBy"
|
1035
1256
|
[attr.aria-required]="required"
|
1036
|
-
aria-autocomplete="list"
|
1037
|
-
[attr.aria-controls]="listId"
|
1038
|
-
role="searchbox"
|
1039
1257
|
[attr.aria-expanded]="overlayVisible"
|
1040
|
-
aria-
|
1041
|
-
[attr.aria-activedescendant]="
|
1258
|
+
[attr.aria-controls]="id + '_list'"
|
1259
|
+
[attr.aria-aria-activedescendant]="focused ? focusedOptionId : undefined"
|
1260
|
+
(input)="onInput($event)"
|
1261
|
+
(keydown)="onKeyDown($event)"
|
1262
|
+
(change)="onInputChange($event)"
|
1263
|
+
(focus)="onInputFocus($event)"
|
1264
|
+
(blur)="onInputBlur($event)"
|
1265
|
+
(paste)="onInputPaste($event)"
|
1266
|
+
(keyup)="onInputKeyUp($event)"
|
1042
1267
|
/>
|
1043
1268
|
</li>
|
1044
1269
|
</ul>
|
1045
1270
|
<ng-container *ngIf="loading">
|
1046
|
-
<SpinnerIcon *ngIf="!loadingIconTemplate" [styleClass]="'p-autocomplete-loader'" [spin]="true" />
|
1047
|
-
<span *ngIf="loadingIconTemplate" class="p-autocomplete-loader pi-spin ">
|
1271
|
+
<SpinnerIcon *ngIf="!loadingIconTemplate" [styleClass]="'p-autocomplete-loader'" [spin]="true" [attr.aria-hidden]="true" />
|
1272
|
+
<span *ngIf="loadingIconTemplate" class="p-autocomplete-loader pi-spin " [attr.aria-hidden]="true">
|
1048
1273
|
<ng-template *ngTemplateOutlet="loadingIconTemplate"></ng-template>
|
1049
1274
|
</span>
|
1050
1275
|
</ng-container>
|
1051
1276
|
<button #ddBtn type="button" pButton [attr.aria-label]="dropdownAriaLabel" class="p-autocomplete-dropdown p-button-icon-only" [disabled]="disabled" pRipple (click)="handleDropdownClick($event)" *ngIf="dropdown" [attr.tabindex]="tabindex">
|
1052
|
-
<span *ngIf="dropdownIcon" [ngClass]="dropdownIcon"></span>
|
1277
|
+
<span *ngIf="dropdownIcon" [ngClass]="dropdownIcon" [attr.aria-hidden]="true"></span>
|
1053
1278
|
<ng-container *ngIf="!dropdownIcon">
|
1054
1279
|
<ChevronDownIcon *ngIf="!dropdownIconTemplate" />
|
1055
1280
|
<ng-template *ngTemplateOutlet="dropdownIconTemplate"></ng-template>
|
@@ -1058,23 +1283,21 @@ class AutoComplete {
|
|
1058
1283
|
<p-overlay
|
1059
1284
|
#overlay
|
1060
1285
|
[(visible)]="overlayVisible"
|
1061
|
-
[options]="
|
1286
|
+
[options]="virtualScrollOptions"
|
1062
1287
|
[target]="'@parent'"
|
1063
1288
|
[appendTo]="appendTo"
|
1064
|
-
[autoZIndex]="autoZIndex"
|
1065
|
-
[baseZIndex]="baseZIndex"
|
1066
1289
|
[showTransitionOptions]="showTransitionOptions"
|
1067
1290
|
[hideTransitionOptions]="hideTransitionOptions"
|
1068
1291
|
(onAnimationStart)="onOverlayAnimationStart($event)"
|
1069
|
-
(
|
1070
|
-
(onHide)="hide($event)"
|
1292
|
+
(onHide)="hide()"
|
1071
1293
|
>
|
1072
|
-
<div [ngClass]="
|
1294
|
+
<div [ngClass]="panelClass" [style.max-height]="virtualScroll ? 'auto' : scrollHeight" [ngStyle]="panelStyle" [class]="panelStyleClass">
|
1073
1295
|
<ng-container *ngTemplateOutlet="headerTemplate"></ng-container>
|
1074
1296
|
<p-scroller
|
1075
1297
|
*ngIf="virtualScroll"
|
1076
1298
|
#scroller
|
1077
|
-
[items]="
|
1299
|
+
[items]="visibleOptions()"
|
1300
|
+
[tabindex]="-1"
|
1078
1301
|
[style]="{ height: scrollHeight }"
|
1079
1302
|
[itemSize]="virtualScrollItemSize || _itemSize"
|
1080
1303
|
[autoSize]="true"
|
@@ -1092,152 +1315,182 @@ class AutoComplete {
|
|
1092
1315
|
</ng-container>
|
1093
1316
|
</p-scroller>
|
1094
1317
|
<ng-container *ngIf="!virtualScroll">
|
1095
|
-
<ng-container *ngTemplateOutlet="buildInItems; context: { $implicit:
|
1318
|
+
<ng-container *ngTemplateOutlet="buildInItems; context: { $implicit: visibleOptions(), options: {} }"></ng-container>
|
1096
1319
|
</ng-container>
|
1097
1320
|
|
1098
1321
|
<ng-template #buildInItems let-items let-scrollerOptions="options">
|
1099
|
-
<ul #items
|
1100
|
-
<ng-
|
1101
|
-
<ng-
|
1102
|
-
<li class="p-autocomplete-item-group" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }">
|
1103
|
-
<span *ngIf="!groupTemplate">{{ getOptionGroupLabel(
|
1104
|
-
<ng-container *ngTemplateOutlet="groupTemplate; context: { $implicit:
|
1322
|
+
<ul #items class="p-autocomplete-items" [ngClass]="scrollerOptions.contentStyleClass" [style]="scrollerOptions.contentStyle" role="listbox" [attr.id]="id + '_list'">
|
1323
|
+
<ng-template ngFor let-option [ngForOf]="items" let-i="index">
|
1324
|
+
<ng-container *ngIf="isOptionGroup(option)">
|
1325
|
+
<li [attr.id]="id + '_' + getOptionIndex(i, scrollerOptions)" class="p-autocomplete-item-group" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }" role="option">
|
1326
|
+
<span *ngIf="!groupTemplate">{{ getOptionGroupLabel(option.optionGroup) }}</span>
|
1327
|
+
<ng-container *ngTemplateOutlet="groupTemplate; context: { $implicit: option.optionGroup }"></ng-container>
|
1328
|
+
</li>
|
1329
|
+
</ng-container>
|
1330
|
+
<ng-container *ngIf="!isOptionGroup(option)">
|
1331
|
+
<li
|
1332
|
+
class="p-autocomplete-item"
|
1333
|
+
pRipple
|
1334
|
+
[ngStyle]="{ height: scrollerOptions.itemSize + 'px' }"
|
1335
|
+
[ngClass]="{ 'p-highlight': isSelected(option), 'p-focus': focusedOptionIndex() === getOptionIndex(i, scrollerOptions), 'p-disabled': isOptionDisabled(option) }"
|
1336
|
+
[attr.id]="id + '_' + getOptionIndex(i, scrollerOptions)"
|
1337
|
+
role="option"
|
1338
|
+
[attr.aria-label]="getOptionLabel(option)"
|
1339
|
+
[attr.aria-selected]="isSelected(option)"
|
1340
|
+
[attr.aria-disabled]="isOptionDisabled(option)"
|
1341
|
+
[attr.data-p-focused]="focusedOptionIndex() === getOptionIndex(i, scrollerOptions)"
|
1342
|
+
[attr.aria-setsize]="ariaSetSize"
|
1343
|
+
[attr.aria-posinset]="getAriaPosInset(getOptionIndex(i, scrollerOptions))"
|
1344
|
+
(click)="onOptionSelect($event, option)"
|
1345
|
+
(mouseenter)="onOptionMouseEnter($event, getOptionIndex(i, scrollerOptions))"
|
1346
|
+
>
|
1347
|
+
<span *ngIf="!itemTemplate">{{ getOptionLabel(option) }}</span>
|
1348
|
+
<ng-container *ngTemplateOutlet="itemTemplate; context: { $implicit: option, index: scrollerOptions.getOptions ? scrollerOptions.getOptions(i) : i }"></ng-container>
|
1105
1349
|
</li>
|
1106
|
-
|
1107
|
-
</ng-template>
|
1108
|
-
</ng-container>
|
1109
|
-
<ng-container *ngIf="!group">
|
1110
|
-
<ng-container *ngTemplateOutlet="itemslist; context: { $implicit: items }"></ng-container>
|
1111
|
-
</ng-container>
|
1112
|
-
<ng-template #itemslist let-suggestionsToDisplay>
|
1113
|
-
<li
|
1114
|
-
role="option"
|
1115
|
-
*ngFor="let option of suggestionsToDisplay; let idx = index"
|
1116
|
-
class="p-autocomplete-item"
|
1117
|
-
pRipple
|
1118
|
-
[ngStyle]="{ height: scrollerOptions.itemSize + 'px' }"
|
1119
|
-
[ngClass]="{ 'p-highlight': option === highlightOption }"
|
1120
|
-
[id]="highlightOption == option ? 'p-highlighted-option' : ''"
|
1121
|
-
(click)="selectItem(option)"
|
1122
|
-
>
|
1123
|
-
<span *ngIf="!itemTemplate">{{ resolveFieldData(option) }}</span>
|
1124
|
-
<ng-container *ngTemplateOutlet="itemTemplate; context: { $implicit: option, index: scrollerOptions.getOptions ? scrollerOptions.getOptions(idx) : idx }"></ng-container>
|
1125
|
-
</li>
|
1350
|
+
</ng-container>
|
1126
1351
|
</ng-template>
|
1127
|
-
<li *ngIf="
|
1352
|
+
<li *ngIf="!items || (items && items.length === 0 && showEmptyMessage)" class="p-autocomplete-empty-message" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }" role="option">
|
1128
1353
|
<ng-container *ngIf="!emptyTemplate; else empty">
|
1129
|
-
{{
|
1354
|
+
{{ searchResultMessageText }}
|
1130
1355
|
</ng-container>
|
1131
1356
|
<ng-container #empty *ngTemplateOutlet="emptyTemplate"></ng-container>
|
1132
1357
|
</li>
|
1133
1358
|
</ul>
|
1359
|
+
<ng-container *ngTemplateOutlet="footerTemplate; context: { $implicit: items }"></ng-container>
|
1360
|
+
<span role="status" aria-live="polite" class="p-hidden-accessible">
|
1361
|
+
{{ selectedMessageText }}
|
1362
|
+
</span>
|
1134
1363
|
</ng-template>
|
1135
|
-
<ng-container *ngTemplateOutlet="footerTemplate"></ng-container>
|
1136
1364
|
</div>
|
1137
1365
|
</p-overlay>
|
1138
|
-
</
|
1366
|
+
</div>
|
1139
1367
|
`, isInline: true, styles: ["@layer primeng{.p-autocomplete{display:inline-flex;position:relative}.p-autocomplete-loader{position:absolute;top:50%;margin-top:-.5rem}.p-autocomplete-dd .p-autocomplete-input{flex:1 1 auto;width:1%}.p-autocomplete-dd .p-autocomplete-input,.p-autocomplete-dd .p-autocomplete-multiple-container{border-top-right-radius:0;border-bottom-right-radius:0}.p-autocomplete-dd .p-autocomplete-dropdown{border-top-left-radius:0;border-bottom-left-radius:0}.p-autocomplete-panel{overflow:auto}.p-autocomplete-items{margin:0;padding:0;list-style-type:none}.p-autocomplete-item{cursor:pointer;white-space:nowrap;position:relative;overflow:hidden}.p-autocomplete-multiple-container{margin:0;padding:0;list-style-type:none;cursor:text;overflow:hidden;display:flex;align-items:center;flex-wrap:wrap}.p-autocomplete-token{width:-moz-fit-content;width:fit-content;cursor:default;display:inline-flex;align-items:center;flex:0 0 auto}.p-autocomplete-token-icon{display:flex;cursor:pointer}.p-autocomplete-input-token{flex:1 1 auto;display:inline-flex}.p-autocomplete-input-token input{border:0 none;outline:0 none;background-color:transparent;margin:0;padding:0;box-shadow:none;border-radius:0;width:100%}.p-fluid .p-autocomplete{display:flex}.p-fluid .p-autocomplete-dd .p-autocomplete-input{width:1%}.p-autocomplete-clear-icon{position:absolute;top:50%;margin-top:-.5rem;cursor:pointer}.p-autocomplete-clearable{position:relative}}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i2.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i0.forwardRef(function () { return i3.Overlay; }), selector: "p-overlay", inputs: ["visible", "mode", "style", "styleClass", "contentStyle", "contentStyleClass", "target", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "listener", "responsive", "options"], outputs: ["visibleChange", "onBeforeShow", "onShow", "onBeforeHide", "onHide", "onAnimationStart", "onAnimationDone"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.PrimeTemplate; }), selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i4.ButtonDirective; }), selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "directive", type: i0.forwardRef(function () { return i5.Ripple; }), selector: "[pRipple]" }, { kind: "component", type: i0.forwardRef(function () { return i6.Scroller; }), selector: "p-scroller", inputs: ["id", "style", "styleClass", "tabindex", "items", "itemSize", "scrollHeight", "scrollWidth", "orientation", "step", "delay", "resizeDelay", "appendOnly", "inline", "lazy", "disabled", "loaderDisabled", "columns", "showSpacer", "showLoader", "numToleratedItems", "loading", "autoSize", "trackBy", "options"], outputs: ["onLazyLoad", "onScroll", "onScrollIndexChange"] }, { kind: "directive", type: i0.forwardRef(function () { return i7.AutoFocus; }), selector: "[pAutoFocus]", inputs: ["autofocus"] }, { kind: "component", type: i0.forwardRef(function () { return TimesCircleIcon; }), selector: "TimesCircleIcon" }, { kind: "component", type: i0.forwardRef(function () { return SpinnerIcon; }), selector: "SpinnerIcon" }, { kind: "component", type: i0.forwardRef(function () { return TimesIcon; }), selector: "TimesIcon" }, { kind: "component", type: i0.forwardRef(function () { return ChevronDownIcon; }), selector: "ChevronDownIcon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
1140
1368
|
}
|
1141
1369
|
export { AutoComplete };
|
1142
1370
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: AutoComplete, decorators: [{
|
1143
1371
|
type: Component,
|
1144
1372
|
args: [{ selector: 'p-autoComplete', template: `
|
1145
|
-
<
|
1373
|
+
<div #container [ngClass]="containerClass" [ngStyle]="style" [class]="styleClass" (click)="onContainerClick($event)">
|
1146
1374
|
<input
|
1375
|
+
*ngIf="!multiple"
|
1376
|
+
#focusInput
|
1147
1377
|
pAutoFocus
|
1148
1378
|
[autofocus]="autofocus"
|
1149
|
-
|
1150
|
-
#in
|
1151
|
-
[attr.type]="type"
|
1152
|
-
[attr.id]="inputId"
|
1379
|
+
[ngClass]="inputClass"
|
1153
1380
|
[ngStyle]="inputStyle"
|
1154
1381
|
[class]="inputStyleClass"
|
1382
|
+
[type]="type"
|
1383
|
+
[attr.value]="inputValue()"
|
1384
|
+
[attr.id]="inputId"
|
1155
1385
|
[autocomplete]="autocomplete"
|
1156
|
-
[
|
1157
|
-
[
|
1158
|
-
class="p-autocomplete-input p-inputtext p-component"
|
1159
|
-
[ngClass]="{ 'p-autocomplete-dd-input': dropdown, 'p-disabled': disabled }"
|
1160
|
-
[value]="inputFieldValue"
|
1386
|
+
[required]="required"
|
1387
|
+
[name]="name"
|
1161
1388
|
aria-autocomplete="list"
|
1162
|
-
role="
|
1163
|
-
(click)="onInputClick($event)"
|
1164
|
-
(input)="onInput($event)"
|
1165
|
-
(keydown)="onKeydown($event)"
|
1166
|
-
(keyup)="onKeyup($event)"
|
1167
|
-
(focus)="onInputFocus($event)"
|
1168
|
-
(blur)="onInputBlur($event)"
|
1169
|
-
(change)="onInputChange($event)"
|
1170
|
-
(paste)="onInputPaste($event)"
|
1389
|
+
role="combobox"
|
1171
1390
|
[attr.placeholder]="placeholder"
|
1172
1391
|
[attr.size]="size"
|
1173
|
-
[
|
1174
|
-
[
|
1392
|
+
[maxlength]="maxlength"
|
1393
|
+
[tabindex]="!disabled ? tabindex : -1"
|
1175
1394
|
[readonly]="readonly"
|
1176
1395
|
[disabled]="disabled"
|
1177
1396
|
[attr.aria-label]="ariaLabel"
|
1178
1397
|
[attr.aria-labelledby]="ariaLabelledBy"
|
1179
1398
|
[attr.aria-required]="required"
|
1399
|
+
[attr.aria-expanded]="overlayVisible"
|
1400
|
+
[attr.aria-controls]="id + '_list'"
|
1401
|
+
[attr.aria-aria-activedescendant]="focused ? focusedOptionId : undefined"
|
1402
|
+
(input)="onInput($event)"
|
1403
|
+
(keydown)="onKeyDown($event)"
|
1404
|
+
(change)="onInputChange($event)"
|
1405
|
+
(focus)="onInputFocus($event)"
|
1406
|
+
(blur)="onInputBlur($event)"
|
1407
|
+
(paste)="onInputPaste($event)"
|
1408
|
+
(keyup)="onInputKeyUp($event)"
|
1180
1409
|
/>
|
1181
1410
|
<ng-container *ngIf="filled && !disabled && showClear && !loading">
|
1182
|
-
<TimesIcon *ngIf="!clearIconTemplate" [styleClass]="'p-autocomplete-clear-icon'" (click)="clear()" />
|
1183
|
-
<span *ngIf="clearIconTemplate" class="p-autocomplete-clear-icon" (click)="clear()">
|
1411
|
+
<TimesIcon *ngIf="!clearIconTemplate" [styleClass]="'p-autocomplete-clear-icon'" (click)="clear()" [attr.aria-hidden]="true" />
|
1412
|
+
<span *ngIf="clearIconTemplate" class="p-autocomplete-clear-icon" (click)="clear()" [attr.aria-hidden]="true">
|
1184
1413
|
<ng-template *ngTemplateOutlet="clearIconTemplate"></ng-template>
|
1185
1414
|
</span>
|
1186
1415
|
</ng-container>
|
1187
|
-
|
1188
|
-
|
1189
|
-
|
1190
|
-
|
1191
|
-
|
1192
|
-
|
1193
|
-
|
1416
|
+
|
1417
|
+
<ul
|
1418
|
+
*ngIf="multiple"
|
1419
|
+
#multiContainer
|
1420
|
+
[class]="multiContainerClass"
|
1421
|
+
[tabindex]="-1"
|
1422
|
+
role="listbox"
|
1423
|
+
[attr.aria-orientation]="'horizontal'"
|
1424
|
+
[attr.aria-activedescendant]="focused ? focusedMultipleOptionId : undefined"
|
1425
|
+
(focus)="onMultipleContainerFocus($event)"
|
1426
|
+
(blur)="onMultipleContainerBlur($event)"
|
1427
|
+
(keydown)="onMultipleContainerKeyDown($event)"
|
1428
|
+
>
|
1429
|
+
<li
|
1430
|
+
#token
|
1431
|
+
*ngFor="let option of modelValue(); let i = index"
|
1432
|
+
[ngClass]="{ 'p-autocomplete-token': true, 'p-focus': focusedMultipleOptionIndex() === i }"
|
1433
|
+
[attr.id]="id + '_multiple_option_' + i"
|
1434
|
+
role="option"
|
1435
|
+
[attr.aria-label]="getOptionLabel(option)"
|
1436
|
+
[attr.aria-setsize]="modelValue().length"
|
1437
|
+
[attr.aria-posinset]="i + 1"
|
1438
|
+
[attr.aria-selected]="true"
|
1439
|
+
>
|
1440
|
+
<ng-container *ngTemplateOutlet="selectedItemTemplate; context: { $implicit: option }"></ng-container>
|
1441
|
+
<span *ngIf="!selectedItemTemplate" class="p-autocomplete-token-label">{{ getOptionLabel(option) }}</span>
|
1442
|
+
<span class="p-autocomplete-token-icon" (click)="removeOption($event, i)">
|
1443
|
+
<TimesCircleIcon [styleClass]="'p-autocomplete-token-icon'" *ngIf="!removeIconTemplate" [attr.aria-hidden]="true" />
|
1444
|
+
<span *ngIf="removeIconTemplate" class="p-autocomplete-token-icon" [attr.aria-hidden]="true">
|
1194
1445
|
<ng-template *ngTemplateOutlet="removeIconTemplate"></ng-template>
|
1195
1446
|
</span>
|
1196
1447
|
</span>
|
1197
1448
|
</li>
|
1198
|
-
<li class="p-autocomplete-input-token">
|
1449
|
+
<li class="p-autocomplete-input-token" role="option">
|
1199
1450
|
<input
|
1451
|
+
#focusInput
|
1200
1452
|
pAutoFocus
|
1201
1453
|
[autofocus]="autofocus"
|
1202
|
-
|
1454
|
+
[ngClass]="inputClass"
|
1455
|
+
[ngStyle]="inputStyle"
|
1456
|
+
[class]="inputStyleClass"
|
1203
1457
|
[attr.type]="type"
|
1204
1458
|
[attr.id]="inputId"
|
1205
|
-
[disabled]="disabled"
|
1206
|
-
[attr.placeholder]="value && value.length ? null : placeholder"
|
1207
|
-
[attr.tabindex]="tabindex"
|
1208
|
-
[attr.maxlength]="maxlength"
|
1209
|
-
(input)="onInput($event)"
|
1210
|
-
(click)="onInputClick($event)"
|
1211
|
-
(keydown)="onKeydown($event)"
|
1212
|
-
[readonly]="readonly"
|
1213
|
-
(keyup)="onKeyup($event)"
|
1214
|
-
(focus)="onInputFocus($event)"
|
1215
|
-
(blur)="onInputBlur($event)"
|
1216
|
-
(change)="onInputChange($event)"
|
1217
|
-
(paste)="onInputPaste($event)"
|
1218
1459
|
[autocomplete]="autocomplete"
|
1219
|
-
[
|
1220
|
-
[
|
1460
|
+
[required]="required"
|
1461
|
+
[attr.name]="name"
|
1462
|
+
role="combobox"
|
1463
|
+
[attr.placeholder]="placeholder"
|
1464
|
+
[attr.size]="size"
|
1465
|
+
aria-autocomplete="list"
|
1466
|
+
[maxlength]="maxlength"
|
1467
|
+
[tabindex]="!disabled ? tabindex : -1"
|
1468
|
+
[readonly]="readonly"
|
1469
|
+
[disabled]="disabled"
|
1221
1470
|
[attr.aria-label]="ariaLabel"
|
1222
1471
|
[attr.aria-labelledby]="ariaLabelledBy"
|
1223
1472
|
[attr.aria-required]="required"
|
1224
|
-
aria-autocomplete="list"
|
1225
|
-
[attr.aria-controls]="listId"
|
1226
|
-
role="searchbox"
|
1227
1473
|
[attr.aria-expanded]="overlayVisible"
|
1228
|
-
aria-
|
1229
|
-
[attr.aria-activedescendant]="
|
1474
|
+
[attr.aria-controls]="id + '_list'"
|
1475
|
+
[attr.aria-aria-activedescendant]="focused ? focusedOptionId : undefined"
|
1476
|
+
(input)="onInput($event)"
|
1477
|
+
(keydown)="onKeyDown($event)"
|
1478
|
+
(change)="onInputChange($event)"
|
1479
|
+
(focus)="onInputFocus($event)"
|
1480
|
+
(blur)="onInputBlur($event)"
|
1481
|
+
(paste)="onInputPaste($event)"
|
1482
|
+
(keyup)="onInputKeyUp($event)"
|
1230
1483
|
/>
|
1231
1484
|
</li>
|
1232
1485
|
</ul>
|
1233
1486
|
<ng-container *ngIf="loading">
|
1234
|
-
<SpinnerIcon *ngIf="!loadingIconTemplate" [styleClass]="'p-autocomplete-loader'" [spin]="true" />
|
1235
|
-
<span *ngIf="loadingIconTemplate" class="p-autocomplete-loader pi-spin ">
|
1487
|
+
<SpinnerIcon *ngIf="!loadingIconTemplate" [styleClass]="'p-autocomplete-loader'" [spin]="true" [attr.aria-hidden]="true" />
|
1488
|
+
<span *ngIf="loadingIconTemplate" class="p-autocomplete-loader pi-spin " [attr.aria-hidden]="true">
|
1236
1489
|
<ng-template *ngTemplateOutlet="loadingIconTemplate"></ng-template>
|
1237
1490
|
</span>
|
1238
1491
|
</ng-container>
|
1239
1492
|
<button #ddBtn type="button" pButton [attr.aria-label]="dropdownAriaLabel" class="p-autocomplete-dropdown p-button-icon-only" [disabled]="disabled" pRipple (click)="handleDropdownClick($event)" *ngIf="dropdown" [attr.tabindex]="tabindex">
|
1240
|
-
<span *ngIf="dropdownIcon" [ngClass]="dropdownIcon"></span>
|
1493
|
+
<span *ngIf="dropdownIcon" [ngClass]="dropdownIcon" [attr.aria-hidden]="true"></span>
|
1241
1494
|
<ng-container *ngIf="!dropdownIcon">
|
1242
1495
|
<ChevronDownIcon *ngIf="!dropdownIconTemplate" />
|
1243
1496
|
<ng-template *ngTemplateOutlet="dropdownIconTemplate"></ng-template>
|
@@ -1246,23 +1499,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1246
1499
|
<p-overlay
|
1247
1500
|
#overlay
|
1248
1501
|
[(visible)]="overlayVisible"
|
1249
|
-
[options]="
|
1502
|
+
[options]="virtualScrollOptions"
|
1250
1503
|
[target]="'@parent'"
|
1251
1504
|
[appendTo]="appendTo"
|
1252
|
-
[autoZIndex]="autoZIndex"
|
1253
|
-
[baseZIndex]="baseZIndex"
|
1254
1505
|
[showTransitionOptions]="showTransitionOptions"
|
1255
1506
|
[hideTransitionOptions]="hideTransitionOptions"
|
1256
1507
|
(onAnimationStart)="onOverlayAnimationStart($event)"
|
1257
|
-
(
|
1258
|
-
(onHide)="hide($event)"
|
1508
|
+
(onHide)="hide()"
|
1259
1509
|
>
|
1260
|
-
<div [ngClass]="
|
1510
|
+
<div [ngClass]="panelClass" [style.max-height]="virtualScroll ? 'auto' : scrollHeight" [ngStyle]="panelStyle" [class]="panelStyleClass">
|
1261
1511
|
<ng-container *ngTemplateOutlet="headerTemplate"></ng-container>
|
1262
1512
|
<p-scroller
|
1263
1513
|
*ngIf="virtualScroll"
|
1264
1514
|
#scroller
|
1265
|
-
[items]="
|
1515
|
+
[items]="visibleOptions()"
|
1516
|
+
[tabindex]="-1"
|
1266
1517
|
[style]="{ height: scrollHeight }"
|
1267
1518
|
[itemSize]="virtualScrollItemSize || _itemSize"
|
1268
1519
|
[autoSize]="true"
|
@@ -1280,60 +1531,65 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1280
1531
|
</ng-container>
|
1281
1532
|
</p-scroller>
|
1282
1533
|
<ng-container *ngIf="!virtualScroll">
|
1283
|
-
<ng-container *ngTemplateOutlet="buildInItems; context: { $implicit:
|
1534
|
+
<ng-container *ngTemplateOutlet="buildInItems; context: { $implicit: visibleOptions(), options: {} }"></ng-container>
|
1284
1535
|
</ng-container>
|
1285
1536
|
|
1286
1537
|
<ng-template #buildInItems let-items let-scrollerOptions="options">
|
1287
|
-
<ul #items
|
1288
|
-
<ng-
|
1289
|
-
<ng-
|
1290
|
-
<li class="p-autocomplete-item-group" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }">
|
1291
|
-
<span *ngIf="!groupTemplate">{{ getOptionGroupLabel(
|
1292
|
-
<ng-container *ngTemplateOutlet="groupTemplate; context: { $implicit:
|
1538
|
+
<ul #items class="p-autocomplete-items" [ngClass]="scrollerOptions.contentStyleClass" [style]="scrollerOptions.contentStyle" role="listbox" [attr.id]="id + '_list'">
|
1539
|
+
<ng-template ngFor let-option [ngForOf]="items" let-i="index">
|
1540
|
+
<ng-container *ngIf="isOptionGroup(option)">
|
1541
|
+
<li [attr.id]="id + '_' + getOptionIndex(i, scrollerOptions)" class="p-autocomplete-item-group" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }" role="option">
|
1542
|
+
<span *ngIf="!groupTemplate">{{ getOptionGroupLabel(option.optionGroup) }}</span>
|
1543
|
+
<ng-container *ngTemplateOutlet="groupTemplate; context: { $implicit: option.optionGroup }"></ng-container>
|
1293
1544
|
</li>
|
1294
|
-
|
1295
|
-
|
1296
|
-
|
1297
|
-
|
1298
|
-
|
1299
|
-
|
1300
|
-
|
1301
|
-
|
1302
|
-
|
1303
|
-
|
1304
|
-
|
1305
|
-
|
1306
|
-
|
1307
|
-
|
1308
|
-
|
1309
|
-
|
1310
|
-
|
1311
|
-
|
1312
|
-
|
1313
|
-
|
1545
|
+
</ng-container>
|
1546
|
+
<ng-container *ngIf="!isOptionGroup(option)">
|
1547
|
+
<li
|
1548
|
+
class="p-autocomplete-item"
|
1549
|
+
pRipple
|
1550
|
+
[ngStyle]="{ height: scrollerOptions.itemSize + 'px' }"
|
1551
|
+
[ngClass]="{ 'p-highlight': isSelected(option), 'p-focus': focusedOptionIndex() === getOptionIndex(i, scrollerOptions), 'p-disabled': isOptionDisabled(option) }"
|
1552
|
+
[attr.id]="id + '_' + getOptionIndex(i, scrollerOptions)"
|
1553
|
+
role="option"
|
1554
|
+
[attr.aria-label]="getOptionLabel(option)"
|
1555
|
+
[attr.aria-selected]="isSelected(option)"
|
1556
|
+
[attr.aria-disabled]="isOptionDisabled(option)"
|
1557
|
+
[attr.data-p-focused]="focusedOptionIndex() === getOptionIndex(i, scrollerOptions)"
|
1558
|
+
[attr.aria-setsize]="ariaSetSize"
|
1559
|
+
[attr.aria-posinset]="getAriaPosInset(getOptionIndex(i, scrollerOptions))"
|
1560
|
+
(click)="onOptionSelect($event, option)"
|
1561
|
+
(mouseenter)="onOptionMouseEnter($event, getOptionIndex(i, scrollerOptions))"
|
1562
|
+
>
|
1563
|
+
<span *ngIf="!itemTemplate">{{ getOptionLabel(option) }}</span>
|
1564
|
+
<ng-container *ngTemplateOutlet="itemTemplate; context: { $implicit: option, index: scrollerOptions.getOptions ? scrollerOptions.getOptions(i) : i }"></ng-container>
|
1565
|
+
</li>
|
1566
|
+
</ng-container>
|
1314
1567
|
</ng-template>
|
1315
|
-
<li *ngIf="
|
1568
|
+
<li *ngIf="!items || (items && items.length === 0 && showEmptyMessage)" class="p-autocomplete-empty-message" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }" role="option">
|
1316
1569
|
<ng-container *ngIf="!emptyTemplate; else empty">
|
1317
|
-
{{
|
1570
|
+
{{ searchResultMessageText }}
|
1318
1571
|
</ng-container>
|
1319
1572
|
<ng-container #empty *ngTemplateOutlet="emptyTemplate"></ng-container>
|
1320
1573
|
</li>
|
1321
1574
|
</ul>
|
1575
|
+
<ng-container *ngTemplateOutlet="footerTemplate; context: { $implicit: items }"></ng-container>
|
1576
|
+
<span role="status" aria-live="polite" class="p-hidden-accessible">
|
1577
|
+
{{ selectedMessageText }}
|
1578
|
+
</span>
|
1322
1579
|
</ng-template>
|
1323
|
-
<ng-container *ngTemplateOutlet="footerTemplate"></ng-container>
|
1324
1580
|
</div>
|
1325
1581
|
</p-overlay>
|
1326
|
-
</
|
1582
|
+
</div>
|
1327
1583
|
`, host: {
|
1328
1584
|
class: 'p-element p-inputwrapper',
|
1329
1585
|
'[class.p-inputwrapper-filled]': 'filled',
|
1330
|
-
'[class.p-inputwrapper-focus]': '((
|
1586
|
+
'[class.p-inputwrapper-focus]': '((focused && !disabled) || autofocus) || overlayVisible',
|
1331
1587
|
'[class.p-autocomplete-clearable]': 'showClear && !disabled'
|
1332
1588
|
}, providers: [AUTOCOMPLETE_VALUE_ACCESSOR], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, styles: ["@layer primeng{.p-autocomplete{display:inline-flex;position:relative}.p-autocomplete-loader{position:absolute;top:50%;margin-top:-.5rem}.p-autocomplete-dd .p-autocomplete-input{flex:1 1 auto;width:1%}.p-autocomplete-dd .p-autocomplete-input,.p-autocomplete-dd .p-autocomplete-multiple-container{border-top-right-radius:0;border-bottom-right-radius:0}.p-autocomplete-dd .p-autocomplete-dropdown{border-top-left-radius:0;border-bottom-left-radius:0}.p-autocomplete-panel{overflow:auto}.p-autocomplete-items{margin:0;padding:0;list-style-type:none}.p-autocomplete-item{cursor:pointer;white-space:nowrap;position:relative;overflow:hidden}.p-autocomplete-multiple-container{margin:0;padding:0;list-style-type:none;cursor:text;overflow:hidden;display:flex;align-items:center;flex-wrap:wrap}.p-autocomplete-token{width:-moz-fit-content;width:fit-content;cursor:default;display:inline-flex;align-items:center;flex:0 0 auto}.p-autocomplete-token-icon{display:flex;cursor:pointer}.p-autocomplete-input-token{flex:1 1 auto;display:inline-flex}.p-autocomplete-input-token input{border:0 none;outline:0 none;background-color:transparent;margin:0;padding:0;box-shadow:none;border-radius:0;width:100%}.p-fluid .p-autocomplete{display:flex}.p-fluid .p-autocomplete-dd .p-autocomplete-input{width:1%}.p-autocomplete-clear-icon{position:absolute;top:50%;margin-top:-.5rem;cursor:pointer}.p-autocomplete-clearable{position:relative}}\n"] }]
|
1333
1589
|
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
1334
1590
|
type: Inject,
|
1335
1591
|
args: [DOCUMENT]
|
1336
|
-
}] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type:
|
1592
|
+
}] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i1.PrimeNGConfig }, { type: i1.OverlayService }, { type: i0.NgZone }]; }, propDecorators: { minLength: [{
|
1337
1593
|
type: Input
|
1338
1594
|
}], delay: [{
|
1339
1595
|
type: Input
|
@@ -1437,6 +1693,26 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1437
1693
|
type: Input
|
1438
1694
|
}], itemSize: [{
|
1439
1695
|
type: Input
|
1696
|
+
}], optionLabel: [{
|
1697
|
+
type: Input
|
1698
|
+
}], id: [{
|
1699
|
+
type: Input
|
1700
|
+
}], searchMessage: [{
|
1701
|
+
type: Input
|
1702
|
+
}], emptySelectionMessage: [{
|
1703
|
+
type: Input
|
1704
|
+
}], selectionMessage: [{
|
1705
|
+
type: Input
|
1706
|
+
}], autoOptionFocus: [{
|
1707
|
+
type: Input
|
1708
|
+
}], selectOnFocus: [{
|
1709
|
+
type: Input
|
1710
|
+
}], searchLocale: [{
|
1711
|
+
type: Input
|
1712
|
+
}], optionDisabled: [{
|
1713
|
+
type: Input
|
1714
|
+
}], focusOnHover: [{
|
1715
|
+
type: Input
|
1440
1716
|
}], completeMethod: [{
|
1441
1717
|
type: Output
|
1442
1718
|
}], onSelect: [{
|
@@ -1464,7 +1740,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1464
1740
|
args: ['container']
|
1465
1741
|
}], inputEL: [{
|
1466
1742
|
type: ViewChild,
|
1467
|
-
args: ['
|
1743
|
+
args: ['focusInput']
|
1468
1744
|
}], multiInputEl: [{
|
1469
1745
|
type: ViewChild,
|
1470
1746
|
args: ['multiIn']
|
@@ -1501,4 +1777,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1501
1777
|
declarations: [AutoComplete]
|
1502
1778
|
}]
|
1503
1779
|
}] });
|
1504
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.js","sourceRoot":"","sources":["../../../src/app/components/autocomplete/autocomplete.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, AnimationEvent, style, transition, trigger } from '@angular/animations';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    AfterContentInit,\n    AfterViewChecked,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Inject,\n    Input,\n    IterableDiffers,\n    NgModule,\n    NgZone,\n    OnDestroy,\n    Output,\n    QueryList,\n    Renderer2,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { OverlayOptions, OverlayService, PrimeNGConfig, PrimeTemplate, SharedModule, TranslationKeys } from 'primeng/api';\nimport { AutoFocusModule } from 'primeng/autofocus';\nimport { ButtonModule } from 'primeng/button';\nimport { ConnectedOverlayScrollHandler, DomHandler } from 'primeng/dom';\nimport { InputTextModule } from 'primeng/inputtext';\nimport { Overlay, OverlayModule } from 'primeng/overlay';\nimport { RippleModule } from 'primeng/ripple';\nimport { Scroller, ScrollerModule } from 'primeng/scroller';\nimport { ScrollerOptions } from 'primeng/api';\nimport { ObjectUtils, UniqueComponentId } from 'primeng/utils';\nimport { TimesCircleIcon } from 'primeng/icons/timescircle';\nimport { SpinnerIcon } from 'primeng/icons/spinner';\nimport { TimesIcon } from 'primeng/icons/times';\nimport { ChevronDownIcon } from 'primeng/icons/chevrondown';\nimport { Nullable, VoidListener } from 'primeng/ts-helpers';\nimport { AutoCompleteCompleteEvent, AutoCompleteDropdownClickEvent, AutoCompleteLazyLoadEvent } from './autocomplete.interface';\n\nexport const AUTOCOMPLETE_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => AutoComplete),\n    multi: true\n};\n/**\n * AutoComplete is an input component that provides real-time suggestions when being typed.\n * @group Components\n */\n@Component({\n    selector: 'p-autoComplete',\n    template: `\n        <span #container [ngClass]=\"{ 'p-autocomplete p-component': true, 'p-autocomplete-dd': dropdown, 'p-autocomplete-multiple': multiple }\" [ngStyle]=\"style\" [class]=\"styleClass\">\n            <input\n                pAutoFocus\n                [autofocus]=\"autofocus\"\n                *ngIf=\"!multiple\"\n                #in\n                [attr.type]=\"type\"\n                [attr.id]=\"inputId\"\n                [ngStyle]=\"inputStyle\"\n                [class]=\"inputStyleClass\"\n                [autocomplete]=\"autocomplete\"\n                [attr.required]=\"required\"\n                [attr.name]=\"name\"\n                class=\"p-autocomplete-input p-inputtext p-component\"\n                [ngClass]=\"{ 'p-autocomplete-dd-input': dropdown, 'p-disabled': disabled }\"\n                [value]=\"inputFieldValue\"\n                aria-autocomplete=\"list\"\n                role=\"searchbox\"\n                (click)=\"onInputClick($event)\"\n                (input)=\"onInput($event)\"\n                (keydown)=\"onKeydown($event)\"\n                (keyup)=\"onKeyup($event)\"\n                (focus)=\"onInputFocus($event)\"\n                (blur)=\"onInputBlur($event)\"\n                (change)=\"onInputChange($event)\"\n                (paste)=\"onInputPaste($event)\"\n                [attr.placeholder]=\"placeholder\"\n                [attr.size]=\"size\"\n                [attr.maxlength]=\"maxlength\"\n                [attr.tabindex]=\"tabindex\"\n                [readonly]=\"readonly\"\n                [disabled]=\"disabled\"\n                [attr.aria-label]=\"ariaLabel\"\n                [attr.aria-labelledby]=\"ariaLabelledBy\"\n                [attr.aria-required]=\"required\"\n            />\n            <ng-container *ngIf=\"filled && !disabled && showClear && !loading\">\n                <TimesIcon *ngIf=\"!clearIconTemplate\" [styleClass]=\"'p-autocomplete-clear-icon'\" (click)=\"clear()\" />\n                <span *ngIf=\"clearIconTemplate\" class=\"p-autocomplete-clear-icon\" (click)=\"clear()\">\n                    <ng-template *ngTemplateOutlet=\"clearIconTemplate\"></ng-template>\n                </span>\n            </ng-container>\n            <ul *ngIf=\"multiple\" #multiContainer class=\"p-autocomplete-multiple-container p-component p-inputtext\" [ngClass]=\"{ 'p-disabled': disabled, 'p-focus': focus }\" (click)=\"multiIn.focus()\">\n                <li #token *ngFor=\"let val of value\" class=\"p-autocomplete-token\">\n                    <ng-container *ngTemplateOutlet=\"selectedItemTemplate; context: { $implicit: val }\"></ng-container>\n                    <span *ngIf=\"!selectedItemTemplate\" class=\"p-autocomplete-token-label\">{{ resolveFieldData(val) }}</span>\n                    <span class=\"p-autocomplete-token-icon\" (click)=\"removeItem(token)\">\n                        <TimesCircleIcon [styleClass]=\"'p-autocomplete-token-icon'\" *ngIf=\"!removeIconTemplate\" />\n                        <span *ngIf=\"removeIconTemplate\" class=\"p-autocomplete-token-icon\">\n                            <ng-template *ngTemplateOutlet=\"removeIconTemplate\"></ng-template>\n                        </span>\n                    </span>\n                </li>\n                <li class=\"p-autocomplete-input-token\">\n                    <input\n                        pAutoFocus\n                        [autofocus]=\"autofocus\"\n                        #multiIn\n                        [attr.type]=\"type\"\n                        [attr.id]=\"inputId\"\n                        [disabled]=\"disabled\"\n                        [attr.placeholder]=\"value && value.length ? null : placeholder\"\n                        [attr.tabindex]=\"tabindex\"\n                        [attr.maxlength]=\"maxlength\"\n                        (input)=\"onInput($event)\"\n                        (click)=\"onInputClick($event)\"\n                        (keydown)=\"onKeydown($event)\"\n                        [readonly]=\"readonly\"\n                        (keyup)=\"onKeyup($event)\"\n                        (focus)=\"onInputFocus($event)\"\n                        (blur)=\"onInputBlur($event)\"\n                        (change)=\"onInputChange($event)\"\n                        (paste)=\"onInputPaste($event)\"\n                        [autocomplete]=\"autocomplete\"\n                        [ngStyle]=\"inputStyle\"\n                        [class]=\"inputStyleClass\"\n                        [attr.aria-label]=\"ariaLabel\"\n                        [attr.aria-labelledby]=\"ariaLabelledBy\"\n                        [attr.aria-required]=\"required\"\n                        aria-autocomplete=\"list\"\n                        [attr.aria-controls]=\"listId\"\n                        role=\"searchbox\"\n                        [attr.aria-expanded]=\"overlayVisible\"\n                        aria-haspopup=\"true\"\n                        [attr.aria-activedescendant]=\"'p-highlighted-option'\"\n                    />\n                </li>\n            </ul>\n            <ng-container *ngIf=\"loading\">\n                <SpinnerIcon *ngIf=\"!loadingIconTemplate\" [styleClass]=\"'p-autocomplete-loader'\" [spin]=\"true\" />\n                <span *ngIf=\"loadingIconTemplate\" class=\"p-autocomplete-loader pi-spin \">\n                    <ng-template *ngTemplateOutlet=\"loadingIconTemplate\"></ng-template>\n                </span>\n            </ng-container>\n            <button #ddBtn type=\"button\" pButton [attr.aria-label]=\"dropdownAriaLabel\" class=\"p-autocomplete-dropdown p-button-icon-only\" [disabled]=\"disabled\" pRipple (click)=\"handleDropdownClick($event)\" *ngIf=\"dropdown\" [attr.tabindex]=\"tabindex\">\n                <span *ngIf=\"dropdownIcon\" [ngClass]=\"dropdownIcon\"></span>\n                <ng-container *ngIf=\"!dropdownIcon\">\n                    <ChevronDownIcon *ngIf=\"!dropdownIconTemplate\" />\n                    <ng-template *ngTemplateOutlet=\"dropdownIconTemplate\"></ng-template>\n                </ng-container>\n            </button>\n            <p-overlay\n                #overlay\n                [(visible)]=\"overlayVisible\"\n                [options]=\"overlayOptions\"\n                [target]=\"'@parent'\"\n                [appendTo]=\"appendTo\"\n                [autoZIndex]=\"autoZIndex\"\n                [baseZIndex]=\"baseZIndex\"\n                [showTransitionOptions]=\"showTransitionOptions\"\n                [hideTransitionOptions]=\"hideTransitionOptions\"\n                (onAnimationStart)=\"onOverlayAnimationStart($event)\"\n                (onShow)=\"show($event)\"\n                (onHide)=\"hide($event)\"\n            >\n                <div [ngClass]=\"['p-autocomplete-panel p-component']\" [style.max-height]=\"virtualScroll ? 'auto' : scrollHeight\" [ngStyle]=\"panelStyle\" [class]=\"panelStyleClass\">\n                    <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n                    <p-scroller\n                        *ngIf=\"virtualScroll\"\n                        #scroller\n                        [items]=\"suggestions\"\n                        [style]=\"{ height: scrollHeight }\"\n                        [itemSize]=\"virtualScrollItemSize || _itemSize\"\n                        [autoSize]=\"true\"\n                        [lazy]=\"lazy\"\n                        (onLazyLoad)=\"onLazyLoad.emit($event)\"\n                        [options]=\"virtualScrollOptions\"\n                    >\n                        <ng-template pTemplate=\"content\" let-items let-scrollerOptions=\"options\">\n                            <ng-container *ngTemplateOutlet=\"buildInItems; context: { $implicit: items, options: scrollerOptions }\"></ng-container>\n                        </ng-template>\n                        <ng-container *ngIf=\"loaderTemplate\">\n                            <ng-template pTemplate=\"loader\" let-scrollerOptions=\"options\">\n                                <ng-container *ngTemplateOutlet=\"loaderTemplate; context: { options: scrollerOptions }\"></ng-container>\n                            </ng-template>\n                        </ng-container>\n                    </p-scroller>\n                    <ng-container *ngIf=\"!virtualScroll\">\n                        <ng-container *ngTemplateOutlet=\"buildInItems; context: { $implicit: suggestions, options: {} }\"></ng-container>\n                    </ng-container>\n\n                    <ng-template #buildInItems let-items let-scrollerOptions=\"options\">\n                        <ul #items role=\"listbox\" [attr.id]=\"listId\" class=\"p-autocomplete-items\" [ngClass]=\"scrollerOptions.contentStyleClass\" [style]=\"scrollerOptions.contentStyle\">\n                            <ng-container *ngIf=\"group\">\n                                <ng-template ngFor let-optgroup [ngForOf]=\"items\">\n                                    <li class=\"p-autocomplete-item-group\" [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\">\n                                        <span *ngIf=\"!groupTemplate\">{{ getOptionGroupLabel(optgroup) || 'empty' }}</span>\n                                        <ng-container *ngTemplateOutlet=\"groupTemplate; context: { $implicit: optgroup }\"></ng-container>\n                                    </li>\n                                    <ng-container *ngTemplateOutlet=\"itemslist; context: { $implicit: getOptionGroupChildren(optgroup) }\"></ng-container>\n                                </ng-template>\n                            </ng-container>\n                            <ng-container *ngIf=\"!group\">\n                                <ng-container *ngTemplateOutlet=\"itemslist; context: { $implicit: items }\"></ng-container>\n                            </ng-container>\n                            <ng-template #itemslist let-suggestionsToDisplay>\n                                <li\n                                    role=\"option\"\n                                    *ngFor=\"let option of suggestionsToDisplay; let idx = index\"\n                                    class=\"p-autocomplete-item\"\n                                    pRipple\n                                    [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\"\n                                    [ngClass]=\"{ 'p-highlight': option === highlightOption }\"\n                                    [id]=\"highlightOption == option ? 'p-highlighted-option' : ''\"\n                                    (click)=\"selectItem(option)\"\n                                >\n                                    <span *ngIf=\"!itemTemplate\">{{ resolveFieldData(option) }}</span>\n                                    <ng-container *ngTemplateOutlet=\"itemTemplate; context: { $implicit: option, index: scrollerOptions.getOptions ? scrollerOptions.getOptions(idx) : idx }\"></ng-container>\n                                </li>\n                            </ng-template>\n                            <li *ngIf=\"noResults && showEmptyMessage\" class=\"p-autocomplete-empty-message\" [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\">\n                                <ng-container *ngIf=\"!emptyTemplate; else empty\">\n                                    {{ emptyMessageLabel }}\n                                </ng-container>\n                                <ng-container #empty *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n                            </li>\n                        </ul>\n                    </ng-template>\n                    <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n                </div>\n            </p-overlay>\n        </span>\n    `,\n    host: {\n        class: 'p-element p-inputwrapper',\n        '[class.p-inputwrapper-filled]': 'filled',\n        '[class.p-inputwrapper-focus]': '((focus && !disabled) || autofocus) || overlayVisible',\n        '[class.p-autocomplete-clearable]': 'showClear && !disabled'\n    },\n    providers: [AUTOCOMPLETE_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./autocomplete.css']\n})\nexport class AutoComplete implements AfterViewChecked, AfterContentInit, OnDestroy, ControlValueAccessor {\n    /**\n     * Minimum number of characters to initiate a search.\n     * @group Props\n     */\n    @Input() minLength: number = 1;\n    /**\n     * Delay between keystrokes to wait before sending a query.\n     * @group Props\n     */\n    @Input() delay: number = 300;\n    /**\n     * Inline style of the component.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Inline style of the overlay panel element.\n     * @group Props\n     */\n    @Input() panelStyle: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the component.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Style class of the overlay panel element.\n     * @group Props\n     */\n    @Input() panelStyleClass: string | undefined;\n    /**\n     * Inline style of the input field.\n     * @group Props\n     */\n    @Input() inputStyle: { [klass: string]: any } | null | undefined;\n    /**\n     * Identifier of the focus input to match a label defined for the component.\n     * @group Props\n     */\n    @Input() inputId: string | undefined;\n    /**\n     * Inline style of the input field.\n     * @group Props\n     */\n    @Input() inputStyleClass: string | undefined;\n    /**\n     * Hint text for the input field.\n     * @group Props\n     */\n    @Input() placeholder: string | undefined;\n    /**\n     * When present, it specifies that the input cannot be typed.\n     * @group Props\n     */\n    @Input() readonly: boolean | undefined;\n    /**\n     * When present, it specifies that the component should be disabled.\n     * @group Props\n     */\n    @Input() disabled: boolean | undefined;\n    /**\n     * Maximum height of the suggestions panel.\n     * @group Props\n     */\n    @Input() scrollHeight: string = '200px';\n    /**\n     * Defines if data is loaded and interacted with in lazy manner.\n     * @group Props\n     */\n    @Input() lazy: boolean = false;\n    /**\n     * Whether the data should be loaded on demand during scroll.\n     * @group Props\n     */\n    @Input() virtualScroll: boolean | undefined;\n    /**\n     * Height of an item in the list for VirtualScrolling.\n     * @group Props\n     */\n    @Input() virtualScrollItemSize: number | undefined;\n    /**\n     * Whether to use the scroller feature. The properties of scroller component can be used like an object in it.\n     * @group Props\n     */\n    @Input() virtualScrollOptions: ScrollerOptions | undefined;\n    /**\n     * Maximum number of character allows in the input field.\n     * @group Props\n     */\n    @Input() maxlength: number | undefined;\n    /**\n     * Name of the input element.\n     * @group Props\n     */\n    @Input() name: string | undefined;\n    /**\n     * When present, it specifies that an input field must be filled out before submitting the form.\n     * @group Props\n     */\n    @Input() required: boolean | undefined;\n    /**\n     * Size of the input field.\n     * @group Props\n     */\n    @Input() size: number | undefined;\n    /**\n     * Target element to attach the overlay, valid values are \"body\" or a local ng-template variable of another element (note: use binding with brackets for template variables, e.g. [appendTo]=\"mydiv\" for a div element having #mydiv as variable name).\n     * @group Props\n     */\n    @Input() appendTo: HTMLElement | ElementRef | TemplateRef<any> | string | null | undefined | any;\n    /**\n     * When enabled, highlights the first item in the list by default.\n     * @group Props\n     */\n    @Input() autoHighlight: boolean | undefined;\n    /**\n     * When present, autocomplete clears the manual input if it does not match of the suggestions to force only accepting values from the suggestions.\n     * @group Props\n     */\n    @Input() forceSelection: boolean | undefined;\n    /**\n     * Type of the input, defaults to \"text\".\n     * @group Props\n     */\n    @Input() type: string = 'text';\n\n    /* @deprecated */\n    _autoZIndex: boolean;\n    @Input() get autoZIndex(): boolean {\n        return this._autoZIndex;\n    }\n    set autoZIndex(val: boolean) {\n        this._autoZIndex = val;\n        console.warn('The autoZIndex property is deprecated since v14.2.0, use overlayOptions property instead.');\n    }\n\n    /* @deprecated */\n    _baseZIndex: number;\n    @Input() get baseZIndex(): number {\n        return this._baseZIndex;\n    }\n    set baseZIndex(val: number) {\n        this._baseZIndex = val;\n        console.warn('The baseZIndex property is deprecated since v14.2.0, use overlayOptions property instead.');\n    }\n\n    /**\n     * Defines a string that labels the input for accessibility.\n     * @group Props\n     */\n    @Input() ariaLabel: string | undefined;\n\n    /**\n     * Defines a string that labels the dropdown button for accessibility.\n     * @group Props\n     */\n    @Input() dropdownAriaLabel: string | undefined;\n\n    /**\n     * Specifies one or more IDs in the DOM that labels the input field.\n     * @group Props\n     */\n    @Input() ariaLabelledBy: string | undefined;\n\n    /**\n     * Icon class of the dropdown icon.\n     * @group Props\n     */\n    @Input() dropdownIcon: string | undefined;\n\n    /**\n     * Ensures uniqueness of selected items on multiple mode.\n     * @group Props\n     */\n    @Input() unique: boolean = true;\n    /**\n     * Whether to display options as grouped when nested options are provided.\n     * @group Props\n     */\n    @Input() group: boolean | undefined;\n    /**\n     * Whether to run a query when input receives focus.\n     * @group Props\n     */\n    @Input() completeOnFocus: boolean = false;\n    /**\n     * When enabled, a clear icon is displayed to clear the value.\n     * @group Props\n     */\n    @Input() showClear: boolean = false;\n    /**\n     * Field of a suggested object to resolve and display.\n     * @group Props\n     */\n    @Input() field: string | undefined;\n    /**\n     * Displays a button next to the input field when enabled.\n     * @group Props\n     */\n    @Input() dropdown: boolean | undefined;\n    /**\n     * Whether to show the empty message or not.\n     * @group Props\n     */\n    @Input() showEmptyMessage: boolean | undefined;\n    /**\n     * Specifies the behavior dropdown button. Default \"blank\" mode sends an empty string and \"current\" mode sends the input value.\n     * @group Props\n     */\n    @Input() dropdownMode: string = 'blank';\n    /**\n     * Specifies if multiple values can be selected.\n     * @group Props\n     */\n    @Input() multiple: boolean | undefined;\n    /**\n     * Index of the element in tabbing order.\n     * @group Props\n     */\n    @Input() tabindex: number | undefined;\n    /**\n     * A property to uniquely identify a value in options.\n     * @group Props\n     */\n    @Input() dataKey: string | undefined;\n    /**\n     * Text to display when there is no data. Defaults to global value in i18n translation configuration.\n     * @group Props\n     */\n    @Input() emptyMessage: string | undefined;\n    /**\n     * Transition options of the show animation.\n     * @group Props\n     */\n    @Input() showTransitionOptions: string = '.12s cubic-bezier(0, 0, 0.2, 1)';\n    /**\n     * Transition options of the hide animation.\n     * @group Props\n     */\n    @Input() hideTransitionOptions: string = '.1s linear';\n    /**\n     * When present, it specifies that the component should automatically get focus on load.\n     * @group Props\n     */\n    @Input() autofocus: boolean | undefined;\n    /**\n     * Used to define a string that autocomplete attribute the current element.\n     * @group Props\n     */\n    @Input() autocomplete: string = 'off';\n    /**\n     * Name of the options field of an option group.\n     * @group Props\n     */\n    @Input() optionGroupChildren: string | undefined;\n    /**\n     * Name of the label field of an option group.\n     * @group Props\n     */\n    @Input() optionGroupLabel: string | undefined;\n    /**\n     * Options for the overlay element.\n     * @group Props\n     */\n    @Input() overlayOptions: OverlayOptions | undefined;\n    /**\n     * An array of suggestions to display.\n     * @group Props\n     */\n    @Input() get suggestions(): any[] {\n        return this._suggestions;\n    }\n    set suggestions(value: any[]) {\n        this._suggestions = value;\n        this.handleSuggestionsChange();\n    }\n    /**\n     * Element dimensions of option for virtual scrolling.\n     * @group Props\n     * @deprecated use virtualScrollItemSize property instead.\n     */\n    @Input() get itemSize(): number {\n        return this._itemSize as number;\n    }\n    set itemSize(val: number) {\n        this._itemSize = val;\n        console.warn('The itemSize property is deprecated, use virtualScrollItemSize property instead.');\n    }\n    /**\n     * Callback to invoke to search for suggestions.\n     * @param {AutoCompleteCompleteEvent} event - Custom complete event.\n     * @group Emits\n     */\n    @Output() completeMethod: EventEmitter<AutoCompleteCompleteEvent> = new EventEmitter<AutoCompleteCompleteEvent>();\n    /**\n     * Callback to invoke when a suggestion is selected.\n     * @param {*} value - selected value.\n     * @group Emits\n     */\n    @Output() onSelect: EventEmitter<any> = new EventEmitter<any>();\n    /**\n     * Callback to invoke when a selected value is removed.\n     * @param {*} value - removed value.\n     * @group Emits\n     */\n    @Output() onUnselect: EventEmitter<any> = new EventEmitter<any>();\n    /**\n     * Callback to invoke when the component receives focus.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onFocus: EventEmitter<Event> = new EventEmitter();\n    /**\n     * Callback to invoke when the component loses focus.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onBlur: EventEmitter<Event> = new EventEmitter();\n    /**\n     * Callback to invoke to when dropdown button is clicked.\n     * @param {AutoCompleteDropdownClickEvent} event - custom dropdown click event.\n     * @group Emits\n     */\n    @Output() onDropdownClick: EventEmitter<AutoCompleteDropdownClickEvent> = new EventEmitter<AutoCompleteDropdownClickEvent>();\n    /**\n     * Callback to invoke when clear button is clicked.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onClear: EventEmitter<Event | undefined> = new EventEmitter<Event | undefined>();\n    /**\n     * Callback to invoke on input key up.\n     * @param {KeyboardEvent} event - Keyboard event.\n     * @group Emits\n     */\n    @Output() onKeyUp: EventEmitter<KeyboardEvent> = new EventEmitter();\n    /**\n     * Callback to invoke on overlay is shown.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onShow: EventEmitter<Event> = new EventEmitter<Event>();\n    /**\n     * Callback to invoke on overlay is hidden.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onHide: EventEmitter<Event> = new EventEmitter<Event>();\n    /**\n     * Callback to invoke on lazy load data.\n     * @param {AutoCompleteLazyLoadEvent} event - Lazy load event.\n     * @group Emits\n     */\n    @Output() onLazyLoad: EventEmitter<AutoCompleteLazyLoadEvent> = new EventEmitter<AutoCompleteLazyLoadEvent>();\n\n    @ViewChild('container') containerEL: Nullable<ElementRef>;\n\n    @ViewChild('in') inputEL: Nullable<ElementRef>;\n\n    @ViewChild('multiIn') multiInputEl: Nullable<ElementRef>;\n\n    @ViewChild('multiContainer') multiContainerEL: Nullable<ElementRef>;\n\n    @ViewChild('ddBtn') dropdownButton: Nullable<ElementRef>;\n\n    @ViewChild('items') itemsViewChild: Nullable<ElementRef>;\n\n    @ViewChild('scroller') scroller: Nullable<Scroller>;\n\n    @ViewChild('overlay') overlayViewChild!: Overlay;\n\n    @ContentChildren(PrimeTemplate) templates: Nullable<QueryList<PrimeTemplate>>;\n\n    _itemSize: Nullable<number>;\n\n    itemsWrapper: Nullable<HTMLDivElement>;\n\n    itemTemplate: Nullable<TemplateRef<any>>;\n\n    emptyTemplate: Nullable<TemplateRef<any>>;\n\n    headerTemplate: Nullable<TemplateRef<any>>;\n\n    footerTemplate: Nullable<TemplateRef<any>>;\n\n    selectedItemTemplate: Nullable<TemplateRef<any>>;\n\n    groupTemplate: Nullable<TemplateRef<any>>;\n\n    loaderTemplate: Nullable<TemplateRef<any>>;\n\n    removeIconTemplate: Nullable<TemplateRef<any>>;\n\n    loadingIconTemplate: Nullable<TemplateRef<any>>;\n\n    clearIconTemplate: Nullable<TemplateRef<any>>;\n\n    dropdownIconTemplate: Nullable<TemplateRef<any>>;\n\n    value: string | any;\n\n    _suggestions: any;\n\n    onModelChange: Function = () => {};\n\n    onModelTouched: Function = () => {};\n\n    timeout: Nullable<any>;\n\n    overlayVisible: boolean = false;\n\n    suggestionsUpdated: Nullable<boolean>;\n\n    highlightOption: any;\n\n    highlightOptionChanged: Nullable<boolean>;\n\n    focus: boolean = false;\n\n    filled: number | boolean | undefined;\n\n    inputClick: Nullable<boolean>;\n\n    inputKeyDown: Nullable<boolean>;\n\n    noResults: Nullable<boolean>;\n\n    differ: any;\n\n    inputFieldValue: Nullable<string> = null;\n\n    loading: Nullable<boolean>;\n\n    scrollHandler: Nullable<ConnectedOverlayScrollHandler>;\n\n    documentResizeListener: VoidListener;\n\n    forceSelectionUpdateModelTimeout: any;\n\n    listId: string | undefined;\n\n    itemClicked: boolean | undefined;\n\n    inputValue: Nullable<string> = null;\n\n    isSearching: boolean = false;\n\n    constructor(\n        @Inject(DOCUMENT) private document: Document,\n        public el: ElementRef,\n        public renderer: Renderer2,\n        public cd: ChangeDetectorRef,\n        public differs: IterableDiffers,\n        public config: PrimeNGConfig,\n        public overlayService: OverlayService,\n        private zone: NgZone\n    ) {\n        this.differ = differs.find([]).create(undefined);\n        this.listId = UniqueComponentId() + '_list';\n    }\n\n    ngAfterViewChecked() {\n        //Use timeouts as since Angular 4.2, AfterViewChecked is broken and not called after panel is updated\n        if (this.suggestionsUpdated && this.overlayViewChild) {\n            this.zone.runOutsideAngular(() => {\n                setTimeout(() => {\n                    if (this.overlayViewChild) {\n                        this.overlayViewChild.alignOverlay();\n                    }\n                }, 1);\n                this.suggestionsUpdated = false;\n            });\n        }\n\n        if (this.highlightOptionChanged) {\n            this.zone.runOutsideAngular(() => {\n                setTimeout(() => {\n                    if (this.overlayViewChild && this.itemsWrapper) {\n                        let listItem = DomHandler.findSingle((this.overlayViewChild.overlayViewChild as ElementRef).nativeElement, 'li.p-highlight');\n\n                        if (listItem) {\n                            DomHandler.scrollInView(this.itemsWrapper, listItem);\n                        }\n                    }\n                }, 1);\n                this.highlightOptionChanged = false;\n            });\n        }\n    }\n\n    handleSuggestionsChange() {\n        if (this._suggestions != null && this.loading) {\n            this.highlightOption = null;\n            if (this._suggestions.length) {\n                this.noResults = false;\n                this.show();\n                this.suggestionsUpdated = true;\n\n                if (this.autoHighlight) {\n                    this.highlightOption = this._suggestions[0];\n                }\n            } else {\n                this.noResults = true;\n\n                if (this.showEmptyMessage) {\n                    this.show();\n                    this.suggestionsUpdated = true;\n                } else {\n                    this.hide();\n                }\n            }\n\n            this.loading = false;\n            this.isSearching = false;\n        }\n    }\n\n    ngAfterContentInit() {\n        (this.templates as QueryList<PrimeTemplate>).forEach((item) => {\n            switch (item.getType()) {\n                case 'item':\n                    this.itemTemplate = item.template;\n                    break;\n\n                case 'group':\n                    this.groupTemplate = item.template;\n                    break;\n\n                case 'selectedItem':\n                    this.selectedItemTemplate = item.template;\n                    break;\n\n                case 'header':\n                    this.headerTemplate = item.template;\n                    break;\n\n                case 'empty':\n                    this.emptyTemplate = item.template;\n                    break;\n\n                case 'footer':\n                    this.footerTemplate = item.template;\n                    break;\n\n                case 'loader':\n                    this.loaderTemplate = item.template;\n                    break;\n\n                case 'removetokenicon':\n                    this.removeIconTemplate = item.template;\n                    break;\n\n                case 'loadingicon':\n                    this.loadingIconTemplate = item.template;\n                    break;\n\n                case 'clearicon':\n                    this.clearIconTemplate = item.template;\n                    break;\n\n                case 'dropdownicon':\n                    this.dropdownIconTemplate = item.template;\n                    break;\n\n                default:\n                    this.itemTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n        this.filled = this.value && this.value.length ? true : false;\n        this.updateInputField();\n        this.cd.markForCheck();\n    }\n\n    getOptionGroupChildren(optionGroup: any) {\n        return this.optionGroupChildren ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupChildren) : optionGroup.items;\n    }\n\n    getOptionGroupLabel(optionGroup: any) {\n        return this.optionGroupLabel ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupLabel) : optionGroup.label != undefined ? optionGroup.label : optionGroup;\n    }\n\n    registerOnChange(fn: Function): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: Function): void {\n        this.onModelTouched = fn;\n    }\n\n    setDisabledState(val: boolean): void {\n        this.disabled = val;\n        this.cd.markForCheck();\n    }\n\n    onInput(event: Event) {\n        // When an input element with a placeholder is clicked, the onInput event is invoked in IE.\n        if (!this.inputKeyDown && DomHandler.isIE()) {\n            return;\n        }\n\n        if (this.timeout) {\n            clearTimeout(this.timeout);\n        }\n\n        let value = (<HTMLInputElement>event.target).value;\n        this.inputValue = value;\n        if (!this.multiple && !this.forceSelection) {\n            this.onModelChange(value);\n        }\n\n        if (value.length === 0 && !this.multiple) {\n            this.value = null;\n            this.hide();\n            this.onClear.emit(event);\n            this.onModelChange(value);\n        }\n\n        if (value.length >= this.minLength) {\n            this.timeout = setTimeout(() => {\n                this.search(event, value);\n            }, this.delay);\n        } else {\n            this.hide();\n        }\n        this.updateFilledState();\n        this.inputKeyDown = false;\n    }\n\n    onInputClick(event: MouseEvent) {\n        this.inputClick = true;\n    }\n\n    search(event: any, query: string) {\n        if (!this.isSearching) {\n            this.isSearching = true;\n            this.loading = true;\n\n            this.completeMethod.emit({\n                originalEvent: event,\n                query: query\n            });\n\n            setTimeout(() => {\n                this.isSearching = false;\n            }, 100);\n        }\n    }\n\n    selectItem(option: any, focus: boolean = true) {\n        if (this.forceSelectionUpdateModelTimeout) {\n            clearTimeout(this.forceSelectionUpdateModelTimeout);\n            this.forceSelectionUpdateModelTimeout = null;\n        }\n\n        if (this.multiple) {\n            (this.multiInputEl as ElementRef).nativeElement.value = '';\n            this.value = this.value || [];\n            if (!this.isSelected(option) || !this.unique) {\n                this.value = [...this.value, option];\n                this.onModelChange(this.value);\n            }\n        } else {\n            (this.inputEL as ElementRef).nativeElement.value = this.resolveFieldData(option);\n            this.value = option;\n            this.onModelChange(this.value);\n        }\n\n        this.onSelect.emit(option);\n        this.updateFilledState();\n\n        if (focus) {\n            this.itemClicked = true;\n            this.focusInput();\n        }\n\n        this.hide();\n    }\n\n    show(event?: Event) {\n        if (this.multiInputEl || this.inputEL) {\n            let hasFocus = this.multiple ? this.multiInputEl?.nativeElement.ownerDocument.activeElement == this.multiInputEl?.nativeElement : this.inputEL?.nativeElement.ownerDocument.activeElement == this.inputEL?.nativeElement;\n\n            if (!this.overlayVisible && hasFocus) {\n                this.overlayVisible = true;\n            }\n        }\n\n        this.onShow.emit(event);\n        this.cd.markForCheck();\n    }\n\n    clear() {\n        this.value = null;\n        this.inputValue = null;\n        if (this.multiple) {\n            (<ElementRef>this.multiInputEl).nativeElement.value = '';\n        } else {\n            this.inputValue = null;\n            (<ElementRef>this.inputEL).nativeElement.value = '';\n        }\n\n        this.updateFilledState();\n        this.onModelChange(this.value);\n        this.onClear.emit();\n    }\n\n    onOverlayAnimationStart(event: AnimationEvent) {\n        if (event.toState === 'visible') {\n            this.itemsWrapper = DomHandler.findSingle(this.overlayViewChild.overlayViewChild?.nativeElement, this.virtualScroll ? '.p-scroller' : '.p-autocomplete-panel');\n            this.virtualScroll && this.scroller?.setContentEl(this.itemsViewChild?.nativeElement);\n        }\n    }\n\n    resolveFieldData(value: any) {\n        let data = this.field ? ObjectUtils.resolveFieldData(value, this.field) : value;\n        return data !== (null || undefined) ? data : '';\n    }\n\n    hide(event?: any) {\n        this.overlayVisible = false;\n\n        this.onHide.emit(event);\n        this.cd.markForCheck();\n    }\n\n    handleDropdownClick(event: Event) {\n        if (!this.overlayVisible) {\n            this.focusInput();\n            let queryValue = this.multiple ? (this.multiInputEl as ElementRef).nativeElement.value : (this.inputEL as ElementRef).nativeElement.value;\n\n            if (this.dropdownMode === 'blank') {\n                this.onDropdownClick.emit({\n                    originalEvent: event,\n                    query: ''\n                });\n                this.search(event, '');\n            } else if (this.dropdownMode === 'current') {\n                this.onDropdownClick.emit({\n                    originalEvent: event,\n                    query: queryValue\n                });\n                this.search(event, queryValue);\n            }\n        } else {\n            this.hide(event);\n        }\n    }\n\n    focusInput() {\n        if (this.multiple) (this.multiInputEl as ElementRef).nativeElement.focus();\n        else this.inputEL?.nativeElement.focus();\n    }\n\n    get emptyMessageLabel(): string {\n        return this.emptyMessage || this.config.getTranslation(TranslationKeys.EMPTY_MESSAGE);\n    }\n\n    removeItem(item: any) {\n        let itemIndex = DomHandler.index(item);\n        let removedValue = (this.value as object[])[itemIndex];\n        this.value = (this.value as object[]).filter((val: any, i: number) => i != itemIndex);\n        this.onModelChange(this.value);\n        this.updateFilledState();\n        this.onUnselect.emit(removedValue);\n    }\n\n    onKeydown(event: Event) {\n        if (this.overlayVisible) {\n            switch ((<KeyboardEvent>event).which) {\n                //down\n                case 40:\n                    if (this.group) {\n                        let highlightItemIndex = this.findOptionGroupIndex(this.highlightOption, this.suggestions);\n                        if (highlightItemIndex !== -1) {\n                            let nextItemIndex = highlightItemIndex.itemIndex + 1;\n                            if (nextItemIndex < this.getOptionGroupChildren(this.suggestions[highlightItemIndex.groupIndex]).length) {\n                                this.highlightOption = this.getOptionGroupChildren(this.suggestions[highlightItemIndex.groupIndex])[nextItemIndex];\n                                this.highlightOptionChanged = true;\n                            } else if (this.suggestions[highlightItemIndex.groupIndex + 1]) {\n                                this.highlightOption = this.getOptionGroupChildren(this.suggestions[highlightItemIndex.groupIndex + 1])[0];\n                                this.highlightOptionChanged = true;\n                            }\n                        } else {\n                            this.highlightOption = this.getOptionGroupChildren(this.suggestions[0])[0];\n                        }\n                    } else {\n                        let highlightItemIndex = this.findOptionIndex(this.highlightOption, this.suggestions);\n                        if (highlightItemIndex != -1) {\n                            var nextItemIndex = highlightItemIndex + 1;\n                            if (nextItemIndex != this.suggestions.length) {\n                                this.highlightOption = this.suggestions[nextItemIndex];\n                                this.highlightOptionChanged = true;\n                            }\n                        } else {\n                            this.highlightOption = this.suggestions[0];\n                        }\n                    }\n\n                    event.preventDefault();\n                    break;\n\n                //up\n                case 38:\n                    if (this.group) {\n                        let highlightItemIndex = this.findOptionGroupIndex(this.highlightOption, this.suggestions);\n                        if (highlightItemIndex !== -1) {\n                            let prevItemIndex = highlightItemIndex.itemIndex - 1;\n                            if (prevItemIndex >= 0) {\n                                this.highlightOption = this.getOptionGroupChildren(this.suggestions[highlightItemIndex.groupIndex])[prevItemIndex];\n                                this.highlightOptionChanged = true;\n                            } else if (prevItemIndex < 0) {\n                                let prevGroup = this.suggestions[highlightItemIndex.groupIndex - 1];\n                                if (prevGroup) {\n                                    this.highlightOption = this.getOptionGroupChildren(prevGroup)[this.getOptionGroupChildren(prevGroup).length - 1];\n                                    this.highlightOptionChanged = true;\n                                }\n                            }\n                        }\n                    } else {\n                        let highlightItemIndex = this.findOptionIndex(this.highlightOption, this.suggestions);\n\n                        if (highlightItemIndex > 0) {\n                            let prevItemIndex = highlightItemIndex - 1;\n                            this.highlightOption = this.suggestions[prevItemIndex];\n                            this.highlightOptionChanged = true;\n                        }\n                    }\n\n                    event.preventDefault();\n                    break;\n\n                //enter\n                case 13:\n                    if (this.highlightOption) {\n                        this.selectItem(this.highlightOption);\n                        this.hide();\n                    }\n                    event.preventDefault();\n                    break;\n\n                //escape\n                case 27:\n                    this.hide();\n                    event.preventDefault();\n                    break;\n\n                //tab\n                case 9:\n                    if (this.highlightOption) {\n                        this.selectItem(this.highlightOption);\n                    }\n                    this.hide();\n                    break;\n            }\n        } else {\n            if ((<KeyboardEvent>event).which === 40 && this.suggestions) {\n                this.search(event, (<HTMLInputElement>event.target).value);\n            } else if ((<KeyboardEvent>event).ctrlKey && (<KeyboardEvent>event).key === 'z' && !this.multiple) {\n                (this.inputEL as ElementRef).nativeElement.value = this.resolveFieldData(null);\n                this.value = '';\n                this.onModelChange(this.value);\n            } else if ((<KeyboardEvent>event).ctrlKey && (<KeyboardEvent>event).key === 'z' && this.multiple) {\n                (this.value as object[]).pop();\n                this.onModelChange(this.value);\n                this.updateFilledState();\n            }\n        }\n\n        if (this.multiple) {\n            switch ((<KeyboardEvent>event).which) {\n                //backspace\n                case 8:\n                    if (this.value && this.value.length && !this.multiInputEl?.nativeElement.value) {\n                        this.value = [...this.value] as object[];\n                        const removedValue = this.value.pop();\n                        this.onModelChange(this.value);\n                        this.updateFilledState();\n                        this.onUnselect.emit(removedValue);\n                    }\n                    break;\n            }\n        }\n\n        this.inputKeyDown = true;\n    }\n\n    onKeyup(event: KeyboardEvent) {\n        this.onKeyUp.emit(event);\n    }\n\n    onInputFocus(event: Event) {\n        if (!this.itemClicked && this.completeOnFocus) {\n            let queryValue = this.multiple ? this.multiInputEl?.nativeElement.value : this.inputEL?.nativeElement.value;\n            this.search(event, queryValue);\n        }\n\n        this.focus = true;\n        this.onFocus.emit(event);\n        this.itemClicked = false;\n    }\n\n    onInputBlur(event: Event) {\n        this.focus = false;\n        this.onModelTouched();\n        this.onBlur.emit(event);\n    }\n\n    onInputChange(event: Event) {\n        if (this.forceSelection) {\n            let valid = false;\n            const target = event.target as HTMLTextAreaElement;\n            let inputValue = target.value.trim();\n\n            if (this.suggestions) {\n                let suggestions = [...this.suggestions];\n                if (this.group) {\n                    let groupedSuggestions = this.suggestions.filter((s) => s[this.optionGroupChildren]).flatMap((s) => s[this.optionGroupChildren]);\n                    suggestions = suggestions.concat(groupedSuggestions);\n                }\n\n                for (let suggestion of suggestions) {\n                    let itemValue = this.field ? ObjectUtils.resolveFieldData(suggestion, this.field) : suggestion;\n                    if (itemValue && inputValue.toLowerCase() === itemValue.toLowerCase().trim()) {\n                        valid = true;\n                        this.forceSelectionUpdateModelTimeout = setTimeout(() => {\n                            this.selectItem(suggestion, false);\n                        }, 250);\n                        break;\n                    }\n                }\n            }\n\n            if (!valid) {\n                if (this.multiple) {\n                    (<ElementRef>this.multiInputEl).nativeElement.value = '';\n                } else {\n                    this.value = null;\n                    (<ElementRef>this.inputEL).nativeElement.value = '';\n                }\n\n                this.onClear.emit(event);\n                this.onModelChange(this.value);\n                this.updateFilledState();\n            }\n        }\n    }\n\n    onInputPaste(event: ClipboardEvent) {\n        this.onKeydown(event);\n    }\n\n    isSelected(val: any): boolean {\n        let selected: boolean = false;\n        if (this.value && this.value.length) {\n            for (let i = 0; i < this.value.length; i++) {\n                if (ObjectUtils.equals(this.value[i], val, this.dataKey)) {\n                    selected = true;\n                    break;\n                }\n            }\n        }\n        return selected;\n    }\n\n    findOptionIndex(option: any, suggestions: any): number {\n        let index: number = -1;\n        if (suggestions) {\n            for (let i = 0; i < suggestions.length; i++) {\n                if (ObjectUtils.equals(option, suggestions[i])) {\n                    index = i;\n                    break;\n                }\n            }\n        }\n\n        return index;\n    }\n\n    findOptionGroupIndex(val: any, opts: any[]): any {\n        let groupIndex, itemIndex;\n\n        if (opts) {\n            for (let i = 0; i < opts.length; i++) {\n                groupIndex = i;\n                itemIndex = this.findOptionIndex(val, this.getOptionGroupChildren(opts[i]));\n\n                if (itemIndex !== -1) {\n                    break;\n                }\n            }\n        }\n\n        if (itemIndex !== -1) {\n            return { groupIndex: groupIndex, itemIndex: itemIndex };\n        } else {\n            return -1;\n        }\n    }\n\n    updateFilledState() {\n        if (this.multiple) this.filled = (this.value && this.value.length) || (this.multiInputEl && this.multiInputEl.nativeElement && this.multiInputEl.nativeElement.value != '');\n        else this.filled = (this.inputFieldValue && this.inputFieldValue != '') || (this.inputEL && this.inputEL.nativeElement && this.inputEL.nativeElement.value != '');\n    }\n\n    updateInputField() {\n        let formattedValue = this.resolveFieldData(this.value);\n        this.inputFieldValue = formattedValue;\n\n        if (this.inputEL && this.inputEL.nativeElement) {\n            this.inputEL.nativeElement.value = formattedValue;\n        }\n\n        this.updateFilledState();\n    }\n\n    ngOnDestroy() {\n        if (this.forceSelectionUpdateModelTimeout) {\n            clearTimeout(this.forceSelectionUpdateModelTimeout);\n            this.forceSelectionUpdateModelTimeout = null;\n        }\n\n        if (this.scrollHandler) {\n            this.scrollHandler.destroy();\n            this.scrollHandler = null;\n        }\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, OverlayModule, InputTextModule, ButtonModule, SharedModule, RippleModule, ScrollerModule, AutoFocusModule, TimesCircleIcon, SpinnerIcon, TimesIcon, ChevronDownIcon],\n    exports: [AutoComplete, OverlayModule, SharedModule, ScrollerModule, AutoFocusModule],\n    declarations: [AutoComplete]\n})\nexport class AutoCompleteModule {}\n"]}
|
1780
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.js","sourceRoot":"","sources":["../../../src/app/components/autocomplete/autocomplete.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, AnimationEvent, style, transition, trigger } from '@angular/animations';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    AfterContentInit,\n    AfterViewChecked,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    computed,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Inject,\n    Input,\n    NgModule,\n    NgZone,\n    OnDestroy,\n    Output,\n    QueryList,\n    Renderer2,\n    signal,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { OverlayOptions, OverlayService, PrimeNGConfig, PrimeTemplate, SharedModule } from 'primeng/api';\nimport { AutoFocusModule } from 'primeng/autofocus';\nimport { ButtonModule } from 'primeng/button';\nimport { ConnectedOverlayScrollHandler, DomHandler } from 'primeng/dom';\nimport { InputTextModule } from 'primeng/inputtext';\nimport { Overlay, OverlayModule } from 'primeng/overlay';\nimport { RippleModule } from 'primeng/ripple';\nimport { Scroller, ScrollerModule } from 'primeng/scroller';\nimport { ScrollerOptions } from 'primeng/api';\nimport { ObjectUtils, UniqueComponentId } from 'primeng/utils';\nimport { TimesCircleIcon } from 'primeng/icons/timescircle';\nimport { SpinnerIcon } from 'primeng/icons/spinner';\nimport { TimesIcon } from 'primeng/icons/times';\nimport { ChevronDownIcon } from 'primeng/icons/chevrondown';\nimport { Nullable, VoidListener } from 'primeng/ts-helpers';\nimport { AutoCompleteCompleteEvent, AutoCompleteDropdownClickEvent, AutoCompleteLazyLoadEvent, AutoCompleteOnSelectEvent, AutoCompleteUnselectEvent } from './autocomplete.interface';\n\nexport const AUTOCOMPLETE_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => AutoComplete),\n    multi: true\n};\n/**\n * AutoComplete is an input component that provides real-time suggestions when being typed.\n * @group Components\n */\n@Component({\n    selector: 'p-autoComplete',\n    template: `\n        <div #container [ngClass]=\"containerClass\" [ngStyle]=\"style\" [class]=\"styleClass\" (click)=\"onContainerClick($event)\">\n            <input\n                *ngIf=\"!multiple\"\n                #focusInput\n                pAutoFocus\n                [autofocus]=\"autofocus\"\n                [ngClass]=\"inputClass\"\n                [ngStyle]=\"inputStyle\"\n                [class]=\"inputStyleClass\"\n                [type]=\"type\"\n                [attr.value]=\"inputValue()\"\n                [attr.id]=\"inputId\"\n                [autocomplete]=\"autocomplete\"\n                [required]=\"required\"\n                [name]=\"name\"\n                aria-autocomplete=\"list\"\n                role=\"combobox\"\n                [attr.placeholder]=\"placeholder\"\n                [attr.size]=\"size\"\n                [maxlength]=\"maxlength\"\n                [tabindex]=\"!disabled ? tabindex : -1\"\n                [readonly]=\"readonly\"\n                [disabled]=\"disabled\"\n                [attr.aria-label]=\"ariaLabel\"\n                [attr.aria-labelledby]=\"ariaLabelledBy\"\n                [attr.aria-required]=\"required\"\n                [attr.aria-expanded]=\"overlayVisible\"\n                [attr.aria-controls]=\"id + '_list'\"\n                [attr.aria-aria-activedescendant]=\"focused ? focusedOptionId : undefined\"\n                (input)=\"onInput($event)\"\n                (keydown)=\"onKeyDown($event)\"\n                (change)=\"onInputChange($event)\"\n                (focus)=\"onInputFocus($event)\"\n                (blur)=\"onInputBlur($event)\"\n                (paste)=\"onInputPaste($event)\"\n                (keyup)=\"onInputKeyUp($event)\"\n            />\n            <ng-container *ngIf=\"filled && !disabled && showClear && !loading\">\n                <TimesIcon *ngIf=\"!clearIconTemplate\" [styleClass]=\"'p-autocomplete-clear-icon'\" (click)=\"clear()\" [attr.aria-hidden]=\"true\" />\n                <span *ngIf=\"clearIconTemplate\" class=\"p-autocomplete-clear-icon\" (click)=\"clear()\" [attr.aria-hidden]=\"true\">\n                    <ng-template *ngTemplateOutlet=\"clearIconTemplate\"></ng-template>\n                </span>\n            </ng-container>\n\n            <ul\n                *ngIf=\"multiple\"\n                #multiContainer\n                [class]=\"multiContainerClass\"\n                [tabindex]=\"-1\"\n                role=\"listbox\"\n                [attr.aria-orientation]=\"'horizontal'\"\n                [attr.aria-activedescendant]=\"focused ? focusedMultipleOptionId : undefined\"\n                (focus)=\"onMultipleContainerFocus($event)\"\n                (blur)=\"onMultipleContainerBlur($event)\"\n                (keydown)=\"onMultipleContainerKeyDown($event)\"\n            >\n                <li\n                    #token\n                    *ngFor=\"let option of modelValue(); let i = index\"\n                    [ngClass]=\"{ 'p-autocomplete-token': true, 'p-focus': focusedMultipleOptionIndex() === i }\"\n                    [attr.id]=\"id + '_multiple_option_' + i\"\n                    role=\"option\"\n                    [attr.aria-label]=\"getOptionLabel(option)\"\n                    [attr.aria-setsize]=\"modelValue().length\"\n                    [attr.aria-posinset]=\"i + 1\"\n                    [attr.aria-selected]=\"true\"\n                >\n                    <ng-container *ngTemplateOutlet=\"selectedItemTemplate; context: { $implicit: option }\"></ng-container>\n                    <span *ngIf=\"!selectedItemTemplate\" class=\"p-autocomplete-token-label\">{{ getOptionLabel(option) }}</span>\n                    <span class=\"p-autocomplete-token-icon\" (click)=\"removeOption($event, i)\">\n                        <TimesCircleIcon [styleClass]=\"'p-autocomplete-token-icon'\" *ngIf=\"!removeIconTemplate\" [attr.aria-hidden]=\"true\" />\n                        <span *ngIf=\"removeIconTemplate\" class=\"p-autocomplete-token-icon\" [attr.aria-hidden]=\"true\">\n                            <ng-template *ngTemplateOutlet=\"removeIconTemplate\"></ng-template>\n                        </span>\n                    </span>\n                </li>\n                <li class=\"p-autocomplete-input-token\" role=\"option\">\n                    <input\n                        #focusInput\n                        pAutoFocus\n                        [autofocus]=\"autofocus\"\n                        [ngClass]=\"inputClass\"\n                        [ngStyle]=\"inputStyle\"\n                        [class]=\"inputStyleClass\"\n                        [attr.type]=\"type\"\n                        [attr.id]=\"inputId\"\n                        [autocomplete]=\"autocomplete\"\n                        [required]=\"required\"\n                        [attr.name]=\"name\"\n                        role=\"combobox\"\n                        [attr.placeholder]=\"placeholder\"\n                        [attr.size]=\"size\"\n                        aria-autocomplete=\"list\"\n                        [maxlength]=\"maxlength\"\n                        [tabindex]=\"!disabled ? tabindex : -1\"\n                        [readonly]=\"readonly\"\n                        [disabled]=\"disabled\"\n                        [attr.aria-label]=\"ariaLabel\"\n                        [attr.aria-labelledby]=\"ariaLabelledBy\"\n                        [attr.aria-required]=\"required\"\n                        [attr.aria-expanded]=\"overlayVisible\"\n                        [attr.aria-controls]=\"id + '_list'\"\n                        [attr.aria-aria-activedescendant]=\"focused ? focusedOptionId : undefined\"\n                        (input)=\"onInput($event)\"\n                        (keydown)=\"onKeyDown($event)\"\n                        (change)=\"onInputChange($event)\"\n                        (focus)=\"onInputFocus($event)\"\n                        (blur)=\"onInputBlur($event)\"\n                        (paste)=\"onInputPaste($event)\"\n                        (keyup)=\"onInputKeyUp($event)\"\n                    />\n                </li>\n            </ul>\n            <ng-container *ngIf=\"loading\">\n                <SpinnerIcon *ngIf=\"!loadingIconTemplate\" [styleClass]=\"'p-autocomplete-loader'\" [spin]=\"true\" [attr.aria-hidden]=\"true\" />\n                <span *ngIf=\"loadingIconTemplate\" class=\"p-autocomplete-loader pi-spin \" [attr.aria-hidden]=\"true\">\n                    <ng-template *ngTemplateOutlet=\"loadingIconTemplate\"></ng-template>\n                </span>\n            </ng-container>\n            <button #ddBtn type=\"button\" pButton [attr.aria-label]=\"dropdownAriaLabel\" class=\"p-autocomplete-dropdown p-button-icon-only\" [disabled]=\"disabled\" pRipple (click)=\"handleDropdownClick($event)\" *ngIf=\"dropdown\" [attr.tabindex]=\"tabindex\">\n                <span *ngIf=\"dropdownIcon\" [ngClass]=\"dropdownIcon\" [attr.aria-hidden]=\"true\"></span>\n                <ng-container *ngIf=\"!dropdownIcon\">\n                    <ChevronDownIcon *ngIf=\"!dropdownIconTemplate\" />\n                    <ng-template *ngTemplateOutlet=\"dropdownIconTemplate\"></ng-template>\n                </ng-container>\n            </button>\n            <p-overlay\n                #overlay\n                [(visible)]=\"overlayVisible\"\n                [options]=\"virtualScrollOptions\"\n                [target]=\"'@parent'\"\n                [appendTo]=\"appendTo\"\n                [showTransitionOptions]=\"showTransitionOptions\"\n                [hideTransitionOptions]=\"hideTransitionOptions\"\n                (onAnimationStart)=\"onOverlayAnimationStart($event)\"\n                (onHide)=\"hide()\"\n            >\n                <div [ngClass]=\"panelClass\" [style.max-height]=\"virtualScroll ? 'auto' : scrollHeight\" [ngStyle]=\"panelStyle\" [class]=\"panelStyleClass\">\n                    <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n                    <p-scroller\n                        *ngIf=\"virtualScroll\"\n                        #scroller\n                        [items]=\"visibleOptions()\"\n                        [tabindex]=\"-1\"\n                        [style]=\"{ height: scrollHeight }\"\n                        [itemSize]=\"virtualScrollItemSize || _itemSize\"\n                        [autoSize]=\"true\"\n                        [lazy]=\"lazy\"\n                        (onLazyLoad)=\"onLazyLoad.emit($event)\"\n                        [options]=\"virtualScrollOptions\"\n                    >\n                        <ng-template pTemplate=\"content\" let-items let-scrollerOptions=\"options\">\n                            <ng-container *ngTemplateOutlet=\"buildInItems; context: { $implicit: items, options: scrollerOptions }\"></ng-container>\n                        </ng-template>\n                        <ng-container *ngIf=\"loaderTemplate\">\n                            <ng-template pTemplate=\"loader\" let-scrollerOptions=\"options\">\n                                <ng-container *ngTemplateOutlet=\"loaderTemplate; context: { options: scrollerOptions }\"></ng-container>\n                            </ng-template>\n                        </ng-container>\n                    </p-scroller>\n                    <ng-container *ngIf=\"!virtualScroll\">\n                        <ng-container *ngTemplateOutlet=\"buildInItems; context: { $implicit: visibleOptions(), options: {} }\"></ng-container>\n                    </ng-container>\n\n                    <ng-template #buildInItems let-items let-scrollerOptions=\"options\">\n                        <ul #items class=\"p-autocomplete-items\" [ngClass]=\"scrollerOptions.contentStyleClass\" [style]=\"scrollerOptions.contentStyle\" role=\"listbox\" [attr.id]=\"id + '_list'\">\n                            <ng-template ngFor let-option [ngForOf]=\"items\" let-i=\"index\">\n                                <ng-container *ngIf=\"isOptionGroup(option)\">\n                                    <li [attr.id]=\"id + '_' + getOptionIndex(i, scrollerOptions)\" class=\"p-autocomplete-item-group\" [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\" role=\"option\">\n                                        <span *ngIf=\"!groupTemplate\">{{ getOptionGroupLabel(option.optionGroup) }}</span>\n                                        <ng-container *ngTemplateOutlet=\"groupTemplate; context: { $implicit: option.optionGroup }\"></ng-container>\n                                    </li>\n                                </ng-container>\n                                <ng-container *ngIf=\"!isOptionGroup(option)\">\n                                    <li\n                                        class=\"p-autocomplete-item\"\n                                        pRipple\n                                        [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\"\n                                        [ngClass]=\"{ 'p-highlight': isSelected(option), 'p-focus': focusedOptionIndex() === getOptionIndex(i, scrollerOptions), 'p-disabled': isOptionDisabled(option) }\"\n                                        [attr.id]=\"id + '_' + getOptionIndex(i, scrollerOptions)\"\n                                        role=\"option\"\n                                        [attr.aria-label]=\"getOptionLabel(option)\"\n                                        [attr.aria-selected]=\"isSelected(option)\"\n                                        [attr.aria-disabled]=\"isOptionDisabled(option)\"\n                                        [attr.data-p-focused]=\"focusedOptionIndex() === getOptionIndex(i, scrollerOptions)\"\n                                        [attr.aria-setsize]=\"ariaSetSize\"\n                                        [attr.aria-posinset]=\"getAriaPosInset(getOptionIndex(i, scrollerOptions))\"\n                                        (click)=\"onOptionSelect($event, option)\"\n                                        (mouseenter)=\"onOptionMouseEnter($event, getOptionIndex(i, scrollerOptions))\"\n                                    >\n                                        <span *ngIf=\"!itemTemplate\">{{ getOptionLabel(option) }}</span>\n                                        <ng-container *ngTemplateOutlet=\"itemTemplate; context: { $implicit: option, index: scrollerOptions.getOptions ? scrollerOptions.getOptions(i) : i }\"></ng-container>\n                                    </li>\n                                </ng-container>\n                            </ng-template>\n                            <li *ngIf=\"!items || (items && items.length === 0 && showEmptyMessage)\" class=\"p-autocomplete-empty-message\" [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\" role=\"option\">\n                                <ng-container *ngIf=\"!emptyTemplate; else empty\">\n                                    {{ searchResultMessageText }}\n                                </ng-container>\n                                <ng-container #empty *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n                            </li>\n                        </ul>\n                        <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: items }\"></ng-container>\n                        <span role=\"status\" aria-live=\"polite\" class=\"p-hidden-accessible\">\n                            {{ selectedMessageText }}\n                        </span>\n                    </ng-template>\n                </div>\n            </p-overlay>\n        </div>\n    `,\n    host: {\n        class: 'p-element p-inputwrapper',\n        '[class.p-inputwrapper-filled]': 'filled',\n        '[class.p-inputwrapper-focus]': '((focused && !disabled) || autofocus) || overlayVisible',\n        '[class.p-autocomplete-clearable]': 'showClear && !disabled'\n    },\n    providers: [AUTOCOMPLETE_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./autocomplete.css']\n})\nexport class AutoComplete implements AfterViewChecked, AfterContentInit, OnDestroy, ControlValueAccessor {\n    /**\n     * Minimum number of characters to initiate a search.\n     * @group Props\n     */\n    @Input() minLength: number = 1;\n    /**\n     * Delay between keystrokes to wait before sending a query.\n     * @group Props\n     */\n    @Input() delay: number = 300;\n    /**\n     * Inline style of the component.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Inline style of the overlay panel element.\n     * @group Props\n     */\n    @Input() panelStyle: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the component.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Style class of the overlay panel element.\n     * @group Props\n     */\n    @Input() panelStyleClass: string | undefined;\n    /**\n     * Inline style of the input field.\n     * @group Props\n     */\n    @Input() inputStyle: { [klass: string]: any } | null | undefined;\n    /**\n     * Identifier of the focus input to match a label defined for the component.\n     * @group Props\n     */\n    @Input() inputId: string | undefined;\n    /**\n     * Inline style of the input field.\n     * @group Props\n     */\n    @Input() inputStyleClass: string | undefined;\n    /**\n     * Hint text for the input field.\n     * @group Props\n     */\n    @Input() placeholder: string | undefined;\n    /**\n     * When present, it specifies that the input cannot be typed.\n     * @group Props\n     */\n    @Input() readonly: boolean | undefined;\n    /**\n     * When present, it specifies that the component should be disabled.\n     * @group Props\n     */\n    @Input() disabled: boolean | undefined;\n    /**\n     * Maximum height of the suggestions panel.\n     * @group Props\n     */\n    @Input() scrollHeight: string = '200px';\n    /**\n     * Defines if data is loaded and interacted with in lazy manner.\n     * @group Props\n     */\n    @Input() lazy: boolean = false;\n    /**\n     * Whether the data should be loaded on demand during scroll.\n     * @group Props\n     */\n    @Input() virtualScroll: boolean | undefined;\n    /**\n     * Height of an item in the list for VirtualScrolling.\n     * @group Props\n     */\n    @Input() virtualScrollItemSize: number | undefined;\n    /**\n     * Whether to use the scroller feature. The properties of scroller component can be used like an object in it.\n     * @group Props\n     */\n    @Input() virtualScrollOptions: ScrollerOptions | undefined;\n    /**\n     * Maximum number of character allows in the input field.\n     * @group Props\n     */\n    @Input() maxlength: number | undefined;\n    /**\n     * Name of the input element.\n     * @group Props\n     */\n    @Input() name: string | undefined;\n    /**\n     * When present, it specifies that an input field must be filled out before submitting the form.\n     * @group Props\n     */\n    @Input() required: boolean | undefined;\n    /**\n     * Size of the input field.\n     * @group Props\n     */\n    @Input() size: number | undefined;\n    /**\n     * Target element to attach the overlay, valid values are \"body\" or a local ng-template variable of another element (note: use binding with brackets for template variables, e.g. [appendTo]=\"mydiv\" for a div element having #mydiv as variable name).\n     * @group Props\n     */\n    @Input() appendTo: HTMLElement | ElementRef | TemplateRef<any> | string | null | undefined | any;\n    /**\n     * When enabled, highlights the first item in the list by default.\n     * @group Props\n     */\n    @Input() autoHighlight: boolean | undefined;\n    /**\n     * When present, autocomplete clears the manual input if it does not match of the suggestions to force only accepting values from the suggestions.\n     * @group Props\n     */\n    @Input() forceSelection: boolean | undefined;\n    /**\n     * Type of the input, defaults to \"text\".\n     * @group Props\n     */\n    @Input() type: string = 'text';\n    /**\n     * Whether to automatically manage layering.\n     * @group Props\n     */\n    @Input() autoZIndex: boolean = true;\n    /**\n     * Base zIndex value to use in layering.\n     * @group Props\n     */\n    @Input() baseZIndex: number = 0;\n    /**\n     * Defines a string that labels the input for accessibility.\n     * @group Props\n     */\n    @Input() ariaLabel: string | undefined;\n    /**\n     * Defines a string that labels the dropdown button for accessibility.\n     * @group Props\n     */\n    @Input() dropdownAriaLabel: string | undefined;\n    /**\n     * Specifies one or more IDs in the DOM that labels the input field.\n     * @group Props\n     */\n    @Input() ariaLabelledBy: string | undefined;\n    /**\n     * Icon class of the dropdown icon.\n     * @group Props\n     */\n    @Input() dropdownIcon: string | undefined;\n    /**\n     * Ensures uniqueness of selected items on multiple mode.\n     * @group Props\n     */\n    @Input() unique: boolean = true;\n    /**\n     * Whether to display options as grouped when nested options are provided.\n     * @group Props\n     */\n    @Input() group: boolean | undefined;\n    /**\n     * Whether to run a query when input receives focus.\n     * @group Props\n     */\n    @Input() completeOnFocus: boolean = false;\n    /**\n     * When enabled, a clear icon is displayed to clear the value.\n     * @group Props\n     */\n    @Input() showClear: boolean = false;\n    /**\n     * Field of a suggested object to resolve and display.\n     * @group Props\n     * @deprecated use optionLabel property instead\n     */\n    @Input() field: string | undefined;\n    /**\n     * Displays a button next to the input field when enabled.\n     * @group Props\n     */\n    @Input() dropdown: boolean | undefined;\n    /**\n     * Whether to show the empty message or not.\n     * @group Props\n     */\n    @Input() showEmptyMessage: boolean | undefined;\n    /**\n     * Specifies the behavior dropdown button. Default \"blank\" mode sends an empty string and \"current\" mode sends the input value.\n     * @group Props\n     */\n    @Input() dropdownMode: string = 'blank';\n    /**\n     * Specifies if multiple values can be selected.\n     * @group Props\n     */\n    @Input() multiple: boolean | undefined;\n    /**\n     * Index of the element in tabbing order.\n     * @group Props\n     */\n    @Input() tabindex: number | undefined;\n    /**\n     * A property to uniquely identify a value in options.\n     * @group Props\n     */\n    @Input() dataKey: string | undefined;\n    /**\n     * Text to display when there is no data. Defaults to global value in i18n translation configuration.\n     * @group Props\n     */\n    @Input() emptyMessage: string | undefined;\n    /**\n     * Transition options of the show animation.\n     * @group Props\n     */\n    @Input() showTransitionOptions: string = '.12s cubic-bezier(0, 0, 0.2, 1)';\n    /**\n     * Transition options of the hide animation.\n     * @group Props\n     */\n    @Input() hideTransitionOptions: string = '.1s linear';\n    /**\n     * When present, it specifies that the component should automatically get focus on load.\n     * @group Props\n     */\n    @Input() autofocus: boolean | undefined;\n    /**\n     * Used to define a string that autocomplete attribute the current element.\n     * @group Props\n     */\n    @Input() autocomplete: string = 'off';\n    /**\n     * Name of the options field of an option group.\n     * @group Props\n     */\n    @Input() optionGroupChildren: string | undefined = 'items';\n    /**\n     * Name of the label field of an option group.\n     * @group Props\n     */\n    @Input() optionGroupLabel: string | undefined = 'label';\n    /**\n     * Options for the overlay element.\n     * @group Props\n     */\n    @Input() overlayOptions: OverlayOptions | undefined;\n    /**\n     * An array of suggestions to display.\n     * @group Props\n     */\n    @Input() get suggestions(): any[] {\n        return this._suggestions();\n    }\n    set suggestions(value: any[]) {\n        this._suggestions.set(value);\n        this.handleSuggestionsChange();\n    }\n    /**\n     * Element dimensions of option for virtual scrolling.\n     * @group Props\n     * @deprecated use virtualScrollItemSize property instead.\n     */\n    @Input() get itemSize(): number {\n        return this._itemSize as number;\n    }\n    set itemSize(val: number) {\n        this._itemSize = val;\n        console.warn('The itemSize property is deprecated, use virtualScrollItemSize property instead.');\n    }\n    /**\n     * Property name or getter function to use as the label of an option.\n     * @group Props\n     */\n    @Input() optionLabel: string | undefined;\n    /**\n     * Unique identifier of the component.\n     * @group Props\n     */\n    @Input() id: string | undefined;\n    /**\n     * Text to display when the search is active. Defaults to global value in i18n translation configuration.\n     * @group Props\n     * @defaultValue '{0} results are available'\n     */\n    @Input() searchMessage: string | undefined;\n    /**\n     * Text to display when filtering does not return any results. Defaults to global value in i18n translation configuration.\n     * @group Props\n     * @defaultValue 'No selected item'\n     */\n    @Input() emptySelectionMessage: string | undefined;\n    /**\n     * Text to be displayed in hidden accessible field when options are selected. Defaults to global value in i18n translation configuration.\n     * @group Props\n     * @defaultValue '{0} items selected'\n     */\n    @Input() selectionMessage: string | undefined;\n    /**\n     * Whether to focus on the first visible or selected element when the overlay panel is shown.\n     * @group Props\n     */\n    @Input() autoOptionFocus: boolean | undefined = true;\n    /**\n     * When enabled, the focused option is selected.\n     * @group Props\n     */\n    @Input() selectOnFocus: boolean | undefined;\n    /**\n     * Locale to use in searching. The default locale is the host environment's current locale.\n     * @group Props\n     */\n    @Input() searchLocale: boolean | undefined;\n    /**\n     * Property name or getter function to use as the disabled flag of an option, defaults to false when not defined.\n     * @group Props\n     */\n    @Input() optionDisabled: string | undefined;\n    /**\n     * When enabled, the hovered option will be focused.\n     * @group Props\n     */\n    @Input() focusOnHover: boolean | undefined;\n    /**\n     * Callback to invoke to search for suggestions.\n     * @param {AutoCompleteCompleteEvent} event - Custom complete event.\n     * @group Emits\n     */\n    @Output() completeMethod: EventEmitter<AutoCompleteCompleteEvent> = new EventEmitter<AutoCompleteCompleteEvent>();\n    /**\n     * Callback to invoke when a suggestion is selected.\n     * @param {AutoCompleteOnSelectEvent} event - custom select event.\n     * @group Emits\n     */\n    @Output() onSelect: EventEmitter<AutoCompleteOnSelectEvent> = new EventEmitter<AutoCompleteOnSelectEvent>();\n    /**\n     * Callback to invoke when a selected value is removed.\n     * @param {AutoCompleteUnselectEvent} event - custom unselect event.\n     * @group Emits\n     */\n    @Output() onUnselect: EventEmitter<AutoCompleteUnselectEvent> = new EventEmitter<AutoCompleteUnselectEvent>();\n    /**\n     * Callback to invoke when the component receives focus.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onFocus: EventEmitter<Event> = new EventEmitter();\n    /**\n     * Callback to invoke when the component loses focus.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onBlur: EventEmitter<Event> = new EventEmitter();\n    /**\n     * Callback to invoke to when dropdown button is clicked.\n     * @param {AutoCompleteDropdownClickEvent} event - custom dropdown click event.\n     * @group Emits\n     */\n    @Output() onDropdownClick: EventEmitter<AutoCompleteDropdownClickEvent> = new EventEmitter<AutoCompleteDropdownClickEvent>();\n    /**\n     * Callback to invoke when clear button is clicked.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onClear: EventEmitter<Event | undefined> = new EventEmitter<Event | undefined>();\n    /**\n     * Callback to invoke on input key up.\n     * @param {KeyboardEvent} event - Keyboard event.\n     * @group Emits\n     */\n    @Output() onKeyUp: EventEmitter<KeyboardEvent> = new EventEmitter();\n    /**\n     * Callback to invoke on overlay is shown.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onShow: EventEmitter<Event> = new EventEmitter<Event>();\n    /**\n     * Callback to invoke on overlay is hidden.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onHide: EventEmitter<Event> = new EventEmitter<Event>();\n    /**\n     * Callback to invoke on lazy load data.\n     * @param {AutoCompleteLazyLoadEvent} event - Lazy load event.\n     * @group Emits\n     */\n    @Output() onLazyLoad: EventEmitter<AutoCompleteLazyLoadEvent> = new EventEmitter<AutoCompleteLazyLoadEvent>();\n\n    @ViewChild('container') containerEL: Nullable<ElementRef>;\n\n    @ViewChild('focusInput') inputEL: Nullable<ElementRef>;\n\n    @ViewChild('multiIn') multiInputEl: Nullable<ElementRef>;\n\n    @ViewChild('multiContainer') multiContainerEL: Nullable<ElementRef>;\n\n    @ViewChild('ddBtn') dropdownButton: Nullable<ElementRef>;\n\n    @ViewChild('items') itemsViewChild: Nullable<ElementRef>;\n\n    @ViewChild('scroller') scroller: Nullable<Scroller>;\n\n    @ViewChild('overlay') overlayViewChild!: Overlay;\n\n    @ContentChildren(PrimeTemplate) templates: Nullable<QueryList<PrimeTemplate>>;\n\n    _itemSize: Nullable<number>;\n\n    itemsWrapper: Nullable<HTMLDivElement>;\n\n    itemTemplate: Nullable<TemplateRef<any>>;\n\n    emptyTemplate: Nullable<TemplateRef<any>>;\n\n    headerTemplate: Nullable<TemplateRef<any>>;\n\n    footerTemplate: Nullable<TemplateRef<any>>;\n\n    selectedItemTemplate: Nullable<TemplateRef<any>>;\n\n    groupTemplate: Nullable<TemplateRef<any>>;\n\n    loaderTemplate: Nullable<TemplateRef<any>>;\n\n    removeIconTemplate: Nullable<TemplateRef<any>>;\n\n    loadingIconTemplate: Nullable<TemplateRef<any>>;\n\n    clearIconTemplate: Nullable<TemplateRef<any>>;\n\n    dropdownIconTemplate: Nullable<TemplateRef<any>>;\n\n    value: string | any;\n\n    _suggestions = signal<any>(null);\n\n    onModelChange: Function = () => {};\n\n    onModelTouched: Function = () => {};\n\n    timeout: Nullable<any>;\n\n    overlayVisible: boolean | undefined;\n\n    suggestionsUpdated: Nullable<boolean>;\n\n    highlightOption: any;\n\n    highlightOptionChanged: Nullable<boolean>;\n\n    focused: boolean = false;\n\n    filled: number | boolean | undefined;\n\n    loading: Nullable<boolean>;\n\n    scrollHandler: Nullable<ConnectedOverlayScrollHandler>;\n\n    listId: string | undefined;\n\n    searchTimeout: any;\n\n    dirty: boolean = false;\n\n    modelValue = signal<any>(null);\n\n    focusedMultipleOptionIndex = signal<number>(-1);\n\n    focusedOptionIndex = signal<number>(-1);\n\n    visibleOptions = computed(() => {\n        return this.group ? this.flatOptions(this._suggestions()) : this._suggestions() || [];\n    });\n\n    inputValue = computed(() => {\n        const modelValue = this.modelValue();\n        this.filled = ObjectUtils.isNotEmpty(this.modelValue());\n        if (modelValue) {\n            if (typeof modelValue === 'object') {\n                const label = this.getOptionLabel(modelValue);\n\n                return label != null ? label : modelValue;\n            } else {\n                return modelValue;\n            }\n        } else {\n            return '';\n        }\n    });\n\n    get focusedMultipleOptionId() {\n        return this.focusedMultipleOptionIndex() !== -1 ? `${this.id}_multiple_option_${this.focusedMultipleOptionIndex()}` : null;\n    }\n\n    get focusedOptionId() {\n        return this.focusedOptionIndex() !== -1 ? `${this.id}_${this.focusedOptionIndex()}` : null;\n    }\n\n    get containerClass() {\n        return {\n            'p-autocomplete p-component p-inputwrapper': true,\n            'p-disabled': this.disabled,\n            'p-focus': this.focused,\n            'p-autocomplete-dd': this.dropdown,\n            'p-autocomplete-multiple': this.multiple,\n            'p-inputwrapper-filled': this.modelValue() || ObjectUtils.isNotEmpty(this.inputValue),\n            'p-inputwrapper-focus': this.focused,\n            'p-overlay-open': this.overlayVisible\n        };\n    }\n\n    get multiContainerClass() {\n        return 'p-autocomplete-multiple-container p-component p-inputtext';\n    }\n\n    get panelClass() {\n        return {\n            'p-autocomplete-panel p-component': true,\n            'p-input-filled': this.config.inputStyle === 'filled',\n            'p-ripple-disabled': this.config.ripple === false\n        };\n    }\n\n    get inputClass() {\n        return {\n            'p-autocomplete-input p-inputtext p-component': !this.multiple,\n            'p-autocomplete-dd-input': this.dropdown\n        };\n    }\n\n    get searchResultMessageText() {\n        return ObjectUtils.isNotEmpty(this.visibleOptions()) && this.overlayVisible ? this.searchMessageText.replaceAll('{0}', this.visibleOptions().length) : this.emptySearchMessageText;\n    }\n\n    get searchMessageText() {\n        return this.searchMessage || this.config.translation.searchMessage || '';\n    }\n\n    get emptySearchMessageText() {\n        return this.emptyMessage || this.config.translation.emptySearchMessage || '';\n    }\n\n    get selectionMessageText() {\n        return this.selectionMessage || this.config.translation.selectionMessage || '';\n    }\n\n    get emptySelectionMessageText() {\n        return this.emptySelectionMessage || this.config.translation.emptySelectionMessage || '';\n    }\n\n    get selectedMessageText() {\n        return this.hasSelectedOption() ? this.selectionMessageText.replaceAll('{0}', this.multiple ? this.modelValue().length : '1') : this.emptySelectionMessageText;\n    }\n\n    get ariaSetSize() {\n        return this.visibleOptions().filter((option) => !this.isOptionGroup(option)).length;\n    }\n\n    get virtualScrollerDisabled() {\n        return !this.virtualScroll;\n    }\n\n    constructor(@Inject(DOCUMENT) private document: Document, public el: ElementRef, public renderer: Renderer2, public cd: ChangeDetectorRef, public config: PrimeNGConfig, public overlayService: OverlayService, private zone: NgZone) {}\n\n    ngOnInit() {\n        this.id = this.id || UniqueComponentId();\n    }\n\n    ngAfterViewChecked() {\n        //Use timeouts as since Angular 4.2, AfterViewChecked is broken and not called after panel is updated\n        if (this.suggestionsUpdated && this.overlayViewChild) {\n            this.zone.runOutsideAngular(() => {\n                setTimeout(() => {\n                    if (this.overlayViewChild) {\n                        this.overlayViewChild.alignOverlay();\n                    }\n                }, 1);\n                this.suggestionsUpdated = false;\n            });\n        }\n    }\n\n    ngAfterContentInit() {\n        (this.templates as QueryList<PrimeTemplate>).forEach((item) => {\n            switch (item.getType()) {\n                case 'item':\n                    this.itemTemplate = item.template;\n                    break;\n\n                case 'group':\n                    this.groupTemplate = item.template;\n                    break;\n\n                case 'selectedItem':\n                    this.selectedItemTemplate = item.template;\n                    break;\n\n                case 'header':\n                    this.headerTemplate = item.template;\n                    break;\n\n                case 'empty':\n                    this.emptyTemplate = item.template;\n                    break;\n\n                case 'footer':\n                    this.footerTemplate = item.template;\n                    break;\n\n                case 'loader':\n                    this.loaderTemplate = item.template;\n                    break;\n\n                case 'removetokenicon':\n                    this.removeIconTemplate = item.template;\n                    break;\n\n                case 'loadingicon':\n                    this.loadingIconTemplate = item.template;\n                    break;\n\n                case 'clearicon':\n                    this.clearIconTemplate = item.template;\n                    break;\n\n                case 'dropdownicon':\n                    this.dropdownIconTemplate = item.template;\n                    break;\n\n                default:\n                    this.itemTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    handleSuggestionsChange() {\n        if (this.loading) {\n            this._suggestions() ? this.show() : !!this.emptyTemplate ? this.show() : this.hide();\n            const focusedOptionIndex = this.overlayVisible && this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;\n            this.focusedOptionIndex.set(focusedOptionIndex);\n            this.suggestionsUpdated = true;\n            this.loading = false;\n            this.cd.markForCheck();\n        }\n    }\n\n    flatOptions(options) {\n        return (options || []).reduce((result, option, index) => {\n            result.push({ optionGroup: option, group: true, index });\n\n            const optionGroupChildren = this.getOptionGroupChildren(option);\n\n            optionGroupChildren && optionGroupChildren.forEach((o) => result.push(o));\n\n            return result;\n        }, []);\n    }\n\n    isOptionGroup(option) {\n        return this.optionGroupLabel && option.optionGroup && option.group;\n    }\n\n    findFirstOptionIndex() {\n        return this.visibleOptions().findIndex((option) => this.isValidOption(option));\n    }\n\n    findLastOptionIndex() {\n        return ObjectUtils.findLastIndex(this.visibleOptions(), (option) => this.isValidOption(option));\n    }\n\n    findFirstFocusedOptionIndex() {\n        const selectedIndex = this.findSelectedOptionIndex();\n\n        return selectedIndex < 0 ? this.findFirstOptionIndex() : selectedIndex;\n    }\n\n    findLastFocusedOptionIndex() {\n        const selectedIndex = this.findSelectedOptionIndex();\n\n        return selectedIndex < 0 ? this.findLastOptionIndex() : selectedIndex;\n    }\n\n    findSelectedOptionIndex() {\n        return this.hasSelectedOption() ? this.visibleOptions().findIndex((option) => this.isValidSelectedOption(option)) : -1;\n    }\n\n    findNextOptionIndex(index) {\n        const matchedOptionIndex =\n            index < this.visibleOptions().length - 1\n                ? this.visibleOptions()\n                      .slice(index + 1)\n                      .findIndex((option) => this.isValidOption(option))\n                : -1;\n\n        return matchedOptionIndex > -1 ? matchedOptionIndex + index + 1 : index;\n    }\n\n    findPrevOptionIndex(index) {\n        const matchedOptionIndex = index > 0 ? ObjectUtils.findLastIndex(this.visibleOptions().slice(0, index), (option) => this.isValidOption(option)) : -1;\n\n        return matchedOptionIndex > -1 ? matchedOptionIndex : index;\n    }\n\n    isValidSelectedOption(option) {\n        return this.isValidOption(option) && this.isSelected(option);\n    }\n\n    isValidOption(option) {\n        return option && !(this.isOptionDisabled(option) || this.isOptionGroup(option));\n    }\n\n    isOptionDisabled(option) {\n        return this.optionDisabled ? ObjectUtils.resolveFieldData(option, this.optionDisabled) : false;\n    }\n\n    isSelected(option) {\n        return ObjectUtils.equals(this.modelValue(), this.getOptionValue(option), this.equalityKey());\n    }\n\n    isOptionMatched(option, value) {\n        return this.isValidOption(option) && this.getOptionLabel(option).toLocaleLowerCase(this.searchLocale) === value.toLocaleLowerCase(this.searchLocale);\n    }\n\n    isInputClicked(event) {\n        if (this.multiple) return event.target === this.multiContainerEL.nativeElement || this.multiContainerEL.nativeElement.contains(event.target);\n        else return event.target === this.inputEL.nativeElement;\n    }\n    isDropdownClicked(event) {\n        return this.dropdownButton?.nativeElement ? event.target === this.dropdownButton.nativeElement || this.dropdownButton.nativeElement.contains(event.target) : false;\n    }\n    equalityKey() {\n        return this.dataKey; // TODO: The 'optionValue' properties can be added.\n    }\n\n    onContainerClick(event) {\n        if (this.disabled || this.loading || this.isInputClicked(event) || this.isDropdownClicked(event)) {\n            return;\n        }\n\n        if (!this.overlayViewChild || !this.overlayViewChild.overlayViewChild.nativeElement.contains(event.target)) {\n            DomHandler.focus(this.inputEL.nativeElement);\n        }\n    }\n\n    handleDropdownClick(event) {\n        let query = undefined;\n\n        if (this.overlayVisible) {\n            this.hide(true);\n        } else {\n            DomHandler.focus(this.inputEL.nativeElement);\n            query = this.inputEL.nativeElement.value;\n\n            if (this.dropdownMode === 'blank') this.search(event, '', 'dropdown');\n            else if (this.dropdownMode === 'current') this.search(event, query, 'dropdown');\n        }\n\n        this.onDropdownClick.emit({ originalEvent: event, query });\n    }\n\n    onInput(event) {\n        if (this.searchTimeout) {\n            clearTimeout(this.searchTimeout);\n        }\n\n        let query = event.target.value;\n\n        if (!this.multiple) {\n            this.updateModel(query);\n        }\n\n        if (query.length === 0) {\n            this.hide();\n            this.onClear.emit();\n        } else {\n            if (query.length >= this.minLength) {\n                this.focusedOptionIndex.set(-1);\n\n                this.searchTimeout = setTimeout(() => {\n                    this.search(event, query, 'input');\n                }, this.delay);\n            } else {\n                this.hide();\n            }\n        }\n    }\n\n    onInputChange(event) {\n        if (this.forceSelection) {\n            let valid = false;\n\n            if (this.visibleOptions()) {\n                const matchedValue = this.visibleOptions().find((option) => this.isOptionMatched(option, this.inputEL.nativeElement.value || ''));\n\n                if (matchedValue !== undefined) {\n                    valid = true;\n                    !this.isSelected(matchedValue) && this.onOptionSelect(event, matchedValue);\n                }\n            }\n\n            if (!valid) {\n                this.inputEL.nativeElement.value = '';\n                !this.multiple && this.updateModel(null);\n            }\n        }\n    }\n\n    onInputFocus(event) {\n        if (this.disabled) {\n            // For ScreenReaders\n            return;\n        }\n\n        if (!this.dirty && this.completeOnFocus) {\n            this.search(event, event.target.value, 'focus');\n        }\n        this.dirty = true;\n        this.focused = true;\n        const focusedOptionIndex = this.focusedOptionIndex() !== -1 ? this.focusedOptionIndex() : this.overlayVisible && this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;\n        this.focusedOptionIndex.set(focusedOptionIndex);\n        this.overlayVisible && this.scrollInView(this.focusedOptionIndex());\n        this.onFocus.emit(event);\n    }\n\n    onMultipleContainerFocus(event) {\n        if (this.disabled) {\n            // For ScreenReaders\n            return;\n        }\n\n        this.focused = true;\n    }\n\n    onMultipleContainerBlur(event) {\n        this.focusedMultipleOptionIndex.set(-1);\n        this.focused = false;\n    }\n\n    onMultipleContainerKeyDown(event) {\n        if (this.disabled) {\n            event.preventDefault();\n\n            return;\n        }\n\n        switch (event.code) {\n            case 'ArrowLeft':\n                this.onArrowLeftKeyOnMultiple(event);\n                break;\n\n            case 'ArrowRight':\n                this.onArrowRightKeyOnMultiple(event);\n                break;\n\n            case 'Backspace':\n                this.onBackspaceKeyOnMultiple(event);\n                break;\n\n            default:\n                break;\n        }\n    }\n\n    onInputBlur(event) {\n        this.dirty = false;\n        this.focused = false;\n        this.focusedOptionIndex.set(-1);\n        this.onModelTouched();\n        this.onBlur.emit(event);\n    }\n\n    onInputPaste(event) {\n        this.onKeyDown(event);\n    }\n\n    onInputKeyUp(event) {\n        this.onKeyUp.emit(event);\n    }\n\n    onKeyDown(event) {\n        if (this.disabled) {\n            event.preventDefault();\n\n            return;\n        }\n\n        switch (event.code) {\n            case 'ArrowDown':\n                this.onArrowDownKey(event);\n                break;\n\n            case 'ArrowUp':\n                this.onArrowUpKey(event);\n                break;\n\n            case 'ArrowLeft':\n                this.onArrowLeftKey(event);\n                break;\n\n            case 'ArrowRight':\n                this.onArrowRightKey(event);\n                break;\n\n            case 'Home':\n                this.onHomeKey(event);\n                break;\n\n            case 'End':\n                this.onEndKey(event);\n                break;\n\n            case 'PageDown':\n                this.onPageDownKey(event);\n                break;\n\n            case 'PageUp':\n                this.onPageUpKey(event);\n                break;\n\n            case 'Enter':\n            case 'NumpadEnter':\n                this.onEnterKey(event);\n                break;\n\n            case 'Escape':\n                this.onEscapeKey(event);\n                break;\n\n            case 'Tab':\n                this.onTabKey(event);\n                break;\n\n            case 'Backspace':\n                this.onBackspaceKey(event);\n                break;\n\n            case 'ShiftLeft':\n            case 'ShiftRight':\n                //NOOP\n                break;\n\n            default:\n                break;\n        }\n    }\n\n    onArrowDownKey(event) {\n        if (!this.overlayVisible) {\n            return;\n        }\n\n        const optionIndex = this.focusedOptionIndex() !== -1 ? this.findNextOptionIndex(this.focusedOptionIndex()) : this.findFirstFocusedOptionIndex();\n\n        this.changeFocusedOptionIndex(event, optionIndex);\n\n        event.preventDefault();\n    }\n\n    onArrowUpKey(event) {\n        if (!this.overlayVisible) {\n            return;\n        }\n\n        if (event.altKey) {\n            if (this.focusedOptionIndex() !== -1) {\n                this.onOptionSelect(event, this.visibleOptions()[this.focusedOptionIndex()]);\n            }\n\n            this.overlayVisible && this.hide();\n            event.preventDefault();\n        } else {\n            const optionIndex = this.focusedOptionIndex() !== -1 ? this.findPrevOptionIndex(this.focusedOptionIndex()) : this.findLastFocusedOptionIndex();\n\n            this.changeFocusedOptionIndex(event, optionIndex);\n\n            event.preventDefault();\n        }\n    }\n\n    onArrowLeftKey(event) {\n        const target = event.currentTarget;\n        this.focusedOptionIndex.set(-1);\n        if (this.multiple) {\n            if (ObjectUtils.isEmpty(target.value) && this.hasSelectedOption()) {\n                DomHandler.focus(this.multiContainerEL.nativeElement);\n                this.focusedMultipleOptionIndex.set(this.modelValue().length);\n            } else {\n                event.stopPropagation(); // To prevent onArrowLeftKeyOnMultiple method\n            }\n        }\n    }\n\n    onArrowRightKey(event) {\n        this.focusedOptionIndex.set(-1);\n\n        this.multiple && event.stopPropagation(); // To prevent onArrowRightKeyOnMultiple method\n    }\n\n    onHomeKey(event) {\n        const { currentTarget } = event;\n        const len = currentTarget.value.length;\n\n        currentTarget.setSelectionRange(0, event.shiftKey ? len : 0);\n        this.focusedOptionIndex.set(-1);\n\n        event.preventDefault();\n    }\n\n    onEndKey(event) {\n        const { currentTarget } = event;\n        const len = currentTarget.value.length;\n\n        currentTarget.setSelectionRange(event.shiftKey ? 0 : len, len);\n        this.focusedOptionIndex.set(-1);\n\n        event.preventDefault();\n    }\n\n    onPageDownKey(event) {\n        this.scrollInView(this.visibleOptions().length - 1);\n        event.preventDefault();\n    }\n\n    onPageUpKey(event) {\n        this.scrollInView(0);\n        event.preventDefault();\n    }\n\n    onEnterKey(event) {\n        if (!this.overlayVisible) {\n            this.onArrowDownKey(event);\n        } else {\n            if (this.focusedOptionIndex() !== -1) {\n                this.onOptionSelect(event, this.visibleOptions()[this.focusedOptionIndex()]);\n            }\n\n            this.hide();\n        }\n\n        event.preventDefault();\n    }\n\n    onEscapeKey(event) {\n        this.overlayVisible && this.hide(true);\n        event.preventDefault();\n    }\n\n    onTabKey(event) {\n        if (this.focusedOptionIndex() !== -1) {\n            this.onOptionSelect(event, this.visibleOptions()[this.focusedOptionIndex()]);\n        }\n\n        this.overlayVisible && this.hide();\n    }\n\n    onBackspaceKey(event) {\n        if (this.multiple) {\n            if (ObjectUtils.isNotEmpty(this.modelValue()) && !this.inputEL.nativeElement.value) {\n                const removedValue = this.modelValue()[this.modelValue().length - 1];\n                const newValue = this.modelValue().slice(0, -1);\n                this.updateModel(newValue);\n                this.onUnselect.emit({ originalEvent: event, value: removedValue });\n            }\n\n            event.stopPropagation(); // To prevent onBackspaceKeyOnMultiple method\n        }\n    }\n\n    onArrowLeftKeyOnMultiple(event) {\n        const optionIndex = this.focusedMultipleOptionIndex() < 1 ? 0 : this.focusedMultipleOptionIndex() - 1;\n        this.focusedMultipleOptionIndex.set(optionIndex);\n    }\n\n    onArrowRightKeyOnMultiple(event) {\n        let optionIndex = this.focusedMultipleOptionIndex();\n        optionIndex++;\n\n        this.focusedMultipleOptionIndex.set(optionIndex);\n        if (optionIndex > this.modelValue().length - 1) {\n            this.focusedMultipleOptionIndex.set(-1);\n            DomHandler.focus(this.inputEL.nativeElement);\n        }\n    }\n\n    onBackspaceKeyOnMultiple(event) {\n        if (this.focusedMultipleOptionIndex() !== -1) {\n            this.removeOption(event, this.focusedMultipleOptionIndex());\n        }\n    }\n\n    onOptionSelect(event, option, isHide = true) {\n        const value = this.getOptionValue(option);\n\n        if (this.multiple) {\n            this.inputEL.nativeElement.value = '';\n\n            if (!this.isSelected(option)) {\n                this.updateModel([...(this.modelValue() || []), value]);\n            }\n        } else {\n            this.updateModel(value);\n        }\n\n        this.onSelect.emit({ originalEvent: event, value: option });\n\n        isHide && this.hide(true);\n    }\n\n    onOptionMouseEnter(event, index) {\n        if (this.focusOnHover) {\n            this.changeFocusedOptionIndex(event, index);\n        }\n    }\n\n    search(event, query, source) {\n        //allow empty string but not undefined or null\n        if (query === undefined || query === null) {\n            return;\n        }\n\n        //do not search blank values on input change\n        if (source === 'input' && query.trim().length === 0) {\n            return;\n        }\n        this.loading = true;\n        this.completeMethod.emit({ originalEvent: event, query });\n    }\n\n    removeOption(event, index) {\n        const removedOption = this.modelValue()[index];\n        const value = this.modelValue()\n            .filter((_, i) => i !== index)\n            .map((option) => this.getOptionValue(option));\n\n        this.updateModel(value);\n        this.onUnselect.emit({ originalEvent: event, value: removedOption });\n        DomHandler.focus(this.inputEL.nativeElement);\n    }\n\n    updateModel(value) {\n        this.value = value;\n        this.modelValue.set(value);\n        this.onModelChange(value);\n        this.updateInputValue();\n        this.cd.markForCheck();\n    }\n\n    updateInputValue() {\n        if (this.value && this.inputEL && this.inputEL.nativeElement) {\n            if (!this.multiple) {\n                this.inputEL.nativeElement.value = this.inputValue();\n            } else {\n                this.inputEL.nativeElement.value = '';\n            }\n        }\n    }\n\n    autoUpdateModel() {\n        if ((this.selectOnFocus || this.autoHighlight) && this.autoOptionFocus && !this.hasSelectedOption()) {\n            const focusedOptionIndex = this.findFirstFocusedOptionIndex();\n            this.focusedOptionIndex.set(focusedOptionIndex);\n            this.onOptionSelect(null, this.visibleOptions()[this.focusedOptionIndex()], false);\n        }\n    }\n\n    scrollInView(index = -1) {\n        const id = index !== -1 ? `${this.id}_${index}` : this.focusedOptionId;\n        if (this.itemsViewChild && this.itemsViewChild.nativeElement) {\n            const element = DomHandler.findSingle(this.itemsViewChild.nativeElement, `li[id=\"${id}\"]`);\n            if (element) {\n                element.scrollIntoView && element.scrollIntoView({ block: 'nearest', inline: 'nearest' });\n            } else if (!this.virtualScrollerDisabled) {\n                setTimeout(() => {\n                    this.virtualScroll && this.scroller?.scrollToIndex(index !== -1 ? index : this.focusedOptionIndex());\n                }, 0);\n            }\n        }\n    }\n\n    changeFocusedOptionIndex(event, index) {\n        if (this.focusedOptionIndex() !== index) {\n            this.focusedOptionIndex.set(index);\n            this.scrollInView();\n\n            if (this.selectOnFocus || this.autoHighlight) {\n                this.onOptionSelect(event, this.visibleOptions()[index], false);\n            }\n        }\n    }\n\n    show(isFocus = false) {\n        this.dirty = true;\n        this.overlayVisible = true;\n        const focusedOptionIndex = this.focusedOptionIndex() !== -1 ? this.focusedOptionIndex() : this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;\n        this.focusedOptionIndex.set(focusedOptionIndex);\n        isFocus && DomHandler.focus(this.inputEL.nativeElement);\n        if (isFocus) {\n            DomHandler.focus(this.inputEL.nativeElement);\n        }\n        this.onShow.emit();\n        this.cd.markForCheck();\n    }\n\n    hide(isFocus = false) {\n        const _hide = () => {\n            this.dirty = isFocus;\n            this.overlayVisible = false;\n            this.focusedOptionIndex.set(-1);\n            isFocus && DomHandler.focus(this.inputEL.nativeElement);\n            this.onHide.emit();\n            this.cd.markForCheck();\n        };\n\n        setTimeout(() => {\n            _hide();\n        }, 0); // For ScreenReaders\n    }\n\n    clear() {\n        this.updateModel(null);\n        this.inputEL.nativeElement.value = '';\n        this.onClear.emit();\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n        this.filled = this.value && this.value.length ? true : false;\n        this.updateModel(value);\n        this.cd.markForCheck();\n    }\n\n    hasSelectedOption() {\n        return ObjectUtils.isNotEmpty(this.modelValue());\n    }\n\n    getAriaPosInset(index) {\n        return (\n            (this.optionGroupLabel\n                ? index -\n                  this.visibleOptions()\n                      .slice(0, index)\n                      .filter((option) => this.isOptionGroup(option)).length\n                : index) + 1\n        );\n    }\n\n    getOptionLabel(option: any) {\n        return this.field || this.optionLabel ? ObjectUtils.resolveFieldData(option, this.field || this.optionLabel) : option && option.label != undefined ? option.label : option;\n    }\n\n    getOptionValue(option) {\n        return option; // TODO: The 'optionValue' properties can be added.\n    }\n\n    getOptionIndex(index, scrollerOptions) {\n        return this.virtualScrollerDisabled ? index : scrollerOptions && scrollerOptions.getItemOptions(index)['index'];\n    }\n\n    getOptionGroupLabel(optionGroup: any) {\n        return this.optionGroupLabel ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupLabel) : optionGroup && optionGroup.label != undefined ? optionGroup.label : optionGroup;\n    }\n\n    getOptionGroupChildren(optionGroup: any) {\n        return this.optionGroupChildren ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupChildren) : optionGroup.items;\n    }\n\n    registerOnChange(fn: Function): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: Function): void {\n        this.onModelTouched = fn;\n    }\n\n    setDisabledState(val: boolean): void {\n        this.disabled = val;\n        this.cd.markForCheck();\n    }\n\n    onOverlayAnimationStart(event: AnimationEvent) {\n        if (event.toState === 'visible') {\n            this.itemsWrapper = DomHandler.findSingle(this.overlayViewChild.overlayViewChild?.nativeElement, this.virtualScroll ? '.p-scroller' : '.p-autocomplete-panel');\n            this.virtualScroll && this.scroller?.setContentEl(this.itemsViewChild?.nativeElement);\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.scrollHandler) {\n            this.scrollHandler.destroy();\n            this.scrollHandler = null;\n        }\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, OverlayModule, InputTextModule, ButtonModule, SharedModule, RippleModule, ScrollerModule, AutoFocusModule, TimesCircleIcon, SpinnerIcon, TimesIcon, ChevronDownIcon],\n    exports: [AutoComplete, OverlayModule, SharedModule, ScrollerModule, AutoFocusModule],\n    declarations: [AutoComplete]\n})\nexport class AutoCompleteModule {}\n"]}
|