primeng 16.6.0 → 16.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (179) hide show
  1. package/animate/animate.d.ts +3 -2
  2. package/animateonscroll/animateonscroll.d.ts +73 -0
  3. package/animateonscroll/index.d.ts +5 -0
  4. package/animateonscroll/public_api.d.ts +1 -0
  5. package/api/primengconfig.d.ts +1 -0
  6. package/autocomplete/autocomplete.d.ts +177 -54
  7. package/autocomplete/autocomplete.interface.d.ts +30 -0
  8. package/cascadeselect/cascadeselect.d.ts +188 -68
  9. package/cascadeselect/cascadeselect.interface.d.ts +19 -0
  10. package/checkbox/checkbox.d.ts +1 -4
  11. package/chips/chips.d.ts +21 -5
  12. package/colorpicker/colorpicker.d.ts +5 -5
  13. package/contextmenu/contextmenu.d.ts +1 -0
  14. package/dialog/dialog.d.ts +1 -2
  15. package/dom/domhandler.d.ts +4 -1
  16. package/dropdown/dropdown.d.ts +115 -37
  17. package/esm2022/accordion/accordion.mjs +11 -7
  18. package/esm2022/animate/animate.mjs +4 -1
  19. package/esm2022/animateonscroll/animateonscroll.mjs +185 -0
  20. package/esm2022/animateonscroll/primeng-animateonscroll.mjs +5 -0
  21. package/esm2022/animateonscroll/public_api.mjs +2 -0
  22. package/esm2022/api/primengconfig.mjs +2 -1
  23. package/esm2022/autocomplete/autocomplete.interface.mjs +1 -1
  24. package/esm2022/autocomplete/autocomplete.mjs +893 -617
  25. package/esm2022/carousel/carousel.mjs +5 -1
  26. package/esm2022/cascadeselect/cascadeselect.interface.mjs +1 -1
  27. package/esm2022/cascadeselect/cascadeselect.mjs +921 -482
  28. package/esm2022/checkbox/checkbox.mjs +90 -73
  29. package/esm2022/chips/chips.mjs +197 -53
  30. package/esm2022/colorpicker/colorpicker.mjs +56 -37
  31. package/esm2022/contextmenu/contextmenu.mjs +10 -1
  32. package/esm2022/dialog/dialog.mjs +6 -11
  33. package/esm2022/dom/domhandler.mjs +26 -8
  34. package/esm2022/dropdown/dropdown.mjs +711 -587
  35. package/esm2022/inputmask/inputmask.mjs +22 -9
  36. package/esm2022/inputnumber/inputnumber.mjs +142 -83
  37. package/esm2022/inputswitch/inputswitch.mjs +55 -49
  38. package/esm2022/knob/knob.mjs +92 -5
  39. package/esm2022/listbox/listbox.interface.mjs +1 -1
  40. package/esm2022/listbox/listbox.mjs +998 -455
  41. package/esm2022/multiselect/multiselect.mjs +1024 -604
  42. package/esm2022/overlaypanel/overlaypanel.mjs +2 -2
  43. package/esm2022/paginator/paginator.mjs +2 -2
  44. package/esm2022/password/password.mjs +29 -28
  45. package/esm2022/radiobutton/radiobutton.mjs +46 -33
  46. package/esm2022/rating/rating.mjs +172 -80
  47. package/esm2022/selectbutton/selectbutton.mjs +105 -33
  48. package/esm2022/slider/slider.mjs +151 -66
  49. package/esm2022/table/table.mjs +3 -3
  50. package/esm2022/togglebutton/togglebutton.mjs +47 -10
  51. package/esm2022/treetable/treetable.mjs +21 -25
  52. package/esm2022/tristatecheckbox/tristatecheckbox.mjs +53 -35
  53. package/fesm2022/primeng-accordion.mjs +10 -6
  54. package/fesm2022/primeng-accordion.mjs.map +1 -1
  55. package/fesm2022/primeng-animate.mjs +3 -0
  56. package/fesm2022/primeng-animate.mjs.map +1 -1
  57. package/fesm2022/primeng-animateonscroll.mjs +190 -0
  58. package/fesm2022/primeng-animateonscroll.mjs.map +1 -0
  59. package/fesm2022/primeng-api.mjs +1 -0
  60. package/fesm2022/primeng-api.mjs.map +1 -1
  61. package/fesm2022/primeng-autocomplete.mjs +893 -617
  62. package/fesm2022/primeng-autocomplete.mjs.map +1 -1
  63. package/fesm2022/primeng-carousel.mjs +4 -0
  64. package/fesm2022/primeng-carousel.mjs.map +1 -1
  65. package/fesm2022/primeng-cascadeselect.mjs +920 -481
  66. package/fesm2022/primeng-cascadeselect.mjs.map +1 -1
  67. package/fesm2022/primeng-checkbox.mjs +89 -72
  68. package/fesm2022/primeng-checkbox.mjs.map +1 -1
  69. package/fesm2022/primeng-chips.mjs +195 -51
  70. package/fesm2022/primeng-chips.mjs.map +1 -1
  71. package/fesm2022/primeng-colorpicker.mjs +55 -36
  72. package/fesm2022/primeng-colorpicker.mjs.map +1 -1
  73. package/fesm2022/primeng-contextmenu.mjs +9 -0
  74. package/fesm2022/primeng-contextmenu.mjs.map +1 -1
  75. package/fesm2022/primeng-dialog.mjs +5 -10
  76. package/fesm2022/primeng-dialog.mjs.map +1 -1
  77. package/fesm2022/primeng-dom.mjs +25 -7
  78. package/fesm2022/primeng-dom.mjs.map +1 -1
  79. package/fesm2022/primeng-dropdown.mjs +710 -586
  80. package/fesm2022/primeng-dropdown.mjs.map +1 -1
  81. package/fesm2022/primeng-inputmask.mjs +20 -7
  82. package/fesm2022/primeng-inputmask.mjs.map +1 -1
  83. package/fesm2022/primeng-inputnumber.mjs +140 -81
  84. package/fesm2022/primeng-inputnumber.mjs.map +1 -1
  85. package/fesm2022/primeng-inputswitch.mjs +55 -49
  86. package/fesm2022/primeng-inputswitch.mjs.map +1 -1
  87. package/fesm2022/primeng-knob.mjs +92 -5
  88. package/fesm2022/primeng-knob.mjs.map +1 -1
  89. package/fesm2022/primeng-listbox.mjs +997 -454
  90. package/fesm2022/primeng-listbox.mjs.map +1 -1
  91. package/fesm2022/primeng-multiselect.mjs +1023 -603
  92. package/fesm2022/primeng-multiselect.mjs.map +1 -1
  93. package/fesm2022/primeng-overlaypanel.mjs +1 -1
  94. package/fesm2022/primeng-overlaypanel.mjs.map +1 -1
  95. package/fesm2022/primeng-paginator.mjs +1 -1
  96. package/fesm2022/primeng-paginator.mjs.map +1 -1
  97. package/fesm2022/primeng-password.mjs +27 -26
  98. package/fesm2022/primeng-password.mjs.map +1 -1
  99. package/fesm2022/primeng-radiobutton.mjs +46 -33
  100. package/fesm2022/primeng-radiobutton.mjs.map +1 -1
  101. package/fesm2022/primeng-rating.mjs +171 -79
  102. package/fesm2022/primeng-rating.mjs.map +1 -1
  103. package/fesm2022/primeng-selectbutton.mjs +104 -32
  104. package/fesm2022/primeng-selectbutton.mjs.map +1 -1
  105. package/fesm2022/primeng-slider.mjs +150 -65
  106. package/fesm2022/primeng-slider.mjs.map +1 -1
  107. package/fesm2022/primeng-table.mjs +2 -2
  108. package/fesm2022/primeng-table.mjs.map +1 -1
  109. package/fesm2022/primeng-togglebutton.mjs +46 -9
  110. package/fesm2022/primeng-togglebutton.mjs.map +1 -1
  111. package/fesm2022/primeng-treetable.mjs +23 -27
  112. package/fesm2022/primeng-treetable.mjs.map +1 -1
  113. package/fesm2022/primeng-tristatecheckbox.mjs +53 -35
  114. package/fesm2022/primeng-tristatecheckbox.mjs.map +1 -1
  115. package/inputmask/inputmask.d.ts +6 -1
  116. package/inputnumber/inputnumber.d.ts +6 -1
  117. package/inputswitch/inputswitch.d.ts +6 -9
  118. package/knob/knob.d.ts +20 -3
  119. package/listbox/listbox.d.ts +208 -39
  120. package/listbox/listbox.interface.d.ts +16 -1
  121. package/multiselect/multiselect.d.ts +171 -60
  122. package/package.json +138 -132
  123. package/password/password.d.ts +3 -4
  124. package/radiobutton/radiobutton.d.ts +1 -2
  125. package/rating/rating.d.ts +29 -7
  126. package/resources/components/dropdown/dropdown.css +16 -2
  127. package/resources/themes/arya-blue/theme.css +106 -84
  128. package/resources/themes/arya-green/theme.css +106 -84
  129. package/resources/themes/arya-orange/theme.css +106 -84
  130. package/resources/themes/arya-purple/theme.css +106 -84
  131. package/resources/themes/bootstrap4-dark-blue/theme.css +110 -88
  132. package/resources/themes/bootstrap4-dark-purple/theme.css +110 -88
  133. package/resources/themes/bootstrap4-light-blue/theme.css +110 -88
  134. package/resources/themes/bootstrap4-light-purple/theme.css +110 -88
  135. package/resources/themes/fluent-light/theme.css +103 -81
  136. package/resources/themes/lara-dark-blue/theme.css +106 -84
  137. package/resources/themes/lara-dark-indigo/theme.css +106 -84
  138. package/resources/themes/lara-dark-purple/theme.css +106 -84
  139. package/resources/themes/lara-dark-teal/theme.css +106 -84
  140. package/resources/themes/lara-light-blue/theme.css +109 -87
  141. package/resources/themes/lara-light-indigo/theme.css +109 -87
  142. package/resources/themes/lara-light-purple/theme.css +109 -87
  143. package/resources/themes/lara-light-teal/theme.css +109 -87
  144. package/resources/themes/luna-amber/theme.css +110 -88
  145. package/resources/themes/luna-blue/theme.css +110 -88
  146. package/resources/themes/luna-green/theme.css +110 -88
  147. package/resources/themes/luna-pink/theme.css +110 -88
  148. package/resources/themes/md-dark-deeppurple/theme.css +117 -95
  149. package/resources/themes/md-dark-indigo/theme.css +117 -95
  150. package/resources/themes/md-light-deeppurple/theme.css +117 -95
  151. package/resources/themes/md-light-indigo/theme.css +117 -95
  152. package/resources/themes/mdc-dark-deeppurple/theme.css +117 -95
  153. package/resources/themes/mdc-dark-indigo/theme.css +117 -95
  154. package/resources/themes/mdc-light-deeppurple/theme.css +117 -95
  155. package/resources/themes/mdc-light-indigo/theme.css +117 -95
  156. package/resources/themes/mira/theme.css +107 -85
  157. package/resources/themes/nano/theme.css +109 -87
  158. package/resources/themes/nova/theme.css +110 -88
  159. package/resources/themes/nova-accent/theme.css +109 -87
  160. package/resources/themes/nova-alt/theme.css +110 -88
  161. package/resources/themes/rhea/theme.css +109 -87
  162. package/resources/themes/saga-blue/theme.css +106 -84
  163. package/resources/themes/saga-green/theme.css +106 -84
  164. package/resources/themes/saga-orange/theme.css +106 -84
  165. package/resources/themes/saga-purple/theme.css +106 -84
  166. package/resources/themes/soho-dark/theme.css +109 -87
  167. package/resources/themes/soho-light/theme.css +109 -87
  168. package/resources/themes/tailwind-light/theme.css +110 -88
  169. package/resources/themes/vela-blue/theme.css +106 -84
  170. package/resources/themes/vela-green/theme.css +106 -84
  171. package/resources/themes/vela-orange/theme.css +106 -84
  172. package/resources/themes/vela-purple/theme.css +106 -84
  173. package/resources/themes/viva-dark/theme.css +109 -87
  174. package/resources/themes/viva-light/theme.css +109 -87
  175. package/selectbutton/selectbutton.d.ts +15 -3
  176. package/slider/slider.d.ts +12 -6
  177. package/togglebutton/togglebutton.d.ts +7 -1
  178. package/treetable/treetable.d.ts +3 -4
  179. 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, TranslationKeys } from 'primeng/api';
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
- /* @deprecated */
169
- _autoZIndex;
170
- get autoZIndex() {
171
- return this._autoZIndex;
172
- }
173
- set autoZIndex(val) {
174
- this._autoZIndex = val;
175
- console.warn('The autoZIndex property is deprecated since v14.2.0, use overlayOptions property instead.');
176
- }
177
- /* @deprecated */
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 = value;
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 {*} value - selected value.
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 {*} value - removed value.
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 = false;
462
+ overlayVisible;
418
463
  suggestionsUpdated;
