@testgorilla/tgo-ui 3.14.13 → 4.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (247) hide show
  1. package/components/donut-chart/donut-chart.component.d.ts +2 -2
  2. package/components/filter-button/filter-button.component.d.ts +2 -2
  3. package/components/icon/icon-svg-content.d.ts +1 -1
  4. package/components/table/table.component.d.ts +1 -1
  5. package/fesm2022/testgorilla-tgo-ui.mjs +731 -715
  6. package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
  7. package/package.json +17 -20
  8. package/projects/tgo-canopy-ui/theme/_palette.scss +2 -1
  9. package/utils/color-contrast.d.ts +1 -1
  10. package/esm2022/assets/i18n/da-dk.json +0 -820
  11. package/esm2022/assets/i18n/de.json +0 -820
  12. package/esm2022/assets/i18n/en.json +0 -827
  13. package/esm2022/assets/i18n/es.json +0 -820
  14. package/esm2022/assets/i18n/fr.json +0 -820
  15. package/esm2022/assets/i18n/it-it.json +0 -820
  16. package/esm2022/assets/i18n/ja-jp.json +0 -820
  17. package/esm2022/assets/i18n/nb-no.json +0 -820
  18. package/esm2022/assets/i18n/nl.json +0 -820
  19. package/esm2022/assets/i18n/pl-pl.json +0 -820
  20. package/esm2022/assets/i18n/pt-br.json +0 -820
  21. package/esm2022/assets/i18n/sv-se.json +0 -820
  22. package/esm2022/components/accordion/accordion.component.mjs +0 -135
  23. package/esm2022/components/accordion/accordion.component.module.mjs +0 -40
  24. package/esm2022/components/accordion/accordion.model.mjs +0 -2
  25. package/esm2022/components/ai-feedback/ai-feedback.component.mjs +0 -35
  26. package/esm2022/components/ai-feedback/ai-feedback.model.mjs +0 -2
  27. package/esm2022/components/ai-feedback/ai-feedback.module.mjs +0 -20
  28. package/esm2022/components/alert-banner/alert-banner.component.mjs +0 -198
  29. package/esm2022/components/alert-banner/alert-banner.component.module.mjs +0 -21
  30. package/esm2022/components/alert-banner/alert-banner.model.mjs +0 -2
  31. package/esm2022/components/autocomplete/autocomplete.component.mjs +0 -837
  32. package/esm2022/components/autocomplete/autocomplete.component.module.mjs +0 -77
  33. package/esm2022/components/autocomplete/autocomplete.model.mjs +0 -25
  34. package/esm2022/components/autocomplete/includes.pipe.mjs +0 -25
  35. package/esm2022/components/autocomplete/prevent-input.directive.mjs +0 -27
  36. package/esm2022/components/autocomplete/transform-Item.pipe.mjs +0 -32
  37. package/esm2022/components/avatar/avatar.component.mjs +0 -104
  38. package/esm2022/components/avatar/avatar.component.module.mjs +0 -23
  39. package/esm2022/components/avatar/avatar.model.mjs +0 -21
  40. package/esm2022/components/badge/badge.component.mjs +0 -118
  41. package/esm2022/components/badge/badge.component.module.mjs +0 -20
  42. package/esm2022/components/badge/badge.model.mjs +0 -39
  43. package/esm2022/components/breadcrumb/breadcrumb.component.mjs +0 -191
  44. package/esm2022/components/breadcrumb/breadcrumb.component.module.mjs +0 -45
  45. package/esm2022/components/breadcrumb/breadcrumb.model.mjs +0 -2
  46. package/esm2022/components/button/button.component.mjs +0 -452
  47. package/esm2022/components/button/button.component.module.mjs +0 -51
  48. package/esm2022/components/button/button.model.mjs +0 -2
  49. package/esm2022/components/card/card.component.mjs +0 -141
  50. package/esm2022/components/card/card.component.module.mjs +0 -19
  51. package/esm2022/components/card/card.model.mjs +0 -2
  52. package/esm2022/components/checkbox/checkbox.component.mjs +0 -336
  53. package/esm2022/components/checkbox/checkbox.component.module.mjs +0 -28
  54. package/esm2022/components/checkbox/focus-visible.directive.mjs +0 -40
  55. package/esm2022/components/checklist/checklist.component.mjs +0 -157
  56. package/esm2022/components/checklist/checklist.model.mjs +0 -2
  57. package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +0 -73
  58. package/esm2022/components/confirm-dialog/confirm-dialog.component.module.mjs +0 -29
  59. package/esm2022/components/confirm-dialog/confirm-dialog.model.mjs +0 -2
  60. package/esm2022/components/datepicker/date-adapter.mjs +0 -39
  61. package/esm2022/components/datepicker/datepicker.component.mjs +0 -353
  62. package/esm2022/components/datepicker/datepicker.component.module.mjs +0 -60
  63. package/esm2022/components/datepicker/datepicker.service.mjs +0 -20
  64. package/esm2022/components/datepicker/no-date-format.directive.mjs +0 -56
  65. package/esm2022/components/deprecated-paginator/deprecated-paginator.component.mjs +0 -55
  66. package/esm2022/components/deprecated-paginator/deprecated-paginator.component.module.mjs +0 -20
  67. package/esm2022/components/dialog/dialog.component.mjs +0 -275
  68. package/esm2022/components/dialog/dialog.component.module.mjs +0 -23
  69. package/esm2022/components/dialog/dialog.model.mjs +0 -2
  70. package/esm2022/components/dialog/dialog.service.mjs +0 -36
  71. package/esm2022/components/divider/divider.component.mjs +0 -65
  72. package/esm2022/components/divider/divider.component.module.mjs +0 -19
  73. package/esm2022/components/divider/divider.model.mjs +0 -2
  74. package/esm2022/components/donut-chart/donut-chart.component.mjs +0 -122
  75. package/esm2022/components/donut-chart/donut-chart.component.model.mjs +0 -2
  76. package/esm2022/components/donut-chart/donut-chart.component.module.mjs +0 -20
  77. package/esm2022/components/dropdown/dropdown.component.mjs +0 -378
  78. package/esm2022/components/dropdown/dropdown.component.module.mjs +0 -57
  79. package/esm2022/components/dropdown/dropdown.model.mjs +0 -2
  80. package/esm2022/components/elevation-shadow/elevation-shadow.component.mjs +0 -45
  81. package/esm2022/components/elevation-shadow/elevation-shadow.component.module.mjs +0 -18
  82. package/esm2022/components/elevation-shadow/elevation-shadow.constant.mjs +0 -9
  83. package/esm2022/components/empty-state/empty-state.component.mjs +0 -301
  84. package/esm2022/components/empty-state/empty-state.component.module.mjs +0 -21
  85. package/esm2022/components/empty-state/empty-state.model.mjs +0 -2
  86. package/esm2022/components/field/field.component.mjs +0 -574
  87. package/esm2022/components/field/field.component.module.mjs +0 -64
  88. package/esm2022/components/field/field.model.mjs +0 -2
  89. package/esm2022/components/file-upload/file-upload.component.mjs +0 -307
  90. package/esm2022/components/file-upload/file-upload.component.module.mjs +0 -40
  91. package/esm2022/components/filter-button/filter-button.component.mjs +0 -255
  92. package/esm2022/components/filter-button/filter-button.component.module.mjs +0 -58
  93. package/esm2022/components/filter-button/filter-button.model.mjs +0 -2
  94. package/esm2022/components/gaussian-chart/gaussian-chart.component.mjs +0 -254
  95. package/esm2022/components/gaussian-chart/gaussian-chart.module.mjs +0 -42
  96. package/esm2022/components/icon/icon-svg-content.mjs +0 -491
  97. package/esm2022/components/icon/icon.component.mjs +0 -178
  98. package/esm2022/components/icon/icon.component.module.mjs +0 -21
  99. package/esm2022/components/icon/icon.config.mjs +0 -780
  100. package/esm2022/components/icon/icon.model.mjs +0 -2
  101. package/esm2022/components/icon-label/icon-label.component.mjs +0 -74
  102. package/esm2022/components/icon-label/icon-label.component.module.mjs +0 -20
  103. package/esm2022/components/inline-field/inline-field.component.mjs +0 -320
  104. package/esm2022/components/inline-field/inline-field.component.module.mjs +0 -43
  105. package/esm2022/components/inline-field/inline-field.model.mjs +0 -2
  106. package/esm2022/components/logo/logo.component.mjs +0 -165
  107. package/esm2022/components/logo/logo.component.module.mjs +0 -18
  108. package/esm2022/components/logo/logo.model.mjs +0 -32
  109. package/esm2022/components/media-card/media-card.component.mjs +0 -47
  110. package/esm2022/components/media-dialog/media-dialog.component.mjs +0 -75
  111. package/esm2022/components/media-dialog/media-dialog.model.mjs +0 -2
  112. package/esm2022/components/multi-input/multi-input.component.mjs +0 -271
  113. package/esm2022/components/multi-input/multi-input.component.module.mjs +0 -58
  114. package/esm2022/components/multi-input/multi-input.model.mjs +0 -2
  115. package/esm2022/components/multi-input/required-multi-input.validator.mjs +0 -14
  116. package/esm2022/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.mjs +0 -86
  117. package/esm2022/components/navbar/navbar.component.mjs +0 -212
  118. package/esm2022/components/navbar/navbar.component.module.mjs +0 -71
  119. package/esm2022/components/navbar/navbar.model.mjs +0 -2
  120. package/esm2022/components/overflow-menu/overflow-menu.component.mjs +0 -254
  121. package/esm2022/components/overflow-menu/overflow-menu.component.module.mjs +0 -25
  122. package/esm2022/components/overflow-menu/overflow-menu.model.mjs +0 -2
  123. package/esm2022/components/page-header/page-header.component.mjs +0 -71
  124. package/esm2022/components/page-header/page-header.component.module.mjs +0 -20
  125. package/esm2022/components/paginator/paginator.component.mjs +0 -87
  126. package/esm2022/components/paginator/paginator.component.module.mjs +0 -19
  127. package/esm2022/components/password-criteria/password.component.mjs +0 -111
  128. package/esm2022/components/password-criteria/password.component.module.mjs +0 -39
  129. package/esm2022/components/password-strength/password-strength.component.mjs +0 -93
  130. package/esm2022/components/password-strength/password-strength.component.module.mjs +0 -21
  131. package/esm2022/components/phone-input/join-strings.pipe.mjs +0 -14
  132. package/esm2022/components/phone-input/phone-input.component.mjs +0 -354
  133. package/esm2022/components/phone-input/phone-input.component.module.mjs +0 -63
  134. package/esm2022/components/phone-input/phone-input.model.mjs +0 -2
  135. package/esm2022/components/progress-bar/progress-bar.component.mjs +0 -103
  136. package/esm2022/components/progress-bar/progress-bar.component.module.mjs +0 -21
  137. package/esm2022/components/prompt/prompt.component.mjs +0 -187
  138. package/esm2022/components/prompt/prompt.model.mjs +0 -2
  139. package/esm2022/components/prompt/prompt.module.mjs +0 -62
  140. package/esm2022/components/radial-progress/radial-progress.component.mjs +0 -118
  141. package/esm2022/components/radial-progress/radial-progress.component.module.mjs +0 -20
  142. package/esm2022/components/radial-progress/radial-progress.model.mjs +0 -11
  143. package/esm2022/components/radio-button/radio-button.component.mjs +0 -344
  144. package/esm2022/components/radio-button/radio-button.component.module.mjs +0 -25
  145. package/esm2022/components/radio-button/radio-button.model.mjs +0 -2
  146. package/esm2022/components/rating/half-star.pipe.mjs +0 -23
  147. package/esm2022/components/rating/rating.component.mjs +0 -106
  148. package/esm2022/components/rating/rating.component.module.mjs +0 -20
  149. package/esm2022/components/scale/scale.component.mjs +0 -136
  150. package/esm2022/components/scale/scale.component.module.mjs +0 -18
  151. package/esm2022/components/scale-table/scale-table.component.mjs +0 -61
  152. package/esm2022/components/scale-table/scale-table.model.mjs +0 -2
  153. package/esm2022/components/segmented-bar/segmented-bar.component.mjs +0 -111
  154. package/esm2022/components/segmented-bar/segmented-bar.component.module.mjs +0 -22
  155. package/esm2022/components/segmented-bar/segmented-bar.model.mjs +0 -2
  156. package/esm2022/components/segmented-button/segmented-button.component.mjs +0 -104
  157. package/esm2022/components/segmented-button/segmented-button.component.module.mjs +0 -21
  158. package/esm2022/components/segmented-button/segmented-button.model.mjs +0 -2
  159. package/esm2022/components/selectable-card/selectable-card.component.mjs +0 -53
  160. package/esm2022/components/selectable-card/selectable-card.component.module.mjs +0 -20
  161. package/esm2022/components/side-panel/side-panel-data-injection-token.mjs +0 -3
  162. package/esm2022/components/side-panel/side-panel.animations.mjs +0 -26
  163. package/esm2022/components/side-panel/side-panel.component.mjs +0 -55
  164. package/esm2022/components/side-panel/side-panel.model.mjs +0 -54
  165. package/esm2022/components/side-panel/side-panel.service.mjs +0 -98
  166. package/esm2022/components/side-sheet/side-sheet.component.mjs +0 -105
  167. package/esm2022/components/side-sheet/side-sheet.component.module.mjs +0 -43
  168. package/esm2022/components/side-sheet/side-sheet.model.mjs +0 -2
  169. package/esm2022/components/side-sheet/side-sheet.service.mjs +0 -31
  170. package/esm2022/components/skeleton/skeleton.component.mjs +0 -74
  171. package/esm2022/components/skeleton/skeleton.model.mjs +0 -2
  172. package/esm2022/components/slider/slider.component.mjs +0 -256
  173. package/esm2022/components/slider/slider.component.module.mjs +0 -16
  174. package/esm2022/components/slider/slider.model.mjs +0 -2
  175. package/esm2022/components/snackbar/snackbar.component.mjs +0 -235
  176. package/esm2022/components/snackbar/snackbar.component.module.mjs +0 -25
  177. package/esm2022/components/snackbar/snackbar.model.mjs +0 -2
  178. package/esm2022/components/snackbar/snackbar.service.mjs +0 -42
  179. package/esm2022/components/spider-chart/spider-chart.component.mjs +0 -443
  180. package/esm2022/components/spider-chart/spider-chart.model.mjs +0 -4
  181. package/esm2022/components/spider-chart/spider-chart.module.mjs +0 -44
  182. package/esm2022/components/spinner/spinner.component.mjs +0 -84
  183. package/esm2022/components/spinner/spinner.model.mjs +0 -2
  184. package/esm2022/components/spinner/spinner.module.mjs +0 -20
  185. package/esm2022/components/step/step.component.mjs +0 -209
  186. package/esm2022/components/step/step.component.module.mjs +0 -21
  187. package/esm2022/components/stepper/stepper.component.mjs +0 -198
  188. package/esm2022/components/stepper/stepper.component.module.mjs +0 -44
  189. package/esm2022/components/stepper/stepper.model.mjs +0 -2
  190. package/esm2022/components/table/sentence-case.pipe.mjs +0 -19
  191. package/esm2022/components/table/table.component.mjs +0 -273
  192. package/esm2022/components/table/table.component.module.mjs +0 -61
  193. package/esm2022/components/table/table.model.mjs +0 -25
  194. package/esm2022/components/tabs/tab.directive.mjs +0 -63
  195. package/esm2022/components/tabs/tabs.component.mjs +0 -219
  196. package/esm2022/components/tabs/tabs.component.module.mjs +0 -23
  197. package/esm2022/components/tabs/tabs.model.mjs +0 -2
  198. package/esm2022/components/tag/tag.component.mjs +0 -212
  199. package/esm2022/components/tag/tag.component.module.mjs +0 -24
  200. package/esm2022/components/tag/tag.model.mjs +0 -2
  201. package/esm2022/components/toggle/toggle.component.mjs +0 -190
  202. package/esm2022/components/toggle/toggle.component.module.mjs +0 -24
  203. package/esm2022/components/toggle/toggle.model.mjs +0 -2
  204. package/esm2022/components/tooltip/tooltip-template.directive.mjs +0 -133
  205. package/esm2022/components/tooltip/tooltip.component.mjs +0 -108
  206. package/esm2022/components/tooltip/tooltip.component.module.mjs +0 -27
  207. package/esm2022/components/tooltip/tooltip.model.mjs +0 -8
  208. package/esm2022/components/universal-skills-report/universal-skills-report.component.mjs +0 -80
  209. package/esm2022/components/universal-skills-report/universal-skills-report.component.module.mjs +0 -43
  210. package/esm2022/components/universal-skills-spider-charts/universal-skills-spider-charts.component.mjs +0 -109
  211. package/esm2022/components/universal-skills-spider-charts/universal-skills-spider-charts.component.module.mjs +0 -52
  212. package/esm2022/components/validation-error/validation-error.component.mjs +0 -55
  213. package/esm2022/components/validation-error/validation-error.model.mjs +0 -2
  214. package/esm2022/components/validation-error/validation-error.module.mjs +0 -20
  215. package/esm2022/directives/digits-only.directive.mjs +0 -77
  216. package/esm2022/directives/drag-drop.directive.mjs +0 -55
  217. package/esm2022/directives/dynamic-component.directive.mjs +0 -40
  218. package/esm2022/directives/ellipse-text.directive.mjs +0 -51
  219. package/esm2022/directives/select-text.directive.mjs +0 -40
  220. package/esm2022/directives/step-line-element.directive.mjs +0 -51
  221. package/esm2022/models/application-theme.model.mjs +0 -2
  222. package/esm2022/models/checkbox.model.mjs +0 -2
  223. package/esm2022/models/colors.model.mjs +0 -78
  224. package/esm2022/models/keyboard-events.model.mjs +0 -13
  225. package/esm2022/models/screen-breakpoints.model.mjs +0 -7
  226. package/esm2022/models/universal-skills-report.model.mjs +0 -33
  227. package/esm2022/pipes/data-property-getter.mjs +0 -33
  228. package/esm2022/pipes/has-validation-error.pipe.mjs +0 -27
  229. package/esm2022/pipes/memoize-func.pipe.mjs +0 -39
  230. package/esm2022/pipes/name-initials.pipe.mjs +0 -25
  231. package/esm2022/pipes/truncate.pipe.mjs +0 -34
  232. package/esm2022/pipes/ui-ordinal-suffix.pipe.mjs +0 -31
  233. package/esm2022/pipes/ui-translate.pipe.mjs +0 -81
  234. package/esm2022/providers/is-large-tablet.mjs +0 -11
  235. package/esm2022/providers/is-mobile.mjs +0 -11
  236. package/esm2022/public-api.mjs +0 -259
  237. package/esm2022/services/icons.service.mjs +0 -22
  238. package/esm2022/services/universal-skills.service.mjs +0 -85
  239. package/esm2022/testgorilla-tgo-ui.mjs +0 -5
  240. package/esm2022/utils/alert-bar.model.mjs +0 -2
  241. package/esm2022/utils/alert-bars.utils.mjs +0 -34
  242. package/esm2022/utils/autocomplete-utils.mjs +0 -78
  243. package/esm2022/utils/color-contrast.mjs +0 -131
  244. package/esm2022/utils/hex-to-rgb.mjs +0 -9
  245. package/esm2022/utils/localization/language.model.mjs +0 -16
  246. package/esm2022/utils/localization/language.service.mjs +0 -44
  247. package/esm2022/utils/table.utils.mjs +0 -25
@@ -1,837 +0,0 @@
1
- import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';
2
- import { isPlatformBrowser } from '@angular/common';
3
- import { booleanAttribute, ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Inject, Input, Optional, Output, PLATFORM_ID, Self, signal, ViewChild, } from '@angular/core';
4
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
5
- import { BehaviorSubject, filter, map, ReplaySubject, startWith, take, throttleTime } from 'rxjs';
6
- import { IKeyboardEvent } from '../../models/keyboard-events.model';
7
- import { AutocompleteUtils } from '../../utils/autocomplete-utils';
8
- import { Autocomplete, DropdownVariation, Padding, Timeout, } from './autocomplete.model';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "@angular/platform-browser";
11
- import * as i2 from "@angular/forms";
12
- import * as i3 from "@angular/cdk/a11y";
13
- import * as i4 from "@angular/common";
14
- import * as i5 from "@angular/material/form-field";
15
- import * as i6 from "@angular/material/autocomplete";
16
- import * as i7 from "@angular/material/core";
17
- import * as i8 from "@angular/material/input";
18
- import * as i9 from "../tag/tag.component";
19
- import * as i10 from "../icon/icon.component";
20
- import * as i11 from "../validation-error/validation-error.component";
21
- import * as i12 from "@angular/cdk/scrolling";
22
- import * as i13 from "./prevent-input.directive";
23
- import * as i14 from "../spinner/spinner.component";
24
- import * as i15 from "../../directives/select-text.directive";
25
- import * as i16 from "../../pipes/ui-translate.pipe";
26
- import * as i17 from "../../pipes/has-validation-error.pipe";
27
- import * as i18 from "./transform-Item.pipe";
28
- import * as i19 from "./includes.pipe";
29
- // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle
30
- export class AutocompleteComponent {
31
- /**
32
- * @property value
33
- * @description The selected value(s) in the autocomplete.
34
- * @memberof AutocompleteComponent
35
- */
36
- set itemValue(v) {
37
- this.value = AutocompleteUtils.isArray(v) ? v : v ? [v] : [];
38
- }
39
- /**
40
- * Input field errors
41
- *
42
- * @type {string[]}
43
- * @memberof AutocompleteComponent
44
- */
45
- set errors(errors) {
46
- this.safeErrors = errors?.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));
47
- }
48
- set cdkVirtualScrollViewport(viewport) {
49
- if (this.savedVirtualScrollSubscription) {
50
- this.savedVirtualScrollSubscription.unsubscribe();
51
- }
52
- if (viewport) {
53
- this.savedVirtualScrollViewport = viewport;
54
- if (this.infiniteScroll) {
55
- setTimeout(() => {
56
- this.inputValueSearch$.pipe(take(1)).subscribe(searchValue => {
57
- this.isFilteredViewport = !!searchValue;
58
- });
59
- }, 0);
60
- this.savedVirtualScrollSubscription = this.savedVirtualScrollViewport
61
- .elementScrolled()
62
- .pipe(map(() => this.savedVirtualScrollViewport.measureScrollOffset('bottom')), filter(offset => offset < this.savedVirtualScrollViewport.getViewportSize() * 0.2), throttleTime(200), takeUntilDestroyed(this.destroyRef))
63
- .subscribe(() => {
64
- if (this.isFilteredViewport) {
65
- this.scrollViewportBottomReachedFiltered.emit();
66
- }
67
- else {
68
- this.scrollViewportBottomReached.emit();
69
- }
70
- });
71
- }
72
- }
73
- }
74
- constructor(defaultAppTheme, cdr, domSanitizer, ngControl, platformId, el, focusMonitor, destroyRef, ngZone) {
75
- this.defaultAppTheme = defaultAppTheme;
76
- this.cdr = cdr;
77
- this.domSanitizer = domSanitizer;
78
- this.ngControl = ngControl;
79
- this.platformId = platformId;
80
- this.el = el;
81
- this.focusMonitor = focusMonitor;
82
- this.destroyRef = destroyRef;
83
- this.ngZone = ngZone;
84
- /**
85
- * @property itemsList
86
- * @description The list of items to display in the autocomplete.
87
- * @memberof AutocompleteComponent
88
- */
89
- this.itemsList = [];
90
- /**
91
- * @property suggestionsList
92
- * @description The list of suggestions to display in the autocomplete.
93
- * @memberof AutocompleteComponent
94
- */
95
- this.suggestionsList = [];
96
- /**
97
- * @property disabled
98
- * @description If `true`, the autocomplete is disabled.
99
- * @memberof AutocompleteComponent
100
- */
101
- this.disabled = false;
102
- /**
103
- * @property allowAdd
104
- * @description If `true`, allows adding new values to the autocomplete.
105
- * @memberof AutocompleteComponent
106
- */
107
- this.allowAdd = true;
108
- /**
109
- * @property textField
110
- * @description The field to be used as the display text in the autocomplete.
111
- * @memberof AutocompleteComponent
112
- */
113
- this.textField = '';
114
- /**
115
- * @property valueField
116
- * @description The field to be used as the value in the autocomplete.
117
- * @memberof AutocompleteComponent
118
- */
119
- this.valueField = '';
120
- /**
121
- * @property label
122
- * @description The label for the autocomplete input.
123
- * @memberof AutocompleteComponent
124
- */
125
- this.label = '';
126
- /**
127
- * @property placeholder
128
- * @description The placeholder for the autocomplete input.
129
- * @memberof AutocompleteComponent
130
- */
131
- this.placeholder = '';
132
- /**
133
- * @property type
134
- * @description The type of the autocomplete ('single', 'multi', etc.).
135
- * @memberof AutocompleteComponent
136
- */
137
- this.type = 'multi';
138
- /**
139
- * @property minCharactersSearch
140
- * @description The minimum characters to trigger search.
141
- * @memberof AutocompleteComponent
142
- */
143
- this.minCharactersSearch = 3;
144
- /**
145
- * @property variant
146
- * @description The variant of Autocomplete
147
- * @memberof AutocompleteComponent
148
- */
149
- this.variant = DropdownVariation.AUTOCOMPLETE;
150
- /**
151
- * Show reserved content below form field
152
- * @property showBottomContent
153
- * @type {boolean}
154
- * @memberof AutocompleteComponent
155
- */
156
- this.showBottomContent = true;
157
- /**
158
- * Return full object if true
159
- * @property valuePrimitive
160
- * @type {boolean}
161
- * @memberof AutocompleteComponent
162
- */
163
- this.valuePrimitive = false;
164
- /**
165
- * Indicator of the autocomplete width
166
- * @property fullWidth
167
- * @type {boolean}
168
- * @memberof AutocompleteComponent
169
- */
170
- this.fullWidth = false;
171
- /**
172
- *
173
- * Defines the application theme
174
- *
175
- * @type {ApplicationTheme}
176
- * @memberof AutocompleteComponent
177
- */
178
- this.applicationTheme = 'light';
179
- /**
180
- * Color of the option hover.
181
- * Defaults to Test Gorilla primary color.
182
- *
183
- * @type {string}
184
- * @memberof AutocompleteComponent
185
- */
186
- this.companyColor = '#FFF2FC';
187
- /**
188
- * Hide in-build errors for Reactive Forms
189
- *
190
- * @type {number}
191
- * @memberof AutocompleteComponent
192
- */
193
- this.hideBuiltInErrors = false;
194
- /**
195
- * Hide label in errors
196
- *
197
- * @type {number}
198
- * @memberof AutocompleteComponent
199
- */
200
- this.hideLabelInErrors = false;
201
- /**
202
- * Sets dropdown list to virtual scroll mode
203
- *
204
- * @type {boolean}
205
- * @memberof AutocompleteComponent
206
- */
207
- this.virtualScroll = false;
208
- /**
209
- * @property dropdownPanelClass
210
- * @description Sets class on autocomplete dropdown
211
- * @memberof AutocompleteComponent
212
- */
213
- this.dropdownPanelClass = '';
214
- /**
215
- * @property closeOnScroll
216
- * @description Defines if dropdown should be closed on page scroll
217
- * @memberof AutocompleteComponent
218
- */
219
- this.closeOnScroll = false;
220
- /**
221
- * @property AutocompleteSize
222
- * @description Defines the size of the autocomplete. Small changes the tags to counter; medium is default.
223
- * @memberof AutocompleteComponent
224
- */
225
- this.size = 'medium';
226
- /**
227
- * @property allowUserInput
228
- * @description If `true`, allows the user to input custom values in the autocomplete.
229
- * @type {boolean}
230
- * @memberof AutocompleteComponent
231
- */
232
- this.allowUserInput = true;
233
- /**
234
- * @property clearable
235
- * @description If `true`, allows the user to clear the input values
236
- * @type {boolean}
237
- * @memberof AutocompleteComponent
238
- */
239
- this.clearable = true;
240
- /**
241
- * @property exactMatchSelect
242
- * @description If `true`, allows to select the exact match from the suggestions list
243
- * @type {boolean}
244
- * @memberof AutocompleteComponent
245
- */
246
- this.exactMatchSelect = true;
247
- /**
248
- * @property maxItemSelected
249
- * @description Sets the maximum number of items that can be selected in the autocomplete
250
- * @type {boolean}
251
- * @memberof AutocompleteComponent
252
- */
253
- this.maxItemSelected = Infinity;
254
- this.isDynamicFilteringEnabled = false;
255
- this.dynamicFilterLoading = false;
256
- this.dynamicFilteredList = null;
257
- this.infiniteScroll = false;
258
- this.hasMoreOptionsForInfiniteScroll = true;
259
- this.selectionChange = new EventEmitter();
260
- this.searchTextChange = new EventEmitter();
261
- this.blur = new EventEmitter();
262
- this.focus = new EventEmitter();
263
- /**
264
- * @property scrollViewportBottomReached
265
- * @description Emits when the bottom of the unfiltered list is reached during infinite scroll
266
- * @memberof AutocompleteComponent
267
- */
268
- this.scrollViewportBottomReached = new EventEmitter();
269
- /**
270
- * @property scrollViewportBottomReachedFiltered
271
- * @description Emits when the bottom of the filtered list is reached during infinite scroll
272
- * @memberof AutocompleteComponent
273
- */
274
- this.scrollViewportBottomReachedFiltered = new EventEmitter();
275
- this.safeErrors = [];
276
- this.inputValue = '';
277
- this.isInputFocus = false;
278
- this.autocompleteType = Autocomplete;
279
- this.isOverLapping = false;
280
- this.isOverlapChecking = true;
281
- this.overlapIndex = 0;
282
- this.inputOpacity = 1;
283
- this.firstTagMaxWidth = 0;
284
- this.inputValueSearch$ = new ReplaySubject(1);
285
- this.userInput$ = new ReplaySubject(1);
286
- this.dynamicFilteredList$ = new BehaviorSubject(null);
287
- this.filteredItemsList$ = this.inputValueSearch$.pipe(startWith(''), map(inputValue => inputValue.length
288
- ? AutocompleteUtils.filterItems(this.itemsList, inputValue, this.textField, this.isGrouped)
289
- : null));
290
- this.filteredSuggestionList$ = this.inputValueSearch$.pipe(map(inputValue => inputValue.length ? AutocompleteUtils.filterItems(this.suggestionsList, inputValue, this.textField) : null));
291
- this.isFilteredViewport = false;
292
- this.scrollEvent = (event) => {
293
- const isNotAutocompleteScroll = !event.target?.id?.includes('mat-autocomplete-') &&
294
- !event.target?.parentElement?.id?.includes('mat-autocomplete-') &&
295
- !event.target?.classList?.contains('mat-mdc-autocomplete-trigger');
296
- if (this.autocomplete.panelOpen && isNotAutocompleteScroll) {
297
- this.autocomplete.closePanel();
298
- }
299
- };
300
- this.searchResult$ = this.inputValueSearch$.pipe(map(inputValue => !!inputValue.trim()));
301
- this.translationContext = 'AUTOCOMPLETE.';
302
- this.AutocompleteUtils = AutocompleteUtils;
303
- this.isPlatform = isPlatformBrowser(this.platformId);
304
- this.keyboardFocused = signal(false);
305
- this.isAlreadyAdded = false;
306
- this.onChange = (_) => { };
307
- this.onTouch = () => { };
308
- this.trackByFn = (index, value) => value.changingThisBreaksApplicationSecurity;
309
- if (this.ngControl != null) {
310
- this.ngControl.valueAccessor = this;
311
- }
312
- if (defaultAppTheme) {
313
- this.applicationTheme = defaultAppTheme;
314
- }
315
- this.subscriberDisplayChange();
316
- }
317
- ngOnInit() {
318
- if (this.isDynamicFilteringEnabled) {
319
- this.filteredItemsList$ = this.dynamicFilteredList$;
320
- }
321
- }
322
- /**
323
- * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors
324
- * to display validation errors that might happen (e.g. required)
325
- */
326
- // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle
327
- ngDoCheck() {
328
- if (this.ngControl?.touched || this.ngControl?.errors) {
329
- this.cdr.markForCheck();
330
- }
331
- }
332
- // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle
333
- ngOnChanges(changes) {
334
- if (this.isDynamicFilteringEnabled) {
335
- const dynamicFilteredList = changes['dynamicFilteredList']?.currentValue;
336
- if (dynamicFilteredList) {
337
- this.dynamicFilteredList$.next(dynamicFilteredList);
338
- }
339
- return;
340
- }
341
- if (changes['itemsList'] || changes['suggestionsList'] || changes['valueField']) {
342
- this.itemsList = this.isGrouped
343
- ? this.itemsList
344
- : AutocompleteUtils.excludeSuggestions(this.itemsList, this.suggestionsList, this.valueField);
345
- this.initValue();
346
- }
347
- if (this.isPlatform && changes['companyColor']) {
348
- this.setCompanyColorVariable();
349
- }
350
- }
351
- // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle
352
- ngAfterViewInit() {
353
- if (this.type !== Autocomplete.LARGE) {
354
- this.checkOverlap(Timeout.VIEW_INITIALIZED_COMPONENT_LOAD, true);
355
- }
356
- this.isPlatform && this.setCompanyColorVariable();
357
- if (this.closeOnScroll) {
358
- window.addEventListener('scroll', this.scrollEvent, true);
359
- }
360
- this.focusMonitor
361
- .monitor(this.matInput)
362
- .pipe(takeUntilDestroyed(this.destroyRef))
363
- .subscribe(origin => this.ngZone.run(() => {
364
- this.keyboardFocused.set(origin === 'keyboard');
365
- }));
366
- this.matInput.nativeElement.onkeydown = this.onKeydown.bind(this);
367
- }
368
- // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle
369
- ngOnDestroy() {
370
- window.removeEventListener('scroll', this.scrollEvent, true);
371
- if (this.observer) {
372
- this.observer.disconnect();
373
- }
374
- }
375
- registerOnChange(fn) {
376
- this.onChange = fn;
377
- }
378
- registerOnTouched(fn) {
379
- this.onTouch = fn;
380
- }
381
- setDisabledState(isDisabled) {
382
- this.disabled = isDisabled;
383
- this.cdr.markForCheck();
384
- }
385
- writeValue(value) {
386
- if (this.valuePrimitive && this.textField && this.valueField) {
387
- if (this.type === Autocomplete.SINGLE) {
388
- this.value = this.itemsList.find(item => item[this.valueField] === value);
389
- }
390
- else {
391
- this.value = AutocompleteUtils.isArray(value)
392
- ? this.itemsList.filter(item => value.find((v) => v === item[this.valueField]))
393
- : [this.itemsList.find(item => item[this.valueField] === value)];
394
- this.value = this.value.filter(Boolean).length ? this.value : null;
395
- }
396
- }
397
- else {
398
- this.value = value;
399
- }
400
- this.initValue();
401
- this.cdr.markForCheck();
402
- }
403
- get isGrouped() {
404
- return this.itemsList?.some((item) => item.isGroup);
405
- }
406
- onOptionSelected(event) {
407
- const inputValue = event.option.value;
408
- const itemValue = AutocompleteUtils.createValueItem(inputValue, this.textField, this.valueField);
409
- this.addNewValue(itemValue);
410
- if (this.type === this.autocompleteType.MULTI) {
411
- this.checkOverlap();
412
- }
413
- queueMicrotask(() => {
414
- if (this.type !== this.autocompleteType.SINGLE) {
415
- this.inputValue = '';
416
- }
417
- else {
418
- this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);
419
- }
420
- this.cdr.markForCheck();
421
- });
422
- this.onUpdate();
423
- }
424
- onOptionRemoved(option) {
425
- setTimeout(() => this.autocomplete.closePanel(), 0);
426
- const foundValue = this.value.find((v) => (this.compareWith ? this.compareWith(v, option) : v === option));
427
- if (foundValue) {
428
- this.value = this.value.filter((v) => (this.compareWith ? !this.compareWith(v, option) : v !== option));
429
- this.matAutocomplete.options.forEach(option => {
430
- if (option.value?.value === foundValue.value) {
431
- option.deselect();
432
- }
433
- });
434
- }
435
- if (this.type === this.autocompleteType.MULTI) {
436
- this.checkOverlap();
437
- }
438
- if (!this.value.length) {
439
- this.inputValue = '';
440
- }
441
- this.onUpdate();
442
- }
443
- onInputChange(event) {
444
- const inputValue = event.target.value;
445
- this.userInput$.next(inputValue);
446
- if (inputValue.length >= this.minCharactersSearch) {
447
- this.inputValueSearch$.next(inputValue);
448
- this.searchTextChange.emit(inputValue);
449
- const itemList = this.isGrouped ? this.itemsList.flatMap(groups => groups.items) : this.itemsList.flat();
450
- const findValue = [...this.suggestionsList, ...itemList].find(v => inputValue === (this.textField ? v[this.textField] : v));
451
- const count = AutocompleteUtils.countMatchingWords([...this.suggestionsList, ...itemList], this.inputValue, this.textField);
452
- if (findValue && count === 1 && this.exactMatchSelect) {
453
- this.onOptionSelected({ option: { value: findValue } });
454
- }
455
- }
456
- else {
457
- this.inputValueSearch$.next('');
458
- this.userInput$.next('');
459
- }
460
- this.isAlreadyAdded = !!(this.compareWith
461
- ? this.value.find((v) => this.compareWith(v, inputValue))
462
- : AutocompleteUtils.findDuplicate(this.value, inputValue, this.textField));
463
- }
464
- onClear() {
465
- this.inputValue = '';
466
- this.value = AutocompleteUtils.isArray(this.value) ? [] : '';
467
- this.isOverLapping = false;
468
- this.overlapIndex = 0;
469
- this.onUpdate();
470
- this.matAutocomplete?.options.forEach(option => option.deselect());
471
- this.onTouch();
472
- }
473
- refillInput() {
474
- setTimeout(() => {
475
- if (this.value && this.type === this.autocompleteType.SINGLE && !this.inputValue) {
476
- this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);
477
- }
478
- else if (!this.inputValue && this.value?.length) {
479
- this.inputValue = ' ';
480
- }
481
- else if (this.inputValue && this.type === Autocomplete.SINGLE && this.value && Object.keys(this.value).length) {
482
- this.inputValue = AutocompleteUtils.transformDisplayValue(AutocompleteUtils.isArray(this.value) ? this.value[0] : this.value, this.textField);
483
- }
484
- else if (this.inputValue) {
485
- this.inputValue = ' ';
486
- }
487
- this.inputValueSearch$.next('');
488
- this.userInput$.next('');
489
- this.isInputFocus = false;
490
- this.onTouch();
491
- this.blur.emit();
492
- }, 0);
493
- }
494
- gotoUp() {
495
- if (this.savedVirtualScrollViewport) {
496
- this.savedVirtualScrollViewport.scrollToIndex(0);
497
- this.savedVirtualScrollViewport.checkViewportSize();
498
- }
499
- }
500
- onFocus() {
501
- this.isInputFocus = true;
502
- const inputValue = AutocompleteUtils.isArray(this.inputValue) ? this.inputValue[0] : this.inputValue;
503
- if (AutocompleteUtils.isPrimitive(inputValue)) {
504
- if (typeof inputValue !== 'number' && inputValue?.match(/^\s+/gm)) {
505
- this.inputValue = inputValue.trimStart();
506
- }
507
- }
508
- else {
509
- if (inputValue[this.textField]?.match(/^\s+/gm)) {
510
- this.inputValue = inputValue[this.textField].trimStart();
511
- }
512
- }
513
- this.focus.emit();
514
- }
515
- checkOverlap(delay = Timeout.VIEW_INITIALIZED_AFTER_ACTION, init = false) {
516
- this.isOverLapping = false;
517
- this.isOverlapChecking = true;
518
- this.inputOpacity = 0;
519
- setTimeout(() => {
520
- const inputWidth = this.inputWidth;
521
- const tags = this.tagContainer?.nativeElement.querySelectorAll('.value-tag');
522
- if (tags) {
523
- let width = 0;
524
- let firstTagWidth = 0;
525
- tags.forEach((tag, index) => {
526
- width += tag.getBoundingClientRect().width;
527
- if (!index) {
528
- firstTagWidth = width;
529
- }
530
- const inpWidth = this.formFieldElement?.nativeElement.getBoundingClientRect().width - 20;
531
- this.firstTagMaxWidth =
532
- tags.length > 1
533
- ? inpWidth -
534
- (this.variant === DropdownVariation.DROPDOWN
535
- ? Padding.DROPDOWN_SPACE_CONTAINER
536
- : Padding.AUTOCOMPLETE_SPACE_CONTAINER)
537
- : inpWidth;
538
- if (!this.isOverLapping && width > inputWidth && index > 0) {
539
- this.isOverLapping = true;
540
- this.overlapIndex = index;
541
- }
542
- });
543
- this.isOverlapChecking = false;
544
- if (init) {
545
- if (this.type === this.autocompleteType.SINGLE) {
546
- this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);
547
- }
548
- else if (this.value?.length) {
549
- this.inputValue = ' ';
550
- }
551
- }
552
- const tagContainerWidth = this.tagContainer.nativeElement.getBoundingClientRect().width;
553
- this.tagContainer.nativeElement.style.maxWidth = tagContainerWidth / 100 ? '100%' : tagContainerWidth + 'px';
554
- this.cdr.markForCheck();
555
- }
556
- this.inputOpacity = 1;
557
- }, delay);
558
- }
559
- onUpdate() {
560
- this.inputValueSearch$.next('');
561
- this.userInput$.next('');
562
- if (!this.valuePrimitive) {
563
- this.onChange(this.value);
564
- }
565
- else {
566
- if (this.type === Autocomplete.SINGLE) {
567
- this.onChange(this.value[this.valueField]);
568
- }
569
- else {
570
- this.onChange(this.value.map((v) => v[this.valueField]));
571
- }
572
- }
573
- this.updateControlMaxLengthValidity();
574
- this.selectionChange.emit(this.value);
575
- }
576
- updateControlMaxLengthValidity() {
577
- const control = this.ngControl?.control;
578
- if (!control) {
579
- return;
580
- }
581
- if (this.type !== Autocomplete.SINGLE) {
582
- const existingErrors = control.errors || {};
583
- if (this.value.length > this.maxItemSelected) {
584
- control.setErrors({
585
- ...existingErrors,
586
- maxItemSelected: {
587
- expected: this.maxItemSelected,
588
- actual: this.value.length,
589
- },
590
- });
591
- control.markAsTouched();
592
- }
593
- else {
594
- if (existingErrors['maxItemSelected']) {
595
- delete existingErrors['maxItemSelected'];
596
- control.setErrors(Object.keys(existingErrors).length ? existingErrors : null);
597
- }
598
- }
599
- }
600
- }
601
- initValue() {
602
- if (this.type === this.autocompleteType.SINGLE && this.variant !== DropdownVariation.DROPDOWN) {
603
- if (AutocompleteUtils.isArray(this.value)) {
604
- this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);
605
- }
606
- else {
607
- this.inputValue = this.value ? AutocompleteUtils.transformDisplayValue(this.value, this.textField) : '';
608
- }
609
- }
610
- else if (this.variant === DropdownVariation.DROPDOWN) {
611
- this.inputValue =
612
- (AutocompleteUtils.isArray(this.value) && !this.value?.length) || !this.value
613
- ? ''
614
- : this.type === Autocomplete.SINGLE
615
- ? AutocompleteUtils.transformDisplayValue(AutocompleteUtils.isArray(this.value) ? this.value[0] : this.value, this.textField)
616
- : ' ';
617
- }
618
- else {
619
- this.inputValue = this.value && this.value.length ? ' ' : '';
620
- }
621
- if (this.type === this.autocompleteType.MULTI) {
622
- this.checkOverlap();
623
- }
624
- }
625
- addNewValue(newValue) {
626
- if (this.type !== this.autocompleteType.SINGLE && !this.value) {
627
- this.value = [];
628
- }
629
- const foundDuplicate = this.compareWith
630
- ? this.value.find((v) => this.compareWith(v, newValue))
631
- : AutocompleteUtils.findDuplicate(this.value, newValue, this.textField);
632
- if (this.type !== this.autocompleteType.SINGLE) {
633
- this.value = foundDuplicate
634
- ? this.value.filter((v) => this.compareWith ? !this.compareWith(v, foundDuplicate) : v !== foundDuplicate)
635
- : [...this.value, newValue];
636
- }
637
- else {
638
- this.value = newValue;
639
- }
640
- }
641
- get isDropdown() {
642
- return this.variant === DropdownVariation.DROPDOWN;
643
- }
644
- onChevronClick(autocomplete) {
645
- if (autocomplete.isOpen) {
646
- setTimeout(() => {
647
- this.autocomplete.closePanel();
648
- }, 0);
649
- }
650
- }
651
- get inputWidth() {
652
- return (this.formFieldElement?.nativeElement.getBoundingClientRect().width -
653
- (this.isDropdown ? Padding.DROPDOWN_CONTAINER : Padding.AUTOCOMPLETE_CONTAINER));
654
- }
655
- /**
656
- * Adding company color variable to the body to style overlay container that's out of the component scope.
657
- */
658
- setCompanyColorVariable() {
659
- document.body.style.setProperty('--ui-autocomplete-option-color', `${this.companyColor}`);
660
- }
661
- subscriberDisplayChange() {
662
- const autocompleteHostElement = this.el.nativeElement;
663
- this.observer = new MutationObserver(mutations => {
664
- mutations.forEach(mutation => {
665
- if (mutation.attributeName === 'style') {
666
- const displayStyle = getComputedStyle(autocompleteHostElement).display;
667
- if (displayStyle !== 'none') {
668
- this.checkOverlap();
669
- }
670
- }
671
- });
672
- });
673
- this.observer.observe(autocompleteHostElement, {
674
- attributes: true,
675
- attributeFilter: ['style'],
676
- });
677
- }
678
- get hasObjectValue() {
679
- return this.value ? !!Object.keys(this.value).length : false;
680
- }
681
- onKeydown($event) {
682
- const optionHeight = 48;
683
- if ($event.key === IKeyboardEvent.HOME) {
684
- this.matAutocomplete._keyManager.setFirstItemActive();
685
- }
686
- else if ($event.key === IKeyboardEvent.END) {
687
- this.matAutocomplete._keyManager.setLastItemActive();
688
- }
689
- else if ($event.key === IKeyboardEvent.PAGE_DOWN) {
690
- this.matAutocomplete._keyManager.setNextItemActive();
691
- this.matAutocomplete._keyManager.setNextItemActive();
692
- this.matAutocomplete._keyManager.setNextItemActive();
693
- }
694
- else if ($event.key === IKeyboardEvent.PAGE_UP) {
695
- this.matAutocomplete._keyManager.setPreviousItemActive();
696
- this.matAutocomplete._keyManager.setPreviousItemActive();
697
- this.matAutocomplete._keyManager.setPreviousItemActive();
698
- }
699
- this.matAutocomplete._setScrollTop(this.matAutocomplete._keyManager.activeItemIndex * optionHeight);
700
- }
701
- getVirtualScrollHeight(itemCount) {
702
- const itemHeight = 48;
703
- const maxHeight = 200;
704
- const minHeight = 48;
705
- const calculatedHeight = itemCount * itemHeight;
706
- return Math.min(Math.max(calculatedHeight, minHeight), maxHeight);
707
- }
708
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AutocompleteComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: i0.ChangeDetectorRef }, { token: i1.DomSanitizer }, { token: i2.NgControl, optional: true, self: true }, { token: PLATFORM_ID }, { token: i0.ElementRef }, { token: i3.FocusMonitor }, { token: i0.DestroyRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
709
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AutocompleteComponent, selector: "ui-autocomplete", inputs: { itemsList: "itemsList", suggestionsList: "suggestionsList", disabled: "disabled", allowAdd: "allowAdd", textField: "textField", valueField: "valueField", label: "label", placeholder: "placeholder", itemValue: "itemValue", type: "type", minCharactersSearch: "minCharactersSearch", variant: "variant", showBottomContent: "showBottomContent", valuePrimitive: "valuePrimitive", fullWidth: "fullWidth", applicationTheme: "applicationTheme", required: "required", errors: "errors", companyColor: "companyColor", hideBuiltInErrors: "hideBuiltInErrors", hideLabelInErrors: "hideLabelInErrors", virtualScroll: ["virtualScroll", "virtualScroll", booleanAttribute], compareWith: "compareWith", dropdownPanelClass: "dropdownPanelClass", closeOnScroll: "closeOnScroll", size: "size", allowUserInput: "allowUserInput", clearable: "clearable", exactMatchSelect: "exactMatchSelect", maxItemSelected: "maxItemSelected", maxLength: "maxLength", isDynamicFilteringEnabled: "isDynamicFilteringEnabled", dynamicFilterLoading: "dynamicFilterLoading", dynamicFilteredList: "dynamicFilteredList", infiniteScroll: "infiniteScroll", hasMoreOptionsForInfiniteScroll: "hasMoreOptionsForInfiniteScroll" }, outputs: { selectionChange: "selectionChange", searchTextChange: "searchTextChange", blur: "blur", focus: "focus", scrollViewportBottomReached: "scrollViewportBottomReached", scrollViewportBottomReachedFiltered: "scrollViewportBottomReachedFiltered" }, host: { properties: { "class.full-width": "this.fullWidth", "attr.theme": "this.applicationTheme" } }, viewQueries: [{ propertyName: "formFieldElement", first: true, predicate: ["formField"], descendants: true }, { propertyName: "tagContainer", first: true, predicate: ["tagContainer"], descendants: true }, { propertyName: "autocomplete", first: true, predicate: ["trigger"], descendants: true }, { propertyName: "cdkVirtualScrollViewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true }, { propertyName: "matAutocomplete", first: true, predicate: ["autocomplete"], descendants: true }, { propertyName: "matInput", first: true, predicate: ["matInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container>\n <div class=\"autocomplete-wrapper\" [ngClass]=\"{ 'full-width': fullWidth, disabled: disabled }\">\n <mat-form-field\n [color]=\"\n safeErrors.length ||\n (ngControl?.errors && ngControl?.touched) ||\n (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected ||\n ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue && inputValue !== ' ')\n ? 'warn'\n : 'accent'\n \"\n [appearance]=\"'outline'\"\n [ngClass]=\"{\n 'large-size': type === autocompleteType.LARGE,\n 'hide-bottom-content': !showBottomContent,\n 'keyboard-focused': keyboardFocused(),\n 'has-label': !!label,\n }\"\n >\n <mat-label *ngIf=\"label\">{{ label }} <span *ngIf=\"required\">*</span></mat-label>\n <div #formField class=\"input-container\">\n <span\n style=\"position: absolute; left: -9999px\"\n *ngIf=\"textField ? value?.[textField] : value === inputValue\"\n aria-live=\"polite\"\n >{{ ('SELECTED' | uiTranslate | async) + ' ' + inputValue }}</span\n >\n\n <input\n #trigger=\"matAutocompleteTrigger\"\n #matInput\n [attr.maxlength]=\"maxLength !== null && maxLength !== undefined ? maxLength : null\"\n [uiPreventInput]=\"!allowUserInput\"\n [disabled]=\"disabled\"\n [ngClass]=\"{ 'unset-margin': this.value && type === autocompleteType.LARGE, 'no-caret': !allowUserInput }\"\n (blur)=\"refillInput()\"\n (focusin)=\"onFocus()\"\n [attr.aria-label]=\"\n (translationContext + 'SELECTED' | uiTranslate | async) + ' ' + (value | transformItem: textField : true)\n \"\n [style.opacity]=\"type === autocompleteType.MULTI ? inputOpacity : 1\"\n matInput\n [placeholder]=\"value && value.length ? '' : placeholder\"\n [type]=\"'text'\"\n [matAutocomplete]=\"autocomplete\"\n (input)=\"onInputChange($event)\"\n [(ngModel)]=\"inputValue\"\n />\n <div\n class=\"selected-items\"\n #tagContainer\n *ngIf=\"\n (type === autocompleteType.LARGE && this.value) ||\n (!(inputValue && this.isInputFocus) && this.value && type !== autocompleteType.SINGLE)\n \"\n >\n <ui-tag\n class=\"value-tag\"\n [id]=\"'ui-tag-' + i\"\n *ngFor=\"let valueItem of value; let i = index\"\n [label]=\"valueItem | transformItem: textField\"\n [allowClose]=\"true\"\n [applicationTheme]=\"applicationTheme\"\n [style.opacity]=\"type === autocompleteType.MULTI ? inputOpacity : 1\"\n [style.display]=\"\n (isOverLapping && i > 0 && i >= overlapIndex) || (size === 'small' && value.length > 1) ? 'none' : 'block'\n \"\n [ngStyle]=\"{ '--tag-max-width': type === autocompleteType.LARGE ? 'fit-content' : firstTagMaxWidth + 'px' }\"\n [ngClass]=\"{\n 'overlap-tag': isOverlapChecking && overlapIndex && i >= overlapIndex && type === autocompleteType.MULTI,\n }\"\n (close)=\"onOptionRemoved(valueItem)\"\n ></ui-tag>\n @if (size === 'small') {\n <div class=\"selected-count\" *ngIf=\"value.length > 1\">\n {{\n translationContext + 'SELECTED_AMOUNT'\n | uiTranslate: { numberSelected: (value | slice: overlapIndex).length }\n | async\n }}\n </div>\n } @else {\n <div *ngIf=\"value.length > 1 && isOverLapping\" class=\"overlap-count\">\n <ui-tag [applicationTheme]=\"applicationTheme\" [label]=\"'+' + (value.length - overlapIndex)\"></ui-tag>\n </div>\n }\n </div>\n </div>\n\n <ui-icon\n *ngIf=\"\n (clearable && type === autocompleteType.SINGLE && (value?.length || hasObjectValue)) ||\n (type !== autocompleteType.SINGLE &&\n value &&\n value.length > 1 &&\n ((AutocompleteUtils.isPrimitive(value) && value.length) ||\n (!AutocompleteUtils.isPrimitive(value) &&\n ((AutocompleteUtils.isArray(value) && value.length) ||\n (!AutocompleteUtils.isArray(value) && !value.length)))))\n \"\n class=\"remove-selected\"\n [tabIndex]=\"disabled ? -1 : 0\"\n (keydown.enter)=\"onClear(); $event.preventDefault(); $event.stopPropagation()\"\n (keydown.space)=\"onClear(); $event.preventDefault(); $event.stopPropagation()\"\n [ngClass]=\"{ 'large-input-icon': type === autocompleteType.LARGE }\"\n (click)=\"onClear(); $event.preventDefault(); $event.stopPropagation()\"\n [size]=\"'24'\"\n [color]=\"applicationTheme === 'classic' ? 'inherit' : 'rebrand-black'\"\n [attr.aria-label]=\"'COMMON.CLEAR' | uiTranslate | async\"\n [name]=\"applicationTheme === 'classic' ? 'Close' : 'Close-in-line'\"\n ></ui-icon>\n\n <ui-icon\n class=\"arrow-state\"\n [ngClass]=\"{ opened: autocomplete.isOpen, 'large-input-icon': type === autocompleteType.LARGE }\"\n *ngIf=\"isDropdown\"\n [size]=\"'24'\"\n [name]=\"applicationTheme !== 'classic' ? 'Arrow-chevron-down-in-line' : 'Arrow_down'\"\n (click)=\"onChevronClick(autocomplete)\"\n ></ui-icon>\n\n <mat-autocomplete\n #autocomplete\n [class]=\"applicationTheme + ' ' + dropdownPanelClass\"\n (optionSelected)=\"onOptionSelected($event)\"\n [disableRipple]=\"applicationTheme !== 'classic'\"\n [hideSingleSelectionIndicator]=\"false\"\n (opened)=\"gotoUp()\"\n >\n @if (type !== autocompleteType.MULTI || value?.length < maxItemSelected) {\n <ng-container *ngIf=\"!(searchResult$ | async)\">\n <ng-container *ngIf=\"!isDropdown; else dropdownList\">\n <mat-optgroup\n [label]=\"(translationContext + 'SUGGESTED' | uiTranslate | async)! | uppercase\"\n *ngIf=\"suggestionsList.length\"\n >\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': suggested | includes: value : valueField }\"\n *ngFor=\"let suggested of suggestionsList\"\n [value]=\"suggested\"\n >\n <span [selectText]=\"userInput$ | async\">{{ suggested | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <mat-optgroup\n [label]=\"(translationContext + 'SELECTED' | uiTranslate | async)! | uppercase\"\n *ngIf=\"value?.length && type !== autocompleteType.SINGLE\"\n >\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of value\"\n [value]=\"item\"\n >\n <span>{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n @if (isGrouped) {\n @for (group of itemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n\n <mat-optgroup\n [label]=\"(translationContext + 'SELECTED' | uiTranslate | async)! | uppercase\"\n *ngIf=\"value?.length && type === autocompleteType.SINGLE\"\n >\n <mat-option (mousedown)=\"$event.preventDefault()\" [class]=\"'selected-option'\" [value]=\"value\">\n <span [selectText]=\"userInput$ | async\">{{ value | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n </ng-container>\n\n <ng-template #dropdownList>\n <cdk-virtual-scroll-viewport\n *ngIf=\"virtualScroll || infiniteScroll; else defaultViewPort\"\n [itemSize]=\"48\"\n [style.height.px]=\"getVirtualScrollHeight(itemsList.length)\"\n class=\"virtual-scroll\"\n >\n @if (!isGrouped) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of itemsList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n\n @if (infiniteScroll && hasMoreOptionsForInfiniteScroll) {\n <mat-option class=\"loading-option\" [style.pointer-events]=\"'none'\">\n <div class=\"loading-container\">\n <ui-spinner size=\"small\" [isLoader]=\"false\"></ui-spinner>\n </div>\n </mat-option>\n }\n } @else {\n @for (group of itemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n </cdk-virtual-scroll-viewport>\n\n <ng-template #defaultViewPort>\n @if (!isGrouped) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of itemsList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n } @else {\n @for (group of itemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"filteredSuggestionList$ | async as filteredSuggestionList\">\n <ng-container *ngIf=\"filteredItemsList$ | async as filteredItemsList\">\n <ng-container *ngIf=\"virtualScroll || infiniteScroll; else filteredWithoutVirtualScroll\">\n <cdk-virtual-scroll-viewport\n [itemSize]=\"48\"\n [style.height.px]=\"getVirtualScrollHeight(filteredItemsList.length)\"\n class=\"virtual-scroll\"\n >\n @if (isGrouped && filteredItemsList.length) {\n @for (group of filteredItemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n\n <mat-optgroup\n [label]=\"(translationContext + 'SUGGESTED' | uiTranslate | async)! | uppercase\"\n *ngIf=\"filteredSuggestionList.length\"\n >\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of filteredSuggestionList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <ng-container *ngIf=\"!filteredSuggestionList.length && !isGrouped; else showItemListWithGroupVirtual\">\n @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n </ng-container>\n\n <ng-template #showItemListWithGroupVirtual>\n <mat-optgroup\n [label]=\"(translationContext + 'ALL_ITEMS' | uiTranslate | async)! | uppercase\"\n *ngIf=\"filteredItemsList.length && !isGrouped\"\n >\n @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n </mat-optgroup>\n </ng-template>\n\n @if (isDynamicFilteringEnabled && dynamicFilterLoading) {\n <mat-option class=\"loading-option\" [style.pointer-events]=\"'none'\">\n <div class=\"loading-container\">\n <ui-spinner size=\"small\" [isLoader]=\"false\"></ui-spinner>\n </div>\n </mat-option>\n } @else if (inputValue) {\n @if (allowAdd && !isAlreadyAdded) {\n <mat-option (mousedown)=\"$event.preventDefault()\" [value]=\"inputValue\">\n <span>{{ 'COMMON.ADD' | uiTranslate | async }}</span>\n <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n </mat-option>\n } @else if (!filteredItemsList.length && !filteredSuggestionList.length) {\n <mat-option [style.pointer-events]=\"'none'\">\n <span>{{ translationContext + 'NO_RESULTS_FOUND' | uiTranslate | async }}</span>\n </mat-option>\n }\n }\n </cdk-virtual-scroll-viewport>\n </ng-container>\n\n <ng-template #filteredWithoutVirtualScroll>\n @if (isGrouped && filteredItemsList.length) {\n @for (group of filteredItemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n\n @if (isGrouped && filteredItemsList.length) {\n @for (group of filteredItemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n\n <mat-optgroup\n [label]=\"(translationContext + 'SUGGESTED' | uiTranslate | async)! | uppercase\"\n *ngIf=\"filteredSuggestionList.length\"\n >\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of filteredSuggestionList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <ng-container *ngIf=\"!filteredSuggestionList.length && !isGrouped; else showItemListWithGroup\">\n @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n </ng-container>\n\n <ng-template #showItemListWithGroup>\n <mat-optgroup\n [label]=\"(translationContext + 'ALL_ITEMS' | uiTranslate | async)! | uppercase\"\n *ngIf=\"filteredItemsList.length && !isGrouped\"\n >\n @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n </mat-optgroup>\n </ng-template>\n\n @if (isDynamicFilteringEnabled && dynamicFilterLoading) {\n <mat-option class=\"loading-option\" [style.pointer-events]=\"'none'\">\n <div class=\"loading-container\">\n <ui-spinner size=\"small\" [isLoader]=\"false\"></ui-spinner>\n </div>\n </mat-option>\n } @else if (inputValue) {\n @if (allowAdd && !isAlreadyAdded) {\n <mat-option (mousedown)=\"$event.preventDefault()\" [value]=\"inputValue\">\n <span>{{ 'COMMON.ADD' | uiTranslate | async }}</span>\n <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n </mat-option>\n } @else if (!filteredItemsList.length && !filteredSuggestionList.length) {\n <mat-option [style.pointer-events]=\"'none'\">\n <span>{{ translationContext + 'NO_RESULTS_FOUND' | uiTranslate | async }}</span>\n </mat-option>\n }\n }\n </ng-template>\n </ng-container>\n </ng-container>\n }\n </mat-autocomplete>\n <mat-hint\n class=\"error\"\n *ngIf=\"\n safeErrors.length ||\n (ngControl?.errors | hasValidationError) ||\n (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected ||\n ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue && inputValue !== ' ')\n \"\n >\n <div\n class=\"errors\"\n *ngIf=\"\n (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected ||\n ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue && inputValue !== ' ')\n \"\n >\n <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n <span>{{ translationContext + 'MAX_SELECTED_ERROR' | uiTranslate: { max: maxItemSelected } | async }}</span>\n </div>\n <ng-container *ngIf=\"safeErrors.length\">\n <div class=\"errors\" *ngFor=\"let error of safeErrors; trackBy: trackByFn\">\n <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n <span [innerHTML]=\"error\"></span>\n </div>\n </ng-container>\n <ui-validation-error\n *ngIf=\"ngControl && !hideBuiltInErrors\"\n [ngControl]=\"ngControl\"\n [label]=\"hideLabelInErrors ? null : label\"\n ></ui-validation-error>\n </mat-hint>\n </mat-form-field>\n </div>\n</ng-container>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}:host{width:320px;display:block}:host.full-width{width:100%}:host ui-tag{height:32px;margin:4px}:host ui-tag ::ng-deep .tag-container{margin:0!important}:host ui-tag ::ng-deep .tag-wrapper{max-width:fit-content}.large-size input{margin:10px 0}.large-size .selected-items{margin:5px 0;flex-wrap:wrap}.large-size .input-container{display:flex;flex-direction:column-reverse}.large-size ::ng-deep .mat-mdc-form-field-infix,.large-size .mat-mdc-form-field-flex{align-items:unset!important}.disabled *{pointer-events:none}.input-container{width:100%;margin:auto;display:flex;flex-direction:row-reverse}.input-container .selected-items{display:flex;padding-left:4px}.input-container .selected-items .selected-count{white-space:nowrap}.input-container .selected-items .value-tag{max-width:var(--tag-max-width)}.input-container .selected-items .value-tag ::ng-deep .tag-container{max-width:var(--tag-max-width)}.input-container .selected-items .overlap-count{font-size:14px;line-height:20px}.input-container .selected-items .overlap-count ui-tag{display:block}.input-container .selected-items .overlap-tag{position:absolute;opacity:0}.input-container input{margin-left:6px}.input-container input.unset-margin{margin-top:unset}.input-container input.no-caret{cursor:pointer;caret-color:transparent!important}.add-suggestion{margin:0 5px;color:#000;font-weight:700}.remove-selected{cursor:pointer;margin-right:2px;border-radius:50px;height:fit-content}.remove-selected.large-input-icon{margin-top:10px}.arrow-state{height:24px;cursor:pointer}.arrow-state.large-input-icon{margin-top:10px}.arrow-state.opened{transform:rotateX(180deg)}::ng-deep .autocomplete-wrapper .mat-mdc-form-field{width:100%}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error,::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error svg{color:#cb7b7a}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error{display:flex}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error{display:flex;flex-flow:column;row-gap:4px}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error .errors{display:flex}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error .errors ui-icon{margin-right:8px}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error{color:#e02800!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error svg{color:#e02800!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-bottom-align:before{height:0}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint-wrapper{padding:0 0 12px;font-size:12px;line-height:16px;position:relative}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint-wrapper .mat-form-field-hint-spacer{display:none}::ng-deep .autocomplete-wrapper .mat-mdc-form-field.hide-bottom-content .mat-mdc-form-field-subscript-wrapper{display:none}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-text-field-wrapper.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above{top:28px!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-floating-label{top:22px!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-text-field-wrapper{padding-left:12px!important;height:unset!important;max-height:unset!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-focused .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-floating-label{color:#276678!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch{border-bottom:2px solid #276678!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading{border-left:2px solid #276678!important;border-bottom:2px solid #276678!important;border-top:2px solid #276678!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing{border:2px solid #276678!important;border-left:unset!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-infix,::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-flex{min-height:48px!important;max-height:184px!important;overflow-y:auto;overflow-x:hidden;padding:0!important;display:flex;justify-content:center;text-align:center;align-items:center;flex-direction:row;width:100%}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mdc-line-ripple{display:none!important}::ng-deep .mat-mdc-autocomplete-panel{box-shadow:0 8px 24px 4px #00000014;max-height:312px!important}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option:hover:not(.mdc-list-item--disabled),::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option:focus:not(.mdc-list-item--disabled),::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option.mat-mdc-option-active,::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option.mdc-list-item--selected:not(.mat-mdc-option-multiple):not(.mdc-list-item--disabled){background:#e9f0f1!important}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option{padding-right:32px;padding-left:12px!important}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option ui-icon{display:none;position:absolute;right:0;bottom:calc(50% - 8px);margin:0 10px}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option.selected-option{background:#e9f0f1}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option.selected-option ui-icon{display:block}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option.mdc-list-item--selected .mdc-list-item__primary-text,::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option .mdc-list-item--activated .mdc-list-item__primary-text{color:#000!important}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option .mat-pseudo-checkbox{display:none}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-optgroup .mat-mdc-optgroup-label{font-weight:700!important}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-optgroup .mdc-list-item__primary-text{color:#000;font-size:12px;line-height:16px;font-weight:700}.active-field .mdc-notched-outline__leading{border-left-width:2px;border-top-width:2px;border-bottom-width:2px}.active-field .mdc-notched-outline__notch{border-top-width:2px;border-bottom-width:2px}.active-field .mdc-notched-outline__trailing{border-top-width:2px;border-bottom-width:2px;border-right-width:2px}.loading-option{display:flex}.loading-option .loading-container{display:flex;justify-content:center;align-items:center;width:100%;height:100%;position:absolute;top:0;left:0}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "component", type: i6.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i7.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "component", type: i7.MatOptgroup, selector: "mat-optgroup", inputs: ["label", "disabled"], exportAs: ["matOptgroup"] }, { kind: "directive", type: i6.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i8.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i9.TagComponent, selector: "ui-tag", inputs: ["label", "icon", "allowClose", "readOnly", "isSelected", "showIconWhenSelected", "isDisabled", "applicationTheme", "ariaLabel", "ariaRequired"], outputs: ["close", "press"] }, { kind: "component", type: i10.IconComponent, selector: "ui-icon", inputs: ["size", "cssClass", "name", "color", "filled", "toggleIconStyle", "applicationTheme", "useFullIconName"] }, { kind: "component", type: i11.ValidationErrorComponent, selector: "ui-validation-error", inputs: ["ngControl", "touchedOn", "errorMessage", "label", "applicationTheme"] }, { kind: "directive", type: i12.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i12.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "directive", type: i12.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i13.PreventInputDirective, selector: "[uiPreventInput]", inputs: ["uiPreventInput"] }, { kind: "component", type: i14.SpinnerComponent, selector: "ui-spinner", inputs: ["size", "isLoader", "text", "applicationTheme", "iconName", "iconSize"] }, { kind: "directive", type: i15.SelectTextDirective, selector: "[selectText]", inputs: ["selectText"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i4.SlicePipe, name: "slice" }, { kind: "pipe", type: i16.UiTranslatePipe, name: "uiTranslate" }, { kind: "pipe", type: i17.HasValidationErrorPipe, name: "hasValidationError" }, { kind: "pipe", type: i18.TransformItemPipe, name: "transformItem" }, { kind: "pipe", type: i19.IncludesPipe, name: "includes" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
710
- }
711
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AutocompleteComponent, decorators: [{
712
- type: Component,
713
- args: [{ selector: 'ui-autocomplete', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container>\n <div class=\"autocomplete-wrapper\" [ngClass]=\"{ 'full-width': fullWidth, disabled: disabled }\">\n <mat-form-field\n [color]=\"\n safeErrors.length ||\n (ngControl?.errors && ngControl?.touched) ||\n (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected ||\n ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue && inputValue !== ' ')\n ? 'warn'\n : 'accent'\n \"\n [appearance]=\"'outline'\"\n [ngClass]=\"{\n 'large-size': type === autocompleteType.LARGE,\n 'hide-bottom-content': !showBottomContent,\n 'keyboard-focused': keyboardFocused(),\n 'has-label': !!label,\n }\"\n >\n <mat-label *ngIf=\"label\">{{ label }} <span *ngIf=\"required\">*</span></mat-label>\n <div #formField class=\"input-container\">\n <span\n style=\"position: absolute; left: -9999px\"\n *ngIf=\"textField ? value?.[textField] : value === inputValue\"\n aria-live=\"polite\"\n >{{ ('SELECTED' | uiTranslate | async) + ' ' + inputValue }}</span\n >\n\n <input\n #trigger=\"matAutocompleteTrigger\"\n #matInput\n [attr.maxlength]=\"maxLength !== null && maxLength !== undefined ? maxLength : null\"\n [uiPreventInput]=\"!allowUserInput\"\n [disabled]=\"disabled\"\n [ngClass]=\"{ 'unset-margin': this.value && type === autocompleteType.LARGE, 'no-caret': !allowUserInput }\"\n (blur)=\"refillInput()\"\n (focusin)=\"onFocus()\"\n [attr.aria-label]=\"\n (translationContext + 'SELECTED' | uiTranslate | async) + ' ' + (value | transformItem: textField : true)\n \"\n [style.opacity]=\"type === autocompleteType.MULTI ? inputOpacity : 1\"\n matInput\n [placeholder]=\"value && value.length ? '' : placeholder\"\n [type]=\"'text'\"\n [matAutocomplete]=\"autocomplete\"\n (input)=\"onInputChange($event)\"\n [(ngModel)]=\"inputValue\"\n />\n <div\n class=\"selected-items\"\n #tagContainer\n *ngIf=\"\n (type === autocompleteType.LARGE && this.value) ||\n (!(inputValue && this.isInputFocus) && this.value && type !== autocompleteType.SINGLE)\n \"\n >\n <ui-tag\n class=\"value-tag\"\n [id]=\"'ui-tag-' + i\"\n *ngFor=\"let valueItem of value; let i = index\"\n [label]=\"valueItem | transformItem: textField\"\n [allowClose]=\"true\"\n [applicationTheme]=\"applicationTheme\"\n [style.opacity]=\"type === autocompleteType.MULTI ? inputOpacity : 1\"\n [style.display]=\"\n (isOverLapping && i > 0 && i >= overlapIndex) || (size === 'small' && value.length > 1) ? 'none' : 'block'\n \"\n [ngStyle]=\"{ '--tag-max-width': type === autocompleteType.LARGE ? 'fit-content' : firstTagMaxWidth + 'px' }\"\n [ngClass]=\"{\n 'overlap-tag': isOverlapChecking && overlapIndex && i >= overlapIndex && type === autocompleteType.MULTI,\n }\"\n (close)=\"onOptionRemoved(valueItem)\"\n ></ui-tag>\n @if (size === 'small') {\n <div class=\"selected-count\" *ngIf=\"value.length > 1\">\n {{\n translationContext + 'SELECTED_AMOUNT'\n | uiTranslate: { numberSelected: (value | slice: overlapIndex).length }\n | async\n }}\n </div>\n } @else {\n <div *ngIf=\"value.length > 1 && isOverLapping\" class=\"overlap-count\">\n <ui-tag [applicationTheme]=\"applicationTheme\" [label]=\"'+' + (value.length - overlapIndex)\"></ui-tag>\n </div>\n }\n </div>\n </div>\n\n <ui-icon\n *ngIf=\"\n (clearable && type === autocompleteType.SINGLE && (value?.length || hasObjectValue)) ||\n (type !== autocompleteType.SINGLE &&\n value &&\n value.length > 1 &&\n ((AutocompleteUtils.isPrimitive(value) && value.length) ||\n (!AutocompleteUtils.isPrimitive(value) &&\n ((AutocompleteUtils.isArray(value) && value.length) ||\n (!AutocompleteUtils.isArray(value) && !value.length)))))\n \"\n class=\"remove-selected\"\n [tabIndex]=\"disabled ? -1 : 0\"\n (keydown.enter)=\"onClear(); $event.preventDefault(); $event.stopPropagation()\"\n (keydown.space)=\"onClear(); $event.preventDefault(); $event.stopPropagation()\"\n [ngClass]=\"{ 'large-input-icon': type === autocompleteType.LARGE }\"\n (click)=\"onClear(); $event.preventDefault(); $event.stopPropagation()\"\n [size]=\"'24'\"\n [color]=\"applicationTheme === 'classic' ? 'inherit' : 'rebrand-black'\"\n [attr.aria-label]=\"'COMMON.CLEAR' | uiTranslate | async\"\n [name]=\"applicationTheme === 'classic' ? 'Close' : 'Close-in-line'\"\n ></ui-icon>\n\n <ui-icon\n class=\"arrow-state\"\n [ngClass]=\"{ opened: autocomplete.isOpen, 'large-input-icon': type === autocompleteType.LARGE }\"\n *ngIf=\"isDropdown\"\n [size]=\"'24'\"\n [name]=\"applicationTheme !== 'classic' ? 'Arrow-chevron-down-in-line' : 'Arrow_down'\"\n (click)=\"onChevronClick(autocomplete)\"\n ></ui-icon>\n\n <mat-autocomplete\n #autocomplete\n [class]=\"applicationTheme + ' ' + dropdownPanelClass\"\n (optionSelected)=\"onOptionSelected($event)\"\n [disableRipple]=\"applicationTheme !== 'classic'\"\n [hideSingleSelectionIndicator]=\"false\"\n (opened)=\"gotoUp()\"\n >\n @if (type !== autocompleteType.MULTI || value?.length < maxItemSelected) {\n <ng-container *ngIf=\"!(searchResult$ | async)\">\n <ng-container *ngIf=\"!isDropdown; else dropdownList\">\n <mat-optgroup\n [label]=\"(translationContext + 'SUGGESTED' | uiTranslate | async)! | uppercase\"\n *ngIf=\"suggestionsList.length\"\n >\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': suggested | includes: value : valueField }\"\n *ngFor=\"let suggested of suggestionsList\"\n [value]=\"suggested\"\n >\n <span [selectText]=\"userInput$ | async\">{{ suggested | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <mat-optgroup\n [label]=\"(translationContext + 'SELECTED' | uiTranslate | async)! | uppercase\"\n *ngIf=\"value?.length && type !== autocompleteType.SINGLE\"\n >\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of value\"\n [value]=\"item\"\n >\n <span>{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n @if (isGrouped) {\n @for (group of itemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n\n <mat-optgroup\n [label]=\"(translationContext + 'SELECTED' | uiTranslate | async)! | uppercase\"\n *ngIf=\"value?.length && type === autocompleteType.SINGLE\"\n >\n <mat-option (mousedown)=\"$event.preventDefault()\" [class]=\"'selected-option'\" [value]=\"value\">\n <span [selectText]=\"userInput$ | async\">{{ value | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n </ng-container>\n\n <ng-template #dropdownList>\n <cdk-virtual-scroll-viewport\n *ngIf=\"virtualScroll || infiniteScroll; else defaultViewPort\"\n [itemSize]=\"48\"\n [style.height.px]=\"getVirtualScrollHeight(itemsList.length)\"\n class=\"virtual-scroll\"\n >\n @if (!isGrouped) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of itemsList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n\n @if (infiniteScroll && hasMoreOptionsForInfiniteScroll) {\n <mat-option class=\"loading-option\" [style.pointer-events]=\"'none'\">\n <div class=\"loading-container\">\n <ui-spinner size=\"small\" [isLoader]=\"false\"></ui-spinner>\n </div>\n </mat-option>\n }\n } @else {\n @for (group of itemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n </cdk-virtual-scroll-viewport>\n\n <ng-template #defaultViewPort>\n @if (!isGrouped) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of itemsList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n } @else {\n @for (group of itemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.items\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"filteredSuggestionList$ | async as filteredSuggestionList\">\n <ng-container *ngIf=\"filteredItemsList$ | async as filteredItemsList\">\n <ng-container *ngIf=\"virtualScroll || infiniteScroll; else filteredWithoutVirtualScroll\">\n <cdk-virtual-scroll-viewport\n [itemSize]=\"48\"\n [style.height.px]=\"getVirtualScrollHeight(filteredItemsList.length)\"\n class=\"virtual-scroll\"\n >\n @if (isGrouped && filteredItemsList.length) {\n @for (group of filteredItemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n\n <mat-optgroup\n [label]=\"(translationContext + 'SUGGESTED' | uiTranslate | async)! | uppercase\"\n *ngIf=\"filteredSuggestionList.length\"\n >\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *cdkVirtualFor=\"let item of filteredSuggestionList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <ng-container *ngIf=\"!filteredSuggestionList.length && !isGrouped; else showItemListWithGroupVirtual\">\n @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n </ng-container>\n\n <ng-template #showItemListWithGroupVirtual>\n <mat-optgroup\n [label]=\"(translationContext + 'ALL_ITEMS' | uiTranslate | async)! | uppercase\"\n *ngIf=\"filteredItemsList.length && !isGrouped\"\n >\n @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n </mat-optgroup>\n </ng-template>\n\n @if (isDynamicFilteringEnabled && dynamicFilterLoading) {\n <mat-option class=\"loading-option\" [style.pointer-events]=\"'none'\">\n <div class=\"loading-container\">\n <ui-spinner size=\"small\" [isLoader]=\"false\"></ui-spinner>\n </div>\n </mat-option>\n } @else if (inputValue) {\n @if (allowAdd && !isAlreadyAdded) {\n <mat-option (mousedown)=\"$event.preventDefault()\" [value]=\"inputValue\">\n <span>{{ 'COMMON.ADD' | uiTranslate | async }}</span>\n <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n </mat-option>\n } @else if (!filteredItemsList.length && !filteredSuggestionList.length) {\n <mat-option [style.pointer-events]=\"'none'\">\n <span>{{ translationContext + 'NO_RESULTS_FOUND' | uiTranslate | async }}</span>\n </mat-option>\n }\n }\n </cdk-virtual-scroll-viewport>\n </ng-container>\n\n <ng-template #filteredWithoutVirtualScroll>\n @if (isGrouped && filteredItemsList.length) {\n @for (group of filteredItemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n\n @if (isGrouped && filteredItemsList.length) {\n @for (group of filteredItemsList; track group) {\n @if (group.groupName) {\n <mat-optgroup [label]=\"group.groupName\">\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n } @else {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of group.filteredItems\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n }\n }\n\n <mat-optgroup\n [label]=\"(translationContext + 'SUGGESTED' | uiTranslate | async)! | uppercase\"\n *ngIf=\"filteredSuggestionList.length\"\n >\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n *ngFor=\"let item of filteredSuggestionList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <ng-container *ngIf=\"!filteredSuggestionList.length && !isGrouped; else showItemListWithGroup\">\n @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n </ng-container>\n\n <ng-template #showItemListWithGroup>\n <mat-optgroup\n [label]=\"(translationContext + 'ALL_ITEMS' | uiTranslate | async)! | uppercase\"\n *ngIf=\"filteredItemsList.length && !isGrouped\"\n >\n @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n <mat-option\n (mousedown)=\"$event.preventDefault()\"\n [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n ></ui-icon>\n </mat-option>\n }\n </mat-optgroup>\n </ng-template>\n\n @if (isDynamicFilteringEnabled && dynamicFilterLoading) {\n <mat-option class=\"loading-option\" [style.pointer-events]=\"'none'\">\n <div class=\"loading-container\">\n <ui-spinner size=\"small\" [isLoader]=\"false\"></ui-spinner>\n </div>\n </mat-option>\n } @else if (inputValue) {\n @if (allowAdd && !isAlreadyAdded) {\n <mat-option (mousedown)=\"$event.preventDefault()\" [value]=\"inputValue\">\n <span>{{ 'COMMON.ADD' | uiTranslate | async }}</span>\n <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n </mat-option>\n } @else if (!filteredItemsList.length && !filteredSuggestionList.length) {\n <mat-option [style.pointer-events]=\"'none'\">\n <span>{{ translationContext + 'NO_RESULTS_FOUND' | uiTranslate | async }}</span>\n </mat-option>\n }\n }\n </ng-template>\n </ng-container>\n </ng-container>\n }\n </mat-autocomplete>\n <mat-hint\n class=\"error\"\n *ngIf=\"\n safeErrors.length ||\n (ngControl?.errors | hasValidationError) ||\n (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected ||\n ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue && inputValue !== ' ')\n \"\n >\n <div\n class=\"errors\"\n *ngIf=\"\n (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected ||\n ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue && inputValue !== ' ')\n \"\n >\n <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n <span>{{ translationContext + 'MAX_SELECTED_ERROR' | uiTranslate: { max: maxItemSelected } | async }}</span>\n </div>\n <ng-container *ngIf=\"safeErrors.length\">\n <div class=\"errors\" *ngFor=\"let error of safeErrors; trackBy: trackByFn\">\n <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n <span [innerHTML]=\"error\"></span>\n </div>\n </ng-container>\n <ui-validation-error\n *ngIf=\"ngControl && !hideBuiltInErrors\"\n [ngControl]=\"ngControl\"\n [label]=\"hideLabelInErrors ? null : label\"\n ></ui-validation-error>\n </mat-hint>\n </mat-form-field>\n </div>\n</ng-container>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}:host{width:320px;display:block}:host.full-width{width:100%}:host ui-tag{height:32px;margin:4px}:host ui-tag ::ng-deep .tag-container{margin:0!important}:host ui-tag ::ng-deep .tag-wrapper{max-width:fit-content}.large-size input{margin:10px 0}.large-size .selected-items{margin:5px 0;flex-wrap:wrap}.large-size .input-container{display:flex;flex-direction:column-reverse}.large-size ::ng-deep .mat-mdc-form-field-infix,.large-size .mat-mdc-form-field-flex{align-items:unset!important}.disabled *{pointer-events:none}.input-container{width:100%;margin:auto;display:flex;flex-direction:row-reverse}.input-container .selected-items{display:flex;padding-left:4px}.input-container .selected-items .selected-count{white-space:nowrap}.input-container .selected-items .value-tag{max-width:var(--tag-max-width)}.input-container .selected-items .value-tag ::ng-deep .tag-container{max-width:var(--tag-max-width)}.input-container .selected-items .overlap-count{font-size:14px;line-height:20px}.input-container .selected-items .overlap-count ui-tag{display:block}.input-container .selected-items .overlap-tag{position:absolute;opacity:0}.input-container input{margin-left:6px}.input-container input.unset-margin{margin-top:unset}.input-container input.no-caret{cursor:pointer;caret-color:transparent!important}.add-suggestion{margin:0 5px;color:#000;font-weight:700}.remove-selected{cursor:pointer;margin-right:2px;border-radius:50px;height:fit-content}.remove-selected.large-input-icon{margin-top:10px}.arrow-state{height:24px;cursor:pointer}.arrow-state.large-input-icon{margin-top:10px}.arrow-state.opened{transform:rotateX(180deg)}::ng-deep .autocomplete-wrapper .mat-mdc-form-field{width:100%}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error,::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error svg{color:#cb7b7a}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error{display:flex}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error{display:flex;flex-flow:column;row-gap:4px}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error .errors{display:flex}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error .errors ui-icon{margin-right:8px}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error{color:#e02800!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint.error svg{color:#e02800!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-bottom-align:before{height:0}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint-wrapper{padding:0 0 12px;font-size:12px;line-height:16px;position:relative}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-hint-wrapper .mat-form-field-hint-spacer{display:none}::ng-deep .autocomplete-wrapper .mat-mdc-form-field.hide-bottom-content .mat-mdc-form-field-subscript-wrapper{display:none}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-text-field-wrapper.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above{top:28px!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-floating-label{top:22px!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-text-field-wrapper{padding-left:12px!important;height:unset!important;max-height:unset!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-focused .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-floating-label{color:#276678!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch{border-bottom:2px solid #276678!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading{border-left:2px solid #276678!important;border-bottom:2px solid #276678!important;border-top:2px solid #276678!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing{border:2px solid #276678!important;border-left:unset!important}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-infix,::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mat-mdc-form-field-flex{min-height:48px!important;max-height:184px!important;overflow-y:auto;overflow-x:hidden;padding:0!important;display:flex;justify-content:center;text-align:center;align-items:center;flex-direction:row;width:100%}::ng-deep .autocomplete-wrapper .mat-mdc-form-field .mdc-line-ripple{display:none!important}::ng-deep .mat-mdc-autocomplete-panel{box-shadow:0 8px 24px 4px #00000014;max-height:312px!important}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option:hover:not(.mdc-list-item--disabled),::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option:focus:not(.mdc-list-item--disabled),::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option.mat-mdc-option-active,::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option.mdc-list-item--selected:not(.mat-mdc-option-multiple):not(.mdc-list-item--disabled){background:#e9f0f1!important}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option{padding-right:32px;padding-left:12px!important}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option ui-icon{display:none;position:absolute;right:0;bottom:calc(50% - 8px);margin:0 10px}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option.selected-option{background:#e9f0f1}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option.selected-option ui-icon{display:block}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option.mdc-list-item--selected .mdc-list-item__primary-text,::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option .mdc-list-item--activated .mdc-list-item__primary-text{color:#000!important}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-option .mat-pseudo-checkbox{display:none}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-optgroup .mat-mdc-optgroup-label{font-weight:700!important}::ng-deep .mat-mdc-autocomplete-panel .mat-mdc-optgroup .mdc-list-item__primary-text{color:#000;font-size:12px;line-height:16px;font-weight:700}.active-field .mdc-notched-outline__leading{border-left-width:2px;border-top-width:2px;border-bottom-width:2px}.active-field .mdc-notched-outline__notch{border-top-width:2px;border-bottom-width:2px}.active-field .mdc-notched-outline__trailing{border-top-width:2px;border-bottom-width:2px;border-right-width:2px}.loading-option{display:flex}.loading-option .loading-container{display:flex;justify-content:center;align-items:center;width:100%;height:100%;position:absolute;top:0;left:0}\n"] }]
714
- }], ctorParameters: () => [{ type: undefined, decorators: [{
715
- type: Optional
716
- }, {
717
- type: Inject,
718
- args: ['CANOPYUI_DEFAULT_APPLICATION_THEME']
719
- }] }, { type: i0.ChangeDetectorRef }, { type: i1.DomSanitizer }, { type: i2.NgControl, decorators: [{
720
- type: Optional
721
- }, {
722
- type: Self
723
- }] }, { type: undefined, decorators: [{
724
- type: Inject,
725
- args: [PLATFORM_ID]
726
- }] }, { type: i0.ElementRef }, { type: i3.FocusMonitor }, { type: i0.DestroyRef }, { type: i0.NgZone }], propDecorators: { itemsList: [{
727
- type: Input
728
- }], suggestionsList: [{
729
- type: Input
730
- }], disabled: [{
731
- type: Input
732
- }], allowAdd: [{
733
- type: Input
734
- }], textField: [{
735
- type: Input
736
- }], valueField: [{
737
- type: Input
738
- }], label: [{
739
- type: Input
740
- }], placeholder: [{
741
- type: Input
742
- }], itemValue: [{
743
- type: Input
744
- }], type: [{
745
- type: Input
746
- }], minCharactersSearch: [{
747
- type: Input
748
- }], variant: [{
749
- type: Input,
750
- args: [{ required: true }]
751
- }], showBottomContent: [{
752
- type: Input
753
- }], valuePrimitive: [{
754
- type: Input
755
- }], fullWidth: [{
756
- type: HostBinding,
757
- args: ['class.full-width']
758
- }, {
759
- type: Input
760
- }], applicationTheme: [{
761
- type: HostBinding,
762
- args: ['attr.theme']
763
- }, {
764
- type: Input
765
- }], required: [{
766
- type: Input
767
- }], errors: [{
768
- type: Input
769
- }], companyColor: [{
770
- type: Input
771
- }], hideBuiltInErrors: [{
772
- type: Input
773
- }], hideLabelInErrors: [{
774
- type: Input
775
- }], virtualScroll: [{
776
- type: Input,
777
- args: [{ transform: booleanAttribute }]
778
- }], compareWith: [{
779
- type: Input
780
- }], dropdownPanelClass: [{
781
- type: Input
782
- }], closeOnScroll: [{
783
- type: Input
784
- }], size: [{
785
- type: Input
786
- }], allowUserInput: [{
787
- type: Input
788
- }], clearable: [{
789
- type: Input
790
- }], exactMatchSelect: [{
791
- type: Input
792
- }], maxItemSelected: [{
793
- type: Input
794
- }], maxLength: [{
795
- type: Input
796
- }], isDynamicFilteringEnabled: [{
797
- type: Input
798
- }], dynamicFilterLoading: [{
799
- type: Input
800
- }], dynamicFilteredList: [{
801
- type: Input
802
- }], infiniteScroll: [{
803
- type: Input
804
- }], hasMoreOptionsForInfiniteScroll: [{
805
- type: Input
806
- }], selectionChange: [{
807
- type: Output
808
- }], searchTextChange: [{
809
- type: Output
810
- }], blur: [{
811
- type: Output
812
- }], focus: [{
813
- type: Output
814
- }], scrollViewportBottomReached: [{
815
- type: Output
816
- }], scrollViewportBottomReachedFiltered: [{
817
- type: Output
818
- }], formFieldElement: [{
819
- type: ViewChild,
820
- args: ['formField']
821
- }], tagContainer: [{
822
- type: ViewChild,
823
- args: ['tagContainer']
824
- }], autocomplete: [{
825
- type: ViewChild,
826
- args: ['trigger']
827
- }], cdkVirtualScrollViewport: [{
828
- type: ViewChild,
829
- args: [CdkVirtualScrollViewport, { static: false }]
830
- }], matAutocomplete: [{
831
- type: ViewChild,
832
- args: ['autocomplete']
833
- }], matInput: [{
834
- type: ViewChild,
835
- args: ['matInput']
836
- }] } });
837
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.ts","../../../../../projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport { isPlatformBrowser } from '@angular/common';\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  PLATFORM_ID,\n  Self,\n  signal,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { MatAutocomplete, MatAutocompleteSelectedEvent, MatAutocompleteTrigger } from '@angular/material/autocomplete';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { BehaviorSubject, filter, map, ReplaySubject, startWith, Subscription, take, throttleTime } from 'rxjs';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { IKeyboardEvent } from '../../models/keyboard-events.model';\nimport { AutocompleteUtils } from '../../utils/autocomplete-utils';\nimport {\n  Autocomplete,\n  AutocompleteSize,\n  AutocompleteType,\n  DropdownVariation,\n  DropdownVariationType,\n  Padding,\n  Timeout,\n} from './autocomplete.model';\n\n@Component({\n  selector: 'ui-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\n// eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\nexport class AutocompleteComponent implements ControlValueAccessor, OnChanges, AfterViewInit, DoCheck, OnDestroy {\n  /**\n   * @property itemsList\n   * @description The list of items to display in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() itemsList: any[] | { groupName: string; items: any[]; isGroup: boolean }[] = [];\n\n  /**\n   * @property suggestionsList\n   * @description The list of suggestions to display in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() suggestionsList: any[] = [];\n\n  /**\n   * @property disabled\n   * @description If `true`, the autocomplete is disabled.\n   * @memberof AutocompleteComponent\n   */\n  @Input() disabled = false;\n\n  /**\n   * @property allowAdd\n   * @description If `true`, allows adding new values to the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() allowAdd = true;\n\n  /**\n   * @property textField\n   * @description The field to be used as the display text in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() textField = '';\n\n  /**\n   * @property valueField\n   * @description The field to be used as the value in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() valueField = '';\n\n  /**\n   * @property label\n   * @description The label for the autocomplete input.\n   * @memberof AutocompleteComponent\n   */\n  @Input() label = '';\n\n  /**\n   * @property placeholder\n   * @description The placeholder for the autocomplete input.\n   * @memberof AutocompleteComponent\n   */\n  @Input() placeholder = '';\n\n  /**\n   * @property value\n   * @description The selected value(s) in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() set itemValue(v: any) {\n    this.value = AutocompleteUtils.isArray(v) ? v : v ? [v] : [];\n  }\n\n  /**\n   * @property type\n   * @description The type of the autocomplete ('single', 'multi', etc.).\n   * @memberof AutocompleteComponent\n   */\n  @Input() type: AutocompleteType = 'multi';\n\n  /**\n   * @property minCharactersSearch\n   * @description The minimum characters to trigger search.\n   * @memberof AutocompleteComponent\n   */\n  @Input() minCharactersSearch = 3;\n\n  /**\n   * @property variant\n   * @description The variant of Autocomplete\n   * @memberof AutocompleteComponent\n   */\n  @Input({ required: true }) variant: DropdownVariationType = DropdownVariation.AUTOCOMPLETE;\n\n  /**\n   * Show reserved content below form field\n   * @property showBottomContent\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() showBottomContent = true;\n\n  /**\n   * Return full object if true\n   * @property valuePrimitive\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() valuePrimitive = false;\n\n  /**\n   * Indicator of the autocomplete width\n   * @property fullWidth\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @HostBinding('class.full-width')\n  @Input()\n  fullWidth = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof AutocompleteComponent\n   */\n  @HostBinding('attr.theme')\n  @Input()\n  applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Autocomplete is required or not\n   *\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   * Input field errors\n   *\n   * @type {string[]}\n   * @memberof AutocompleteComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this.safeErrors = errors?.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));\n  }\n\n  /**\n   * Color of the option hover.\n   * Defaults to Test Gorilla primary color.\n   *\n   * @type {string}\n   * @memberof AutocompleteComponent\n   */\n  @Input() companyColor: string | null = '#FFF2FC';\n\n  /**\n   * Hide in-build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof AutocompleteComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof AutocompleteComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  /**\n   * Sets dropdown list to virtual scroll mode\n   *\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input({ transform: booleanAttribute }) virtualScroll = false;\n\n  /**\n   * @property compareWith\n   * @description Custom comparison logic for the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() compareWith: (a: any, b: any) => boolean;\n\n  /**\n   * @property dropdownPanelClass\n   * @description Sets class on autocomplete dropdown\n   * @memberof AutocompleteComponent\n   */\n  @Input() dropdownPanelClass = '';\n\n  /**\n   * @property closeOnScroll\n   * @description Defines if dropdown should be closed on page scroll\n   * @memberof AutocompleteComponent\n   */\n  @Input() closeOnScroll = false;\n\n  /**\n   * @property AutocompleteSize\n   * @description Defines the size of the autocomplete. Small changes the tags to counter; medium is default.\n   * @memberof AutocompleteComponent\n   */\n  @Input() size: AutocompleteSize = 'medium';\n\n  /**\n   * @property allowUserInput\n   * @description If `true`, allows the user to input custom values in the autocomplete.\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() allowUserInput = true;\n\n  /**\n   * @property clearable\n   * @description If `true`, allows the user to clear the input values\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() clearable = true;\n\n  /**\n   * @property exactMatchSelect\n   * @description If `true`, allows to select the exact match from the suggestions list\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() exactMatchSelect = true;\n\n  /**\n   * @property maxItemSelected\n   * @description Sets the maximum number of items that can be selected in the autocomplete\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() maxItemSelected = Infinity;\n\n  /**\n   * @property maxItemSelected\n   * @description Sets the maximum length of the autocomplete input\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() maxLength?: number;\n\n  @Input() isDynamicFilteringEnabled = false;\n  @Input() dynamicFilterLoading = false;\n  @Input() dynamicFilteredList: any[] | null = null;\n\n  @Input() infiniteScroll = false;\n  @Input() hasMoreOptionsForInfiniteScroll = true;\n\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() searchTextChange = new EventEmitter<string>();\n  @Output() blur = new EventEmitter<void>();\n  @Output() focus = new EventEmitter<void>();\n\n  /**\n   * @property scrollViewportBottomReached\n   * @description Emits when the bottom of the unfiltered list is reached during infinite scroll\n   * @memberof AutocompleteComponent\n   */\n  @Output() scrollViewportBottomReached = new EventEmitter<void>();\n\n  /**\n   * @property scrollViewportBottomReachedFiltered\n   * @description Emits when the bottom of the filtered list is reached during infinite scroll\n   * @memberof AutocompleteComponent\n   */\n  @Output() scrollViewportBottomReachedFiltered = new EventEmitter<void>();\n\n  @ViewChild('formField') formFieldElement: ElementRef<HTMLElement>;\n  @ViewChild('tagContainer') tagContainer: ElementRef<HTMLElement>;\n  @ViewChild('trigger') autocomplete: MatAutocompleteTrigger;\n  @ViewChild(CdkVirtualScrollViewport, { static: false }) set cdkVirtualScrollViewport(\n    viewport: CdkVirtualScrollViewport\n  ) {\n    if (this.savedVirtualScrollSubscription) {\n      this.savedVirtualScrollSubscription.unsubscribe();\n    }\n\n    if (viewport) {\n      this.savedVirtualScrollViewport = viewport;\n\n      if (this.infiniteScroll) {\n        setTimeout(() => {\n          this.inputValueSearch$.pipe(take(1)).subscribe(searchValue => {\n            this.isFilteredViewport = !!searchValue;\n          });\n        }, 0);\n\n        this.savedVirtualScrollSubscription = this.savedVirtualScrollViewport\n          .elementScrolled()\n          .pipe(\n            map(() => this.savedVirtualScrollViewport.measureScrollOffset('bottom')),\n            filter(offset => offset < this.savedVirtualScrollViewport.getViewportSize() * 0.2),\n            throttleTime(200),\n            takeUntilDestroyed(this.destroyRef)\n          )\n          .subscribe(() => {\n            if (this.isFilteredViewport) {\n              this.scrollViewportBottomReachedFiltered.emit();\n            } else {\n              this.scrollViewportBottomReached.emit();\n            }\n          });\n      }\n    }\n  }\n  @ViewChild('autocomplete') matAutocomplete: MatAutocomplete;\n  @ViewChild('matInput') matInput: ElementRef<HTMLInputElement>;\n\n  protected safeErrors: SafeHtml[] = [];\n  protected value: any;\n  protected inputValue: any = '';\n  protected isInputFocus = false;\n  protected autocompleteType = Autocomplete;\n  protected isOverLapping = false;\n  protected isOverlapChecking = true;\n  protected overlapIndex = 0;\n  protected inputOpacity = 1;\n  protected firstTagMaxWidth: number = 0;\n  protected inputValueSearch$ = new ReplaySubject<string>(1);\n  protected userInput$ = new ReplaySubject<string>(1);\n  protected dynamicFilteredList$ = new BehaviorSubject<any[] | null>(null);\n  protected filteredItemsList$ = this.inputValueSearch$.pipe(\n    startWith(''),\n    map(inputValue =>\n      inputValue.length\n        ? AutocompleteUtils.filterItems(this.itemsList, inputValue, this.textField, this.isGrouped)\n        : null\n    )\n  );\n  protected filteredSuggestionList$ = this.inputValueSearch$.pipe(\n    map(inputValue =>\n      inputValue.length ? AutocompleteUtils.filterItems(this.suggestionsList, inputValue, this.textField) : null\n    )\n  );\n  protected savedVirtualScrollViewport: CdkVirtualScrollViewport;\n  protected savedVirtualScrollSubscription: Subscription;\n  protected isFilteredViewport = false;\n\n  scrollEvent = (event: any): void => {\n    const isNotAutocompleteScroll =\n      !event.target?.id?.includes('mat-autocomplete-') &&\n      !event.target?.parentElement?.id?.includes('mat-autocomplete-') &&\n      !event.target?.classList?.contains('mat-mdc-autocomplete-trigger');\n\n    if (this.autocomplete.panelOpen && isNotAutocompleteScroll) {\n      this.autocomplete.closePanel();\n    }\n  };\n\n  protected searchResult$ = this.inputValueSearch$.pipe(map(inputValue => !!inputValue.trim()));\n  protected translationContext = 'AUTOCOMPLETE.';\n  protected readonly AutocompleteUtils = AutocompleteUtils;\n  private readonly isPlatform = isPlatformBrowser(this.platformId);\n  private observer: MutationObserver;\n  protected keyboardFocused = signal<boolean>(false);\n  isAlreadyAdded = false;\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly domSanitizer: DomSanitizer,\n    @Optional() @Self() public ngControl: NgControl,\n    @Inject(PLATFORM_ID) private readonly platformId: any,\n    private readonly el: ElementRef,\n    private readonly focusMonitor: FocusMonitor,\n    private readonly destroyRef: DestroyRef,\n    private readonly ngZone: NgZone\n  ) {\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    this.subscriberDisplayChange();\n  }\n\n  ngOnInit(): void {\n    if (this.isDynamicFilteringEnabled) {\n      this.filteredItemsList$ = this.dynamicFilteredList$;\n    }\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\n   * to display validation errors that might happen (e.g. required)\n   */\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngDoCheck(): void {\n    if (this.ngControl?.touched || this.ngControl?.errors) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isDynamicFilteringEnabled) {\n      const dynamicFilteredList = changes['dynamicFilteredList']?.currentValue;\n\n      if (dynamicFilteredList) {\n        this.dynamicFilteredList$.next(dynamicFilteredList);\n      }\n\n      return;\n    }\n\n    if (changes['itemsList'] || changes['suggestionsList'] || changes['valueField']) {\n      this.itemsList = this.isGrouped\n        ? this.itemsList\n        : AutocompleteUtils.excludeSuggestions(this.itemsList, this.suggestionsList, this.valueField);\n      this.initValue();\n    }\n\n    if (this.isPlatform && changes['companyColor']) {\n      this.setCompanyColorVariable();\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngAfterViewInit(): void {\n    if (this.type !== Autocomplete.LARGE) {\n      this.checkOverlap(Timeout.VIEW_INITIALIZED_COMPONENT_LOAD, true);\n    }\n    this.isPlatform && this.setCompanyColorVariable();\n    if (this.closeOnScroll) {\n      window.addEventListener('scroll', this.scrollEvent, true);\n    }\n\n    this.focusMonitor\n      .monitor(this.matInput)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(origin =>\n        this.ngZone.run(() => {\n          this.keyboardFocused.set(origin === 'keyboard');\n        })\n      );\n\n    this.matInput.nativeElement.onkeydown = this.onKeydown.bind(this);\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnDestroy(): void {\n    window.removeEventListener('scroll', this.scrollEvent, true);\n\n    if (this.observer) {\n      this.observer.disconnect();\n    }\n  }\n\n  onChange = (_: any) => {};\n  onTouch = () => {};\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  writeValue(value: any): void {\n    if (this.valuePrimitive && this.textField && this.valueField) {\n      if (this.type === Autocomplete.SINGLE) {\n        this.value = this.itemsList.find(item => item[this.valueField] === value);\n      } else {\n        this.value = AutocompleteUtils.isArray(value)\n          ? this.itemsList.filter(item => value.find((v: any) => v === item[this.valueField]))\n          : [this.itemsList.find(item => item[this.valueField] === value)];\n        this.value = this.value.filter(Boolean).length ? this.value : null;\n      }\n    } else {\n      this.value = value;\n    }\n\n    this.initValue();\n\n    this.cdr.markForCheck();\n  }\n\n  protected get isGrouped(): boolean {\n    return this.itemsList?.some((item: any) => item.isGroup);\n  }\n\n  protected onOptionSelected(event: MatAutocompleteSelectedEvent): void {\n    const inputValue = event.option.value;\n    const itemValue = AutocompleteUtils.createValueItem(inputValue, this.textField, this.valueField);\n    this.addNewValue(itemValue);\n\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n\n    queueMicrotask(() => {\n      if (this.type !== this.autocompleteType.SINGLE) {\n        this.inputValue = '';\n      } else {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);\n      }\n      this.cdr.markForCheck();\n    });\n\n    this.onUpdate();\n  }\n\n  protected onOptionRemoved(option: any): void {\n    setTimeout(() => this.autocomplete.closePanel(), 0);\n    const foundValue = this.value.find((v: any) => (this.compareWith ? this.compareWith(v, option) : v === option));\n\n    if (foundValue) {\n      this.value = this.value.filter((v: any) => (this.compareWith ? !this.compareWith(v, option) : v !== option));\n      this.matAutocomplete.options.forEach(option => {\n        if (option.value?.value === foundValue.value) {\n          option.deselect();\n        }\n      });\n    }\n\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n\n    if (!this.value.length) {\n      this.inputValue = '';\n    }\n\n    this.onUpdate();\n  }\n\n  protected onInputChange(event: Event): void {\n    const inputValue = (event.target as HTMLInputElement).value;\n    this.userInput$.next(inputValue);\n    if (inputValue.length >= this.minCharactersSearch) {\n      this.inputValueSearch$.next(inputValue);\n      this.searchTextChange.emit(inputValue);\n      const itemList = this.isGrouped ? this.itemsList.flatMap(groups => groups.items) : this.itemsList.flat();\n\n      const findValue = [...this.suggestionsList, ...itemList].find(\n        v => inputValue === (this.textField ? v[this.textField] : v)\n      );\n      const count = AutocompleteUtils.countMatchingWords(\n        [...this.suggestionsList, ...itemList],\n        this.inputValue,\n        this.textField\n      );\n      if (findValue && count === 1 && this.exactMatchSelect) {\n        this.onOptionSelected({ option: { value: findValue } } as MatAutocompleteSelectedEvent);\n      }\n    } else {\n      this.inputValueSearch$.next('');\n      this.userInput$.next('');\n    }\n    this.isAlreadyAdded = !!(this.compareWith\n      ? this.value.find((v: any) => this.compareWith(v, inputValue))\n      : AutocompleteUtils.findDuplicate(this.value, inputValue, this.textField));\n  }\n\n  protected onClear(): void {\n    this.inputValue = '';\n    this.value = AutocompleteUtils.isArray(this.value) ? [] : '';\n    this.isOverLapping = false;\n    this.overlapIndex = 0;\n    this.onUpdate();\n    this.matAutocomplete?.options.forEach(option => option.deselect());\n    this.onTouch();\n  }\n\n  protected refillInput(): void {\n    setTimeout(() => {\n      if (this.value && this.type === this.autocompleteType.SINGLE && !this.inputValue) {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);\n      } else if (!this.inputValue && this.value?.length) {\n        this.inputValue = ' ';\n      } else if (this.inputValue && this.type === Autocomplete.SINGLE && this.value && Object.keys(this.value).length) {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(\n          AutocompleteUtils.isArray(this.value) ? this.value[0] : this.value,\n          this.textField\n        );\n      } else if (this.inputValue) {\n        this.inputValue = ' ';\n      }\n\n      this.inputValueSearch$.next('');\n      this.userInput$.next('');\n      this.isInputFocus = false;\n      this.onTouch();\n      this.blur.emit();\n    }, 0);\n  }\n\n  protected gotoUp() {\n    if (this.savedVirtualScrollViewport) {\n      this.savedVirtualScrollViewport.scrollToIndex(0);\n      this.savedVirtualScrollViewport.checkViewportSize();\n    }\n  }\n\n  protected onFocus(): void {\n    this.isInputFocus = true;\n\n    const inputValue = AutocompleteUtils.isArray(this.inputValue) ? this.inputValue[0] : this.inputValue;\n\n    if (AutocompleteUtils.isPrimitive(inputValue)) {\n      if (typeof inputValue !== 'number' && inputValue?.match(/^\\s+/gm)) {\n        this.inputValue = inputValue.trimStart();\n      }\n    } else {\n      if (inputValue[this.textField]?.match(/^\\s+/gm)) {\n        this.inputValue = inputValue[this.textField].trimStart();\n      }\n    }\n    this.focus.emit();\n  }\n\n  private checkOverlap(delay = Timeout.VIEW_INITIALIZED_AFTER_ACTION, init = false): void {\n    this.isOverLapping = false;\n    this.isOverlapChecking = true;\n    this.inputOpacity = 0;\n\n    setTimeout(() => {\n      const inputWidth = this.inputWidth;\n      const tags = this.tagContainer?.nativeElement.querySelectorAll('.value-tag');\n      if (tags) {\n        let width = 0;\n        let firstTagWidth = 0;\n\n        tags.forEach((tag: any, index: number) => {\n          width += tag.getBoundingClientRect().width;\n\n          if (!index) {\n            firstTagWidth = width;\n          }\n\n          const inpWidth = this.formFieldElement?.nativeElement.getBoundingClientRect().width - 20;\n          this.firstTagMaxWidth =\n            tags.length > 1\n              ? inpWidth -\n                (this.variant === DropdownVariation.DROPDOWN\n                  ? Padding.DROPDOWN_SPACE_CONTAINER\n                  : Padding.AUTOCOMPLETE_SPACE_CONTAINER)\n              : inpWidth;\n\n          if (!this.isOverLapping && width > inputWidth && index > 0) {\n            this.isOverLapping = true;\n            this.overlapIndex = index;\n          }\n        });\n        this.isOverlapChecking = false;\n        if (init) {\n          if (this.type === this.autocompleteType.SINGLE) {\n            this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);\n          } else if (this.value?.length) {\n            this.inputValue = ' ';\n          }\n        }\n        const tagContainerWidth = this.tagContainer.nativeElement.getBoundingClientRect().width;\n        this.tagContainer.nativeElement.style.maxWidth = tagContainerWidth / 100 ? '100%' : tagContainerWidth + 'px';\n        this.cdr.markForCheck();\n      }\n      this.inputOpacity = 1;\n    }, delay);\n  }\n\n  private onUpdate(): void {\n    this.inputValueSearch$.next('');\n    this.userInput$.next('');\n    if (!this.valuePrimitive) {\n      this.onChange(this.value);\n    } else {\n      if (this.type === Autocomplete.SINGLE) {\n        this.onChange(this.value[this.valueField]);\n      } else {\n        this.onChange(this.value.map((v: any) => v[this.valueField]));\n      }\n    }\n    this.updateControlMaxLengthValidity();\n    this.selectionChange.emit(this.value);\n  }\n\n  private updateControlMaxLengthValidity(): void {\n    const control = this.ngControl?.control;\n    if (!control) {\n      return;\n    }\n\n    if (this.type !== Autocomplete.SINGLE) {\n      const existingErrors = control.errors || {};\n\n      if (this.value.length > this.maxItemSelected) {\n        control.setErrors({\n          ...existingErrors,\n          maxItemSelected: {\n            expected: this.maxItemSelected,\n            actual: this.value.length,\n          },\n        });\n        control.markAsTouched();\n      } else {\n        if (existingErrors['maxItemSelected']) {\n          delete existingErrors['maxItemSelected'];\n          control.setErrors(Object.keys(existingErrors).length ? existingErrors : null);\n        }\n      }\n    }\n  }\n\n  private initValue(): void {\n    if (this.type === this.autocompleteType.SINGLE && this.variant !== DropdownVariation.DROPDOWN) {\n      if (AutocompleteUtils.isArray(this.value)) {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);\n      } else {\n        this.inputValue = this.value ? AutocompleteUtils.transformDisplayValue(this.value, this.textField) : '';\n      }\n    } else if (this.variant === DropdownVariation.DROPDOWN) {\n      this.inputValue =\n        (AutocompleteUtils.isArray(this.value) && !this.value?.length) || !this.value\n          ? ''\n          : this.type === Autocomplete.SINGLE\n          ? AutocompleteUtils.transformDisplayValue(\n              AutocompleteUtils.isArray(this.value) ? this.value[0] : this.value,\n              this.textField\n            )\n          : ' ';\n    } else {\n      this.inputValue = this.value && this.value.length ? ' ' : '';\n    }\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n  }\n\n  private addNewValue(newValue: any): void {\n    if (this.type !== this.autocompleteType.SINGLE && !this.value) {\n      this.value = [];\n    }\n\n    const foundDuplicate = this.compareWith\n      ? this.value.find((v: any) => this.compareWith(v, newValue))\n      : AutocompleteUtils.findDuplicate(this.value, newValue, this.textField);\n\n    if (this.type !== this.autocompleteType.SINGLE) {\n      this.value = foundDuplicate\n        ? this.value.filter((v: any) =>\n            this.compareWith ? !this.compareWith(v, foundDuplicate) : v !== foundDuplicate\n          )\n        : [...this.value, newValue];\n    } else {\n      this.value = newValue;\n    }\n  }\n\n  protected get isDropdown(): boolean {\n    return this.variant === DropdownVariation.DROPDOWN;\n  }\n\n  protected onChevronClick(autocomplete: MatAutocomplete): void {\n    if (autocomplete.isOpen) {\n      setTimeout(() => {\n        this.autocomplete.closePanel();\n      }, 0);\n    }\n  }\n\n  protected get inputWidth(): number {\n    return (\n      this.formFieldElement?.nativeElement.getBoundingClientRect().width -\n      (this.isDropdown ? Padding.DROPDOWN_CONTAINER : Padding.AUTOCOMPLETE_CONTAINER)\n    );\n  }\n\n  protected trackByFn = (index: number, value: any) => value.changingThisBreaksApplicationSecurity;\n\n  /**\n   * Adding company color variable to the body to style overlay container that's out of the component scope.\n   */\n  private setCompanyColorVariable(): void {\n    document.body.style.setProperty('--ui-autocomplete-option-color', `${this.companyColor}`);\n  }\n\n  private subscriberDisplayChange(): void {\n    const autocompleteHostElement = this.el.nativeElement;\n\n    this.observer = new MutationObserver(mutations => {\n      mutations.forEach(mutation => {\n        if (mutation.attributeName === 'style') {\n          const displayStyle = getComputedStyle(autocompleteHostElement).display;\n          if (displayStyle !== 'none') {\n            this.checkOverlap();\n          }\n        }\n      });\n    });\n\n    this.observer.observe(autocompleteHostElement, {\n      attributes: true,\n      attributeFilter: ['style'],\n    });\n  }\n\n  protected get hasObjectValue(): boolean {\n    return this.value ? !!Object.keys(this.value).length : false;\n  }\n\n  onKeydown($event: KeyboardEvent) {\n    const optionHeight = 48;\n\n    if ($event.key === IKeyboardEvent.HOME) {\n      this.matAutocomplete._keyManager.setFirstItemActive();\n    } else if ($event.key === IKeyboardEvent.END) {\n      this.matAutocomplete._keyManager.setLastItemActive();\n    } else if ($event.key === IKeyboardEvent.PAGE_DOWN) {\n      this.matAutocomplete._keyManager.setNextItemActive();\n      this.matAutocomplete._keyManager.setNextItemActive();\n      this.matAutocomplete._keyManager.setNextItemActive();\n    } else if ($event.key === IKeyboardEvent.PAGE_UP) {\n      this.matAutocomplete._keyManager.setPreviousItemActive();\n      this.matAutocomplete._keyManager.setPreviousItemActive();\n      this.matAutocomplete._keyManager.setPreviousItemActive();\n    }\n\n    this.matAutocomplete._setScrollTop(this.matAutocomplete._keyManager.activeItemIndex! * optionHeight);\n  }\n\n  protected getVirtualScrollHeight(itemCount: number): number {\n    const itemHeight = 48;\n    const maxHeight = 200;\n    const minHeight = 48;\n\n    const calculatedHeight = itemCount * itemHeight;\n\n    return Math.min(Math.max(calculatedHeight, minHeight), maxHeight);\n  }\n}\n","<ng-container>\n  <div class=\"autocomplete-wrapper\" [ngClass]=\"{ 'full-width': fullWidth, disabled: disabled }\">\n    <mat-form-field\n      [color]=\"\n        safeErrors.length ||\n        (ngControl?.errors && ngControl?.touched) ||\n        (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected ||\n        ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue && inputValue !== ' ')\n          ? 'warn'\n          : 'accent'\n      \"\n      [appearance]=\"'outline'\"\n      [ngClass]=\"{\n        'large-size': type === autocompleteType.LARGE,\n        'hide-bottom-content': !showBottomContent,\n        'keyboard-focused': keyboardFocused(),\n        'has-label': !!label,\n      }\"\n    >\n      <mat-label *ngIf=\"label\">{{ label }} <span *ngIf=\"required\">*</span></mat-label>\n      <div #formField class=\"input-container\">\n        <span\n          style=\"position: absolute; left: -9999px\"\n          *ngIf=\"textField ? value?.[textField] : value === inputValue\"\n          aria-live=\"polite\"\n          >{{ ('SELECTED' | uiTranslate | async) + ' ' + inputValue }}</span\n        >\n\n        <input\n          #trigger=\"matAutocompleteTrigger\"\n          #matInput\n          [attr.maxlength]=\"maxLength !== null && maxLength !== undefined ? maxLength : null\"\n          [uiPreventInput]=\"!allowUserInput\"\n          [disabled]=\"disabled\"\n          [ngClass]=\"{ 'unset-margin': this.value && type === autocompleteType.LARGE, 'no-caret': !allowUserInput }\"\n          (blur)=\"refillInput()\"\n          (focusin)=\"onFocus()\"\n          [attr.aria-label]=\"\n            (translationContext + 'SELECTED' | uiTranslate | async) + ' ' + (value | transformItem: textField : true)\n          \"\n          [style.opacity]=\"type === autocompleteType.MULTI ? inputOpacity : 1\"\n          matInput\n          [placeholder]=\"value && value.length ? '' : placeholder\"\n          [type]=\"'text'\"\n          [matAutocomplete]=\"autocomplete\"\n          (input)=\"onInputChange($event)\"\n          [(ngModel)]=\"inputValue\"\n        />\n        <div\n          class=\"selected-items\"\n          #tagContainer\n          *ngIf=\"\n            (type === autocompleteType.LARGE && this.value) ||\n            (!(inputValue && this.isInputFocus) && this.value && type !== autocompleteType.SINGLE)\n          \"\n        >\n          <ui-tag\n            class=\"value-tag\"\n            [id]=\"'ui-tag-' + i\"\n            *ngFor=\"let valueItem of value; let i = index\"\n            [label]=\"valueItem | transformItem: textField\"\n            [allowClose]=\"true\"\n            [applicationTheme]=\"applicationTheme\"\n            [style.opacity]=\"type === autocompleteType.MULTI ? inputOpacity : 1\"\n            [style.display]=\"\n              (isOverLapping && i > 0 && i >= overlapIndex) || (size === 'small' && value.length > 1) ? 'none' : 'block'\n            \"\n            [ngStyle]=\"{ '--tag-max-width': type === autocompleteType.LARGE ? 'fit-content' : firstTagMaxWidth + 'px' }\"\n            [ngClass]=\"{\n              'overlap-tag': isOverlapChecking && overlapIndex && i >= overlapIndex && type === autocompleteType.MULTI,\n            }\"\n            (close)=\"onOptionRemoved(valueItem)\"\n          ></ui-tag>\n          @if (size === 'small') {\n            <div class=\"selected-count\" *ngIf=\"value.length > 1\">\n              {{\n                translationContext + 'SELECTED_AMOUNT'\n                  | uiTranslate: { numberSelected: (value | slice: overlapIndex).length }\n                  | async\n              }}\n            </div>\n          } @else {\n            <div *ngIf=\"value.length > 1 && isOverLapping\" class=\"overlap-count\">\n              <ui-tag [applicationTheme]=\"applicationTheme\" [label]=\"'+' + (value.length - overlapIndex)\"></ui-tag>\n            </div>\n          }\n        </div>\n      </div>\n\n      <ui-icon\n        *ngIf=\"\n          (clearable && type === autocompleteType.SINGLE && (value?.length || hasObjectValue)) ||\n          (type !== autocompleteType.SINGLE &&\n            value &&\n            value.length > 1 &&\n            ((AutocompleteUtils.isPrimitive(value) && value.length) ||\n              (!AutocompleteUtils.isPrimitive(value) &&\n                ((AutocompleteUtils.isArray(value) && value.length) ||\n                  (!AutocompleteUtils.isArray(value) && !value.length)))))\n        \"\n        class=\"remove-selected\"\n        [tabIndex]=\"disabled ? -1 : 0\"\n        (keydown.enter)=\"onClear(); $event.preventDefault(); $event.stopPropagation()\"\n        (keydown.space)=\"onClear(); $event.preventDefault(); $event.stopPropagation()\"\n        [ngClass]=\"{ 'large-input-icon': type === autocompleteType.LARGE }\"\n        (click)=\"onClear(); $event.preventDefault(); $event.stopPropagation()\"\n        [size]=\"'24'\"\n        [color]=\"applicationTheme === 'classic' ? 'inherit' : 'rebrand-black'\"\n        [attr.aria-label]=\"'COMMON.CLEAR' | uiTranslate | async\"\n        [name]=\"applicationTheme === 'classic' ? 'Close' : 'Close-in-line'\"\n      ></ui-icon>\n\n      <ui-icon\n        class=\"arrow-state\"\n        [ngClass]=\"{ opened: autocomplete.isOpen, 'large-input-icon': type === autocompleteType.LARGE }\"\n        *ngIf=\"isDropdown\"\n        [size]=\"'24'\"\n        [name]=\"applicationTheme !== 'classic' ? 'Arrow-chevron-down-in-line' : 'Arrow_down'\"\n        (click)=\"onChevronClick(autocomplete)\"\n      ></ui-icon>\n\n      <mat-autocomplete\n        #autocomplete\n        [class]=\"applicationTheme + ' ' + dropdownPanelClass\"\n        (optionSelected)=\"onOptionSelected($event)\"\n        [disableRipple]=\"applicationTheme !== 'classic'\"\n        [hideSingleSelectionIndicator]=\"false\"\n        (opened)=\"gotoUp()\"\n      >\n        @if (type !== autocompleteType.MULTI || value?.length < maxItemSelected) {\n          <ng-container *ngIf=\"!(searchResult$ | async)\">\n            <ng-container *ngIf=\"!isDropdown; else dropdownList\">\n              <mat-optgroup\n                [label]=\"(translationContext + 'SUGGESTED' | uiTranslate | async)! | uppercase\"\n                *ngIf=\"suggestionsList.length\"\n              >\n                <mat-option\n                  (mousedown)=\"$event.preventDefault()\"\n                  [ngClass]=\"{ 'selected-option': suggested | includes: value : valueField }\"\n                  *ngFor=\"let suggested of suggestionsList\"\n                  [value]=\"suggested\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ suggested | transformItem: textField }}</span>\n                  <ui-icon\n                    [applicationTheme]=\"applicationTheme\"\n                    [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                  ></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n\n              <mat-optgroup\n                [label]=\"(translationContext + 'SELECTED' | uiTranslate | async)! | uppercase\"\n                *ngIf=\"value?.length && type !== autocompleteType.SINGLE\"\n              >\n                <mat-option\n                  (mousedown)=\"$event.preventDefault()\"\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *ngFor=\"let item of value\"\n                  [value]=\"item\"\n                >\n                  <span>{{ item | transformItem: textField }}</span>\n                  <ui-icon\n                    [applicationTheme]=\"applicationTheme\"\n                    [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                  ></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n\n              @if (isGrouped) {\n                @for (group of itemsList; track group) {\n                  @if (group.groupName) {\n                    <mat-optgroup [label]=\"group.groupName\">\n                      <mat-option\n                        (mousedown)=\"$event.preventDefault()\"\n                        [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                        *ngFor=\"let item of group.items\"\n                        [value]=\"item\"\n                      >\n                        <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                        <ui-icon\n                          [applicationTheme]=\"applicationTheme\"\n                          [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                        ></ui-icon>\n                      </mat-option>\n                    </mat-optgroup>\n                  } @else {\n                    <mat-option\n                      (mousedown)=\"$event.preventDefault()\"\n                      [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                      *ngFor=\"let item of group.items\"\n                      [value]=\"item\"\n                    >\n                      <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                      <ui-icon\n                        [applicationTheme]=\"applicationTheme\"\n                        [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                      ></ui-icon>\n                    </mat-option>\n                  }\n                }\n              }\n\n              <mat-optgroup\n                [label]=\"(translationContext + 'SELECTED' | uiTranslate | async)! | uppercase\"\n                *ngIf=\"value?.length && type === autocompleteType.SINGLE\"\n              >\n                <mat-option (mousedown)=\"$event.preventDefault()\" [class]=\"'selected-option'\" [value]=\"value\">\n                  <span [selectText]=\"userInput$ | async\">{{ value | transformItem: textField }}</span>\n                  <ui-icon\n                    [applicationTheme]=\"applicationTheme\"\n                    [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                  ></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n            </ng-container>\n\n            <ng-template #dropdownList>\n              <cdk-virtual-scroll-viewport\n                *ngIf=\"virtualScroll || infiniteScroll; else defaultViewPort\"\n                [itemSize]=\"48\"\n                [style.height.px]=\"getVirtualScrollHeight(itemsList.length)\"\n                class=\"virtual-scroll\"\n              >\n                @if (!isGrouped) {\n                  <mat-option\n                    (mousedown)=\"$event.preventDefault()\"\n                    [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                    *cdkVirtualFor=\"let item of itemsList\"\n                    [value]=\"item\"\n                  >\n                    <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                    ></ui-icon>\n                  </mat-option>\n\n                  @if (infiniteScroll && hasMoreOptionsForInfiniteScroll) {\n                    <mat-option class=\"loading-option\" [style.pointer-events]=\"'none'\">\n                      <div class=\"loading-container\">\n                        <ui-spinner size=\"small\" [isLoader]=\"false\"></ui-spinner>\n                      </div>\n                    </mat-option>\n                  }\n                } @else {\n                  @for (group of itemsList; track group) {\n                    @if (group.groupName) {\n                      <mat-optgroup [label]=\"group.groupName\">\n                        <mat-option\n                          (mousedown)=\"$event.preventDefault()\"\n                          [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                          *cdkVirtualFor=\"let item of group.items\"\n                          [value]=\"item\"\n                        >\n                          <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                          <ui-icon\n                            [applicationTheme]=\"applicationTheme\"\n                            [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                          ></ui-icon>\n                        </mat-option>\n                      </mat-optgroup>\n                    } @else {\n                      <mat-option\n                        (mousedown)=\"$event.preventDefault()\"\n                        [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                        *cdkVirtualFor=\"let item of group.items\"\n                        [value]=\"item\"\n                      >\n                        <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                        <ui-icon\n                          [applicationTheme]=\"applicationTheme\"\n                          [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                        ></ui-icon>\n                      </mat-option>\n                    }\n                  }\n                }\n              </cdk-virtual-scroll-viewport>\n\n              <ng-template #defaultViewPort>\n                @if (!isGrouped) {\n                  <mat-option\n                    (mousedown)=\"$event.preventDefault()\"\n                    [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                    *ngFor=\"let item of itemsList\"\n                    [value]=\"item\"\n                  >\n                    <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                    ></ui-icon>\n                  </mat-option>\n                } @else {\n                  @for (group of itemsList; track group) {\n                    @if (group.groupName) {\n                      <mat-optgroup [label]=\"group.groupName\">\n                        <mat-option\n                          (mousedown)=\"$event.preventDefault()\"\n                          [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                          *ngFor=\"let item of group.items\"\n                          [value]=\"item\"\n                        >\n                          <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                          <ui-icon\n                            [applicationTheme]=\"applicationTheme\"\n                            [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                          ></ui-icon>\n                        </mat-option>\n                      </mat-optgroup>\n                    } @else {\n                      <mat-option\n                        (mousedown)=\"$event.preventDefault()\"\n                        [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                        *ngFor=\"let item of group.items\"\n                        [value]=\"item\"\n                      >\n                        <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                        <ui-icon\n                          [applicationTheme]=\"applicationTheme\"\n                          [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                        ></ui-icon>\n                      </mat-option>\n                    }\n                  }\n                }\n              </ng-template>\n            </ng-template>\n          </ng-container>\n\n          <ng-container *ngIf=\"filteredSuggestionList$ | async as filteredSuggestionList\">\n            <ng-container *ngIf=\"filteredItemsList$ | async as filteredItemsList\">\n              <ng-container *ngIf=\"virtualScroll || infiniteScroll; else filteredWithoutVirtualScroll\">\n                <cdk-virtual-scroll-viewport\n                  [itemSize]=\"48\"\n                  [style.height.px]=\"getVirtualScrollHeight(filteredItemsList.length)\"\n                  class=\"virtual-scroll\"\n                >\n                  @if (isGrouped && filteredItemsList.length) {\n                    @for (group of filteredItemsList; track group) {\n                      @if (group.groupName) {\n                        <mat-optgroup [label]=\"group.groupName\">\n                          <mat-option\n                            (mousedown)=\"$event.preventDefault()\"\n                            [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                            *cdkVirtualFor=\"let item of group.filteredItems\"\n                            [value]=\"item\"\n                          >\n                            <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                            <ui-icon\n                              [applicationTheme]=\"applicationTheme\"\n                              [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                            ></ui-icon>\n                          </mat-option>\n                        </mat-optgroup>\n                      } @else {\n                        <mat-option\n                          (mousedown)=\"$event.preventDefault()\"\n                          [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                          *cdkVirtualFor=\"let item of group.filteredItems\"\n                          [value]=\"item\"\n                        >\n                          <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                          <ui-icon\n                            [applicationTheme]=\"applicationTheme\"\n                            [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                          ></ui-icon>\n                        </mat-option>\n                      }\n                    }\n                  }\n\n                  <mat-optgroup\n                    [label]=\"(translationContext + 'SUGGESTED' | uiTranslate | async)! | uppercase\"\n                    *ngIf=\"filteredSuggestionList.length\"\n                  >\n                    <mat-option\n                      (mousedown)=\"$event.preventDefault()\"\n                      [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                      *cdkVirtualFor=\"let item of filteredSuggestionList\"\n                      [value]=\"item\"\n                    >\n                      <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                      <ui-icon\n                        [applicationTheme]=\"applicationTheme\"\n                        [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                      ></ui-icon>\n                    </mat-option>\n                  </mat-optgroup>\n\n                  <ng-container *ngIf=\"!filteredSuggestionList.length && !isGrouped; else showItemListWithGroupVirtual\">\n                    @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n                      <mat-option\n                        (mousedown)=\"$event.preventDefault()\"\n                        [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                        [value]=\"item\"\n                      >\n                        <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                        <ui-icon\n                          [applicationTheme]=\"applicationTheme\"\n                          [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                        ></ui-icon>\n                      </mat-option>\n                    }\n                  </ng-container>\n\n                  <ng-template #showItemListWithGroupVirtual>\n                    <mat-optgroup\n                      [label]=\"(translationContext + 'ALL_ITEMS' | uiTranslate | async)! | uppercase\"\n                      *ngIf=\"filteredItemsList.length && !isGrouped\"\n                    >\n                      @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n                        <mat-option\n                          (mousedown)=\"$event.preventDefault()\"\n                          [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                          [value]=\"item\"\n                        >\n                          <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                          <ui-icon\n                            [applicationTheme]=\"applicationTheme\"\n                            [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                          ></ui-icon>\n                        </mat-option>\n                      }\n                    </mat-optgroup>\n                  </ng-template>\n\n                  @if (isDynamicFilteringEnabled && dynamicFilterLoading) {\n                    <mat-option class=\"loading-option\" [style.pointer-events]=\"'none'\">\n                      <div class=\"loading-container\">\n                        <ui-spinner size=\"small\" [isLoader]=\"false\"></ui-spinner>\n                      </div>\n                    </mat-option>\n                  } @else if (inputValue) {\n                    @if (allowAdd && !isAlreadyAdded) {\n                      <mat-option (mousedown)=\"$event.preventDefault()\" [value]=\"inputValue\">\n                        <span>{{ 'COMMON.ADD' | uiTranslate | async }}</span>\n                        <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n                      </mat-option>\n                    } @else if (!filteredItemsList.length && !filteredSuggestionList.length) {\n                      <mat-option [style.pointer-events]=\"'none'\">\n                        <span>{{ translationContext + 'NO_RESULTS_FOUND' | uiTranslate | async }}</span>\n                      </mat-option>\n                    }\n                  }\n                </cdk-virtual-scroll-viewport>\n              </ng-container>\n\n              <ng-template #filteredWithoutVirtualScroll>\n                @if (isGrouped && filteredItemsList.length) {\n                  @for (group of filteredItemsList; track group) {\n                    @if (group.groupName) {\n                      <mat-optgroup [label]=\"group.groupName\">\n                        <mat-option\n                          (mousedown)=\"$event.preventDefault()\"\n                          [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                          *ngFor=\"let item of group.filteredItems\"\n                          [value]=\"item\"\n                        >\n                          <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                          <ui-icon\n                            [applicationTheme]=\"applicationTheme\"\n                            [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                          ></ui-icon>\n                        </mat-option>\n                      </mat-optgroup>\n                    } @else {\n                      <mat-option\n                        (mousedown)=\"$event.preventDefault()\"\n                        [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                        *ngFor=\"let item of group.filteredItems\"\n                        [value]=\"item\"\n                      >\n                        <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                        <ui-icon\n                          [applicationTheme]=\"applicationTheme\"\n                          [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                        ></ui-icon>\n                      </mat-option>\n                    }\n                  }\n                }\n\n                @if (isGrouped && filteredItemsList.length) {\n                  @for (group of filteredItemsList; track group) {\n                    @if (group.groupName) {\n                      <mat-optgroup [label]=\"group.groupName\">\n                        <mat-option\n                          (mousedown)=\"$event.preventDefault()\"\n                          [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                          *ngFor=\"let item of group.filteredItems\"\n                          [value]=\"item\"\n                        >\n                          <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                          <ui-icon\n                            [applicationTheme]=\"applicationTheme\"\n                            [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                          ></ui-icon>\n                        </mat-option>\n                      </mat-optgroup>\n                    } @else {\n                      <mat-option\n                        (mousedown)=\"$event.preventDefault()\"\n                        [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                        *ngFor=\"let item of group.filteredItems\"\n                        [value]=\"item\"\n                      >\n                        <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                        <ui-icon\n                          [applicationTheme]=\"applicationTheme\"\n                          [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                        ></ui-icon>\n                      </mat-option>\n                    }\n                  }\n                }\n\n                <mat-optgroup\n                  [label]=\"(translationContext + 'SUGGESTED' | uiTranslate | async)! | uppercase\"\n                  *ngIf=\"filteredSuggestionList.length\"\n                >\n                  <mat-option\n                    (mousedown)=\"$event.preventDefault()\"\n                    [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                    *ngFor=\"let item of filteredSuggestionList\"\n                    [value]=\"item\"\n                  >\n                    <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                    ></ui-icon>\n                  </mat-option>\n                </mat-optgroup>\n\n                <ng-container *ngIf=\"!filteredSuggestionList.length && !isGrouped; else showItemListWithGroup\">\n                  @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n                    <mat-option\n                      (mousedown)=\"$event.preventDefault()\"\n                      [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                      [value]=\"item\"\n                    >\n                      <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                      <ui-icon\n                        [applicationTheme]=\"applicationTheme\"\n                        [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                      ></ui-icon>\n                    </mat-option>\n                  }\n                </ng-container>\n\n                <ng-template #showItemListWithGroup>\n                  <mat-optgroup\n                    [label]=\"(translationContext + 'ALL_ITEMS' | uiTranslate | async)! | uppercase\"\n                    *ngIf=\"filteredItemsList.length && !isGrouped\"\n                  >\n                    @for (item of filteredItemsList; let idx = $index; track item[valueField] || idx) {\n                      <mat-option\n                        (mousedown)=\"$event.preventDefault()\"\n                        [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                        [value]=\"item\"\n                      >\n                        <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                        <ui-icon\n                          [applicationTheme]=\"applicationTheme\"\n                          [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"\n                        ></ui-icon>\n                      </mat-option>\n                    }\n                  </mat-optgroup>\n                </ng-template>\n\n                @if (isDynamicFilteringEnabled && dynamicFilterLoading) {\n                  <mat-option class=\"loading-option\" [style.pointer-events]=\"'none'\">\n                    <div class=\"loading-container\">\n                      <ui-spinner size=\"small\" [isLoader]=\"false\"></ui-spinner>\n                    </div>\n                  </mat-option>\n                } @else if (inputValue) {\n                  @if (allowAdd && !isAlreadyAdded) {\n                    <mat-option (mousedown)=\"$event.preventDefault()\" [value]=\"inputValue\">\n                      <span>{{ 'COMMON.ADD' | uiTranslate | async }}</span>\n                      <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n                    </mat-option>\n                  } @else if (!filteredItemsList.length && !filteredSuggestionList.length) {\n                    <mat-option [style.pointer-events]=\"'none'\">\n                      <span>{{ translationContext + 'NO_RESULTS_FOUND' | uiTranslate | async }}</span>\n                    </mat-option>\n                  }\n                }\n              </ng-template>\n            </ng-container>\n          </ng-container>\n        }\n      </mat-autocomplete>\n      <mat-hint\n        class=\"error\"\n        *ngIf=\"\n          safeErrors.length ||\n          (ngControl?.errors | hasValidationError) ||\n          (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected ||\n          ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue && inputValue !== ' ')\n        \"\n      >\n        <div\n          class=\"errors\"\n          *ngIf=\"\n            (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected ||\n            ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue && inputValue !== ' ')\n          \"\n        >\n          <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n          <span>{{ translationContext + 'MAX_SELECTED_ERROR' | uiTranslate: { max: maxItemSelected } | async }}</span>\n        </div>\n        <ng-container *ngIf=\"safeErrors.length\">\n          <div class=\"errors\" *ngFor=\"let error of safeErrors; trackBy: trackByFn\">\n            <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n            <span [innerHTML]=\"error\"></span>\n          </div>\n        </ng-container>\n        <ui-validation-error\n          *ngIf=\"ngControl && !hideBuiltInErrors\"\n          [ngControl]=\"ngControl\"\n          [label]=\"hideLabelInErrors ? null : label\"\n        ></ui-validation-error>\n      </mat-hint>\n    </mat-form-field>\n  </div>\n</ng-container>\n"]}