419
464
  highlightOption;
420
465
  highlightOptionChanged;
421
- focus = false;
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
- itemClicked;
434
- inputValue = null;
435
- isSearching = false;
436
- constructor(document, el, renderer, cd, differs, config, overlayService, zone) {
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
- this.differ = differs.find([]).create(undefined);
446
- this.listId = UniqueComponentId() + '_list';
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
- writeValue(value) {
542
- this.value = value;
543
- this.filled = this.value && this.value.length ? true : false;
544
- this.updateInputField();
545
- this.cd.markForCheck();
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
- getOptionGroupChildren(optionGroup) {
548
- return this.optionGroupChildren ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupChildren) : optionGroup.items;
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
- getOptionGroupLabel(optionGroup) {
551
- return this.optionGroupLabel ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupLabel) : optionGroup.label != undefined ? optionGroup.label : optionGroup;
638
+ isOptionGroup(option) {
639
+ return this.optionGroupLabel && option.optionGroup && option.group;
552
640
  }
553
- registerOnChange(fn) {
554
- this.onModelChange = fn;
641
+ findFirstOptionIndex() {
642
+ return this.visibleOptions().findIndex((option) => this.isValidOption(option));
555
643
  }
556
- registerOnTouched(fn) {
557
- this.onModelTouched = fn;
644
+ findLastOptionIndex() {
645
+ return ObjectUtils.findLastIndex(this.visibleOptions(), (option) => this.isValidOption(option));
558
646
  }
559
- setDisabledState(val) {
560
- this.disabled = val;
561
- this.cd.markForCheck();
647
+ findFirstFocusedOptionIndex() {
648
+ const selectedIndex = this.findSelectedOptionIndex();
649
+ return selectedIndex < 0 ? this.findFirstOptionIndex() : selectedIndex;
562
650
  }
563
- onInput(event) {
564
- // When an input element with a placeholder is clicked, the onInput event is invoked in IE.
565
- if (!this.inputKeyDown && DomHandler.isIE()) {
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.timeout) {
569
- clearTimeout(this.timeout);
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
- let value = event.target.value;
572
- this.inputValue = value;
573
- if (!this.multiple && !this.forceSelection) {
574
- this.onModelChange(value);
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
- if (value.length === 0 && !this.multiple) {
577
- this.value = null;
578
- this.hide();
579
- this.onClear.emit(event);
580
- this.onModelChange(value);
718
+ this.onDropdownClick.emit({ originalEvent: event, query });
719
+ }
720
+ onInput(event) {
721
+ if (this.searchTimeout) {
722
+ clearTimeout(this.searchTimeout);
581
723
  }
582
- if (value.length >= this.minLength) {
583
- this.timeout = setTimeout(() => {
584
- this.search(event, value);
585
- }, this.delay);
724
+ let query = event.target.value;
725
+ if (!this.multiple) {
726
+ this.updateModel(query);
586
727
  }
587
- else {
728
+ if (query.length === 0) {
588
729
  this.hide();
730
+ this.onClear.emit();
589
731
  }
590
- this.updateFilledState();
591
- this.inputKeyDown = false;
592
- }
593
- onInputClick(event) {
594
- this.inputClick = true;
595
- }
596
- search(event, query) {
597
- if (!this.isSearching) {
598
- this.isSearching = true;
599
- this.loading = true;
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
- selectItem(option, focus = true) {
610
- if (this.forceSelectionUpdateModelTimeout) {
611
- clearTimeout(this.forceSelectionUpdateModelTimeout);
612
- this.forceSelectionUpdateModelTimeout = null;
613
- }
614
- if (this.multiple) {
615
- this.multiInputEl.nativeElement.value = '';
616
- this.value = this.value || [];
617
- if (!this.isSelected(option) || !this.unique) {
618
- this.value = [...this.value, option];
619
- this.onModelChange(this.value);
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
- else {
623
- this.inputEL.nativeElement.value = this.resolveFieldData(option);
624
- this.value = option;
625
- this.onModelChange(this.value);
759
+ }
760
+ onInputFocus(event) {
761
+ if (this.disabled) {
762
+ // For ScreenReaders
763
+ return;
626
764
  }
627
- this.onSelect.emit(option);
628
- this.updateFilledState();
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.hide();
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
- show(event) {
636
- if (this.multiInputEl || this.inputEL) {
637
- let hasFocus = this.multiple ? this.multiInputEl?.nativeElement.ownerDocument.activeElement == this.multiInputEl?.nativeElement : this.inputEL?.nativeElement.ownerDocument.activeElement == this.inputEL?.nativeElement;
638
- if (!this.overlayVisible && hasFocus) {
639
- this.overlayVisible = true;
640
- }
775
+ onMultipleContainerFocus(event) {
776
+ if (this.disabled) {
777
+ // For ScreenReaders
778
+ return;
641
779
  }
642
- this.onShow.emit(event);
643
- this.cd.markForCheck();
780
+ this.focused = true;
644
781
  }
645
- clear() {
646
- this.value = null;
647
- this.inputValue = null;
648
- if (this.multiple) {
649
- this.multiInputEl.nativeElement.value = '';
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
- else {
652
- this.inputValue = null;
653
- this.inputEL.nativeElement.value = '';
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
- onOverlayAnimationStart(event) {
660
- if (event.toState === 'visible') {
661
- this.itemsWrapper = DomHandler.findSingle(this.overlayViewChild.overlayViewChild?.nativeElement, this.virtualScroll ? '.p-scroller' : '.p-autocomplete-panel');
662
- this.virtualScroll && this.scroller?.setContentEl(this.itemsViewChild?.nativeElement);
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
- resolveFieldData(value) {
666
- let data = this.field ? ObjectUtils.resolveFieldData(value, this.field) : value;
667
- return data !== (null || undefined) ? data : '';
812
+ onInputPaste(event) {
813
+ this.onKeyDown(event);
668
814
  }
669
- hide(event) {
670
- this.overlayVisible = false;
671
- this.onHide.emit(event);
672
- this.cd.markForCheck();
815
+ onInputKeyUp(event) {
816
+ this.onKeyUp.emit(event);
673
817
  }
674
- handleDropdownClick(event) {
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
- this.focusInput();
677
- let queryValue = this.multiple ? this.multiInputEl.nativeElement.value : this.inputEL.nativeElement.value;
678
- if (this.dropdownMode === 'blank') {
679
- this.onDropdownClick.emit({
680
- originalEvent: event,
681
- query: ''
682
- });
683
- this.search(event, '');
684
- }
685
- else if (this.dropdownMode === 'current') {
686
- this.onDropdownClick.emit({
687
- originalEvent: event,
688
- query: queryValue
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.hide(event);
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
- focusInput() {
698
- if (this.multiple)
699
- this.multiInputEl.nativeElement.focus();
700
- else
701
- this.inputEL?.nativeElement.focus();
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
- get emptyMessageLabel() {
704
- return this.emptyMessage || this.config.getTranslation(TranslationKeys.EMPTY_MESSAGE);
907
+ onArrowRightKey(event) {
908
+ this.focusedOptionIndex.set(-1);
909
+ this.multiple && event.stopPropagation(); // To prevent onArrowRightKeyOnMultiple method
705
910
  }
706
- removeItem(item) {
707
- let itemIndex = DomHandler.index(item);
708
- let removedValue = this.value[itemIndex];
709
- this.value = this.value.filter((val, i) => i != itemIndex);
710
- this.onModelChange(this.value);
711
- this.updateFilledState();
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
- onKeydown(event) {
715
- if (this.overlayVisible) {
716
- switch (event.which) {
717
- //down
718
- case 40:
719
- if (this.group) {
720
- let highlightItemIndex = this.findOptionGroupIndex(this.highlightOption, this.suggestions);
721
- if (highlightItemIndex !== -1) {
722
- let nextItemIndex = highlightItemIndex.itemIndex + 1;
723
- if (nextItemIndex < this.getOptionGroupChildren(this.suggestions[highlightItemIndex.groupIndex]).length) {
724
- this.highlightOption = this.getOptionGroupChildren(this.suggestions[highlightItemIndex.groupIndex])[nextItemIndex];
725
- this.highlightOptionChanged = true;
726
- }
727
- else if (this.suggestions[highlightItemIndex.groupIndex + 1]) {
728
- this.highlightOption = this.getOptionGroupChildren(this.suggestions[highlightItemIndex.groupIndex + 1])[0];
729
- this.highlightOptionChanged = true;
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 (event.which === 40 && this.suggestions) {
804
- this.search(event, event.target.value);
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
- else if (event.ctrlKey && event.key === 'z' && this.multiple) {
812
- this.value.pop();
813
- this.onModelChange(this.value);
814
- this.updateFilledState();
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
- switch (event.which) {
819
- //backspace
820
- case 8:
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
- this.inputKeyDown = true;
992
+ else {
993
+ this.updateModel(value);
994
+ }
995
+ this.onSelect.emit({ originalEvent: event, value: option });
996
+ isHide && this.hide(true);
832
997
  }
833
- onKeyup(event) {
834
- this.onKeyUp.emit(event);
998
+ onOptionMouseEnter(event, index) {
999
+ if (this.focusOnHover) {
1000
+ this.changeFocusedOptionIndex(event, index);
1001
+ }
835
1002
  }
836
- onInputFocus(event) {
837
- if (!this.itemClicked && this.completeOnFocus) {
838
- let queryValue = this.multiple ? this.multiInputEl?.nativeElement.value : this.inputEL?.nativeElement.value;
839
- this.search(event, queryValue);
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
- this.focus = true;
842
- this.onFocus.emit(event);
843
- this.itemClicked = false;
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
- onInputBlur(event) {
846
- this.focus = false;
847
- this.onModelTouched();
848
- this.onBlur.emit(event);
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
- onInputChange(event) {
851
- if (this.forceSelection) {
852
- let valid = false;
853
- const target = event.target;
854
- let inputValue = target.value.trim();
855
- if (this.suggestions) {
856
- let suggestions = [...this.suggestions];
857
- if (this.group) {
858
- let groupedSuggestions = this.suggestions.filter((s) => s[this.optionGroupChildren]).flatMap((s) => s[this.optionGroupChildren]);
859
- suggestions = suggestions.concat(groupedSuggestions);
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
- if (!valid) {
873
- if (this.multiple) {
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
- onInputPaste(event) {
887
- this.onKeydown(event);
888
- }
889
- isSelected(val) {
890
- let selected = false;
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
- return selected;
900
- }
901
- findOptionIndex(option, suggestions) {
902
- let index = -1;
903
- if (suggestions) {
904
- for (let i = 0; i < suggestions.length; i++) {
905
- if (ObjectUtils.equals(option, suggestions[i])) {
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
- return index;
912
- }
913
- findOptionGroupIndex(val, opts) {
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
- if (itemIndex !== -1) {
925
- return { groupIndex: groupIndex, itemIndex: itemIndex };
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
- else {
928
- return -1;
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
- updateFilledState() {
932
- if (this.multiple)
933
- this.filled = (this.value && this.value.length) || (this.multiInputEl && this.multiInputEl.nativeElement && this.multiInputEl.nativeElement.value != '');
934
- else
935
- this.filled = (this.inputFieldValue && this.inputFieldValue != '') || (this.inputEL && this.inputEL.nativeElement && this.inputEL.nativeElement.value != '');
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
- updateInputField() {
938
- let formattedValue = this.resolveFieldData(this.value);
939
- this.inputFieldValue = formattedValue;
940
- if (this.inputEL && this.inputEL.nativeElement) {
941
- this.inputEL.nativeElement.value = formattedValue;
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: i0.IterableDiffers }, { token: i1.PrimeNGConfig }, { token: i1.OverlayService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
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": "((focus && !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: ["in"], 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: `
957
- <span #container [ngClass]="{ 'p-autocomplete p-component': true, 'p-autocomplete-dd': dropdown, 'p-autocomplete-multiple': multiple }" [ngStyle]="style" [class]="styleClass">
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
- *ngIf="!multiple"
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
- [attr.required]="required"
969
- [attr.name]="name"
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="searchbox"
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
- [attr.maxlength]="maxlength"
986
- [attr.tabindex]="tabindex"
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
- <ul *ngIf="multiple" #multiContainer class="p-autocomplete-multiple-container p-component p-inputtext" [ngClass]="{ 'p-disabled': disabled, 'p-focus': focus }" (click)="multiIn.focus()">
1000
- <li #token *ngFor="let val of value" class="p-autocomplete-token">
1001
- <ng-container *ngTemplateOutlet="selectedItemTemplate; context: { $implicit: val }"></ng-container>
1002
- <span *ngIf="!selectedItemTemplate" class="p-autocomplete-token-label">{{ resolveFieldData(val) }}</span>
1003
- <span class="p-autocomplete-token-icon" (click)="removeItem(token)">
1004
- <TimesCircleIcon [styleClass]="'p-autocomplete-token-icon'" *ngIf="!removeIconTemplate" />
1005
- <span *ngIf="removeIconTemplate" class="p-autocomplete-token-icon">
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
- #multiIn
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
- [ngStyle]="inputStyle"
1032
- [class]="inputStyleClass"
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-haspopup="true"
1041
- [attr.aria-activedescendant]="'p-highlighted-option'"
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]="overlayOptions"
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
- (onShow)="show($event)"
1070
- (onHide)="hide($event)"
1292
+ (onHide)="hide()"
1071
1293
  >
1072
- <div [ngClass]="['p-autocomplete-panel p-component']" [style.max-height]="virtualScroll ? 'auto' : scrollHeight" [ngStyle]="panelStyle" [class]="panelStyleClass">
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]="suggestions"
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: suggestions, options: {} }"></ng-container>
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 role="listbox" [attr.id]="listId" class="p-autocomplete-items" [ngClass]="scrollerOptions.contentStyleClass" [style]="scrollerOptions.contentStyle">
1100
- <ng-container *ngIf="group">
1101
- <ng-template ngFor let-optgroup [ngForOf]="items">
1102
- <li class="p-autocomplete-item-group" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }">
1103
- <span *ngIf="!groupTemplate">{{ getOptionGroupLabel(optgroup) || 'empty' }}</span>
1104
- <ng-container *ngTemplateOutlet="groupTemplate; context: { $implicit: optgroup }"></ng-container>
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
- <ng-container *ngTemplateOutlet="itemslist; context: { $implicit: getOptionGroupChildren(optgroup) }"></ng-container>
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="noResults && showEmptyMessage" class="p-autocomplete-empty-message" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }">
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
- {{ emptyMessageLabel }}
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
- </span>
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
- <span #container [ngClass]="{ 'p-autocomplete p-component': true, 'p-autocomplete-dd': dropdown, 'p-autocomplete-multiple': multiple }" [ngStyle]="style" [class]="styleClass">
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
- *ngIf="!multiple"
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
- [attr.required]="required"
1157
- [attr.name]="name"
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="searchbox"
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
- [attr.maxlength]="maxlength"
1174
- [attr.tabindex]="tabindex"
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
- <ul *ngIf="multiple" #multiContainer class="p-autocomplete-multiple-container p-component p-inputtext" [ngClass]="{ 'p-disabled': disabled, 'p-focus': focus }" (click)="multiIn.focus()">
1188
- <li #token *ngFor="let val of value" class="p-autocomplete-token">
1189
- <ng-container *ngTemplateOutlet="selectedItemTemplate; context: { $implicit: val }"></ng-container>
1190
- <span *ngIf="!selectedItemTemplate" class="p-autocomplete-token-label">{{ resolveFieldData(val) }}</span>
1191
- <span class="p-autocomplete-token-icon" (click)="removeItem(token)">
1192
- <TimesCircleIcon [styleClass]="'p-autocomplete-token-icon'" *ngIf="!removeIconTemplate" />
1193
- <span *ngIf="removeIconTemplate" class="p-autocomplete-token-icon">
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
- #multiIn
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
- [ngStyle]="inputStyle"
1220
- [class]="inputStyleClass"
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-haspopup="true"
1229
- [attr.aria-activedescendant]="'p-highlighted-option'"
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]="overlayOptions"
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
- (onShow)="show($event)"
1258
- (onHide)="hide($event)"
1508
+ (onHide)="hide()"
1259
1509
  >
1260
- <div [ngClass]="['p-autocomplete-panel p-component']" [style.max-height]="virtualScroll ? 'auto' : scrollHeight" [ngStyle]="panelStyle" [class]="panelStyleClass">
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]="suggestions"
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: suggestions, options: {} }"></ng-container>
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 role="listbox" [attr.id]="listId" class="p-autocomplete-items" [ngClass]="scrollerOptions.contentStyleClass" [style]="scrollerOptions.contentStyle">
1288
- <ng-container *ngIf="group">
1289
- <ng-template ngFor let-optgroup [ngForOf]="items">
1290
- <li class="p-autocomplete-item-group" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }">
1291
- <span *ngIf="!groupTemplate">{{ getOptionGroupLabel(optgroup) || 'empty' }}</span>
1292
- <ng-container *ngTemplateOutlet="groupTemplate; context: { $implicit: optgroup }"></ng-container>
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
- <ng-container *ngTemplateOutlet="itemslist; context: { $implicit: getOptionGroupChildren(optgroup) }"></ng-container>
1295
- </ng-template>
1296
- </ng-container>
1297
- <ng-container *ngIf="!group">
1298
- <ng-container *ngTemplateOutlet="itemslist; context: { $implicit: items }"></ng-container>
1299
- </ng-container>
1300
- <ng-template #itemslist let-suggestionsToDisplay>
1301
- <li
1302
- role="option"
1303
- *ngFor="let option of suggestionsToDisplay; let idx = index"
1304
- class="p-autocomplete-item"
1305
- pRipple
1306
- [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }"
1307
- [ngClass]="{ 'p-highlight': option === highlightOption }"
1308
- [id]="highlightOption == option ? 'p-highlighted-option' : ''"
1309
- (click)="selectItem(option)"
1310
- >
1311
- <span *ngIf="!itemTemplate">{{ resolveFieldData(option) }}</span>
1312
- <ng-container *ngTemplateOutlet="itemTemplate; context: { $implicit: option, index: scrollerOptions.getOptions ? scrollerOptions.getOptions(idx) : idx }"></ng-container>
1313
- </li>
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="noResults && showEmptyMessage" class="p-autocomplete-empty-message" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }">
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
- {{ emptyMessageLabel }}
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
- </span>
1582
+ </div>
1327
1583
  `, host: {
1328
1584
  class: 'p-element p-inputwrapper',
1329
1585
  '[class.p-inputwrapper-filled]': 'filled',
1330
- '[class.p-inputwrapper-focus]': '((focus && !disabled) || autofocus) || overlayVisible',
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: i0.IterableDiffers }, { type: i1.PrimeNGConfig }, { type: i1.OverlayService }, { type: i0.NgZone }]; }, propDecorators: { minLength: [{
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: ['in']
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"]}