@ardium-ui/ui 1.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 (491) hide show
  1. package/README.md +25 -0
  2. package/esm2022/ardium-ui-ui.mjs +5 -0
  3. package/esm2022/lib/_internal/boolean-component.mjs +108 -0
  4. package/esm2022/lib/_internal/clear-button/clear-button.component.mjs +12 -0
  5. package/esm2022/lib/_internal/clear-button/clear-button.module.mjs +18 -0
  6. package/esm2022/lib/_internal/disablable-component.mjs +44 -0
  7. package/esm2022/lib/_internal/focusable-component.mjs +91 -0
  8. package/esm2022/lib/_internal/item-storages/dropdown-item-storage.mjs +436 -0
  9. package/esm2022/lib/_internal/item-storages/simple-item-storage.mjs +349 -0
  10. package/esm2022/lib/_internal/item-storages/simplest-item-storage.mjs +155 -0
  11. package/esm2022/lib/_internal/models/pagination.model.mjs +124 -0
  12. package/esm2022/lib/_internal/ngmodel-component.mjs +42 -0
  13. package/esm2022/lib/_internal/queue.mjs +59 -0
  14. package/esm2022/lib/_internal/selectable-list-component.mjs +304 -0
  15. package/esm2022/lib/badge/badge.directive.mjs +123 -0
  16. package/esm2022/lib/badge/badge.module.mjs +18 -0
  17. package/esm2022/lib/badge/badge.types.mjs +16 -0
  18. package/esm2022/lib/buttons/_button-base.mjs +45 -0
  19. package/esm2022/lib/buttons/button/button.component.mjs +49 -0
  20. package/esm2022/lib/buttons/button/button.module.mjs +18 -0
  21. package/esm2022/lib/buttons/fab/fab.component.mjs +40 -0
  22. package/esm2022/lib/buttons/fab/fab.module.mjs +18 -0
  23. package/esm2022/lib/buttons/general-button.types.mjs +55 -0
  24. package/esm2022/lib/buttons/icon-button/icon-button.component.mjs +37 -0
  25. package/esm2022/lib/buttons/icon-button/icon-button.module.mjs +18 -0
  26. package/esm2022/lib/calendar/calendar.component.mjs +982 -0
  27. package/esm2022/lib/calendar/calendar.directives.mjs +107 -0
  28. package/esm2022/lib/calendar/calendar.helpers.mjs +47 -0
  29. package/esm2022/lib/calendar/calendar.module.mjs +21 -0
  30. package/esm2022/lib/calendar/calendar.types.mjs +11 -0
  31. package/esm2022/lib/card/card.children.mjs +97 -0
  32. package/esm2022/lib/card/card.component.mjs +40 -0
  33. package/esm2022/lib/card/card.module.mjs +59 -0
  34. package/esm2022/lib/card/card.types.mjs +9 -0
  35. package/esm2022/lib/checkbox/checkbox.component.mjs +73 -0
  36. package/esm2022/lib/checkbox/checkbox.module.mjs +18 -0
  37. package/esm2022/lib/checkbox/checkbox.types.mjs +6 -0
  38. package/esm2022/lib/checkbox-list/checkbox-list.component.mjs +139 -0
  39. package/esm2022/lib/checkbox-list/checkbox-list.module.mjs +19 -0
  40. package/esm2022/lib/checkbox-list/checkbox-list.types.mjs +7 -0
  41. package/esm2022/lib/chip/chip.component.mjs +55 -0
  42. package/esm2022/lib/chip/chip.module.mjs +21 -0
  43. package/esm2022/lib/chip/deletable-chip/deletable-chip.component.mjs +80 -0
  44. package/esm2022/lib/chip/selectable-chip/selectable-chip.component.mjs +77 -0
  45. package/esm2022/lib/color/color-display/color-display.component.mjs +48 -0
  46. package/esm2022/lib/color/color-display/color-display.module.mjs +18 -0
  47. package/esm2022/lib/color/color-display/color-display.types.mjs +9 -0
  48. package/esm2022/lib/color/color-picker/color-picker.component.mjs +484 -0
  49. package/esm2022/lib/color/color-picker/color-picker.directives.mjs +55 -0
  50. package/esm2022/lib/color/color-picker/color-picker.module.mjs +43 -0
  51. package/esm2022/lib/color/color-picker/color-picker.types.mjs +11 -0
  52. package/esm2022/lib/dialog/dialog.component.mjs +167 -0
  53. package/esm2022/lib/dialog/dialog.directives.mjs +14 -0
  54. package/esm2022/lib/dialog/dialog.module.mjs +21 -0
  55. package/esm2022/lib/dialog/dialog.types.mjs +6 -0
  56. package/esm2022/lib/divider/divider.component.mjs +26 -0
  57. package/esm2022/lib/divider/divider.module.mjs +18 -0
  58. package/esm2022/lib/dropdown-panel/dropdown-panel.component.mjs +130 -0
  59. package/esm2022/lib/dropdown-panel/dropdown-panel.module.mjs +18 -0
  60. package/esm2022/lib/dropdown-panel/dropdown-panel.types.mjs +10 -0
  61. package/esm2022/lib/file-inputs/file-drop-area/file-drop-area.component.mjs +82 -0
  62. package/esm2022/lib/file-inputs/file-drop-area/file-drop-area.directives.mjs +42 -0
  63. package/esm2022/lib/file-inputs/file-drop-area/file-drop-area.module.mjs +58 -0
  64. package/esm2022/lib/file-inputs/file-input/file-input.component.mjs +153 -0
  65. package/esm2022/lib/file-inputs/file-input/file-input.directives.mjs +73 -0
  66. package/esm2022/lib/file-inputs/file-input/file-input.module.mjs +21 -0
  67. package/esm2022/lib/file-inputs/file-input-base.mjs +187 -0
  68. package/esm2022/lib/file-inputs/file-input-types.mjs +2 -0
  69. package/esm2022/lib/form-field-frame/form-field-frame.component.mjs +74 -0
  70. package/esm2022/lib/form-field-frame/form-field-frame.directives.mjs +25 -0
  71. package/esm2022/lib/form-field-frame/form-field-frame.module.mjs +19 -0
  72. package/esm2022/lib/icon/icon.component.mjs +85 -0
  73. package/esm2022/lib/icon/icon.module.mjs +19 -0
  74. package/esm2022/lib/icon/icon.pipe.mjs +18 -0
  75. package/esm2022/lib/inputs/color-input/color-input.component.mjs +421 -0
  76. package/esm2022/lib/inputs/color-input/color-input.directives.mjs +101 -0
  77. package/esm2022/lib/inputs/color-input/color-input.module.mjs +85 -0
  78. package/esm2022/lib/inputs/color-input/color-input.types.mjs +2 -0
  79. package/esm2022/lib/inputs/digit-input/digit-input.component.mjs +218 -0
  80. package/esm2022/lib/inputs/digit-input/digit-input.model.mjs +217 -0
  81. package/esm2022/lib/inputs/digit-input/digit-input.module.mjs +18 -0
  82. package/esm2022/lib/inputs/digit-input/digit-input.types.mjs +15 -0
  83. package/esm2022/lib/inputs/digit-input/digit-input.utils.mjs +8 -0
  84. package/esm2022/lib/inputs/hex-input/hex-input.component.mjs +234 -0
  85. package/esm2022/lib/inputs/hex-input/hex-input.directives.mjs +36 -0
  86. package/esm2022/lib/inputs/hex-input/hex-input.module.mjs +21 -0
  87. package/esm2022/lib/inputs/hex-input.model.mjs +106 -0
  88. package/esm2022/lib/inputs/input/input.component.mjs +344 -0
  89. package/esm2022/lib/inputs/input/input.directives.mjs +58 -0
  90. package/esm2022/lib/inputs/input/input.module.mjs +47 -0
  91. package/esm2022/lib/inputs/input-transformers.mjs +66 -0
  92. package/esm2022/lib/inputs/input-types.mjs +6 -0
  93. package/esm2022/lib/inputs/input-utils.mjs +205 -0
  94. package/esm2022/lib/inputs/number-input/number-input.component.mjs +289 -0
  95. package/esm2022/lib/inputs/number-input/number-input.directives.mjs +14 -0
  96. package/esm2022/lib/inputs/number-input/number-input.module.mjs +21 -0
  97. package/esm2022/lib/inputs/password-input/password-input.component.mjs +222 -0
  98. package/esm2022/lib/inputs/password-input/password-input.directives.mjs +49 -0
  99. package/esm2022/lib/inputs/password-input/password-input.module.mjs +41 -0
  100. package/esm2022/lib/inputs/password-input/password-input.types.mjs +2 -0
  101. package/esm2022/lib/inputs/simple-input/simple-input.component.mjs +219 -0
  102. package/esm2022/lib/inputs/simple-input/simple-input.directives.mjs +36 -0
  103. package/esm2022/lib/inputs/simple-input/simple-input.module.mjs +37 -0
  104. package/esm2022/lib/kbd/kbd.component.mjs +42 -0
  105. package/esm2022/lib/kbd/kbd.module.mjs +19 -0
  106. package/esm2022/lib/kbd/kbd.pipe.mjs +17 -0
  107. package/esm2022/lib/kbd-shortcut/kbd-shortcut.component.mjs +55 -0
  108. package/esm2022/lib/kbd-shortcut/kbd-shortcut.module.mjs +19 -0
  109. package/esm2022/lib/modal/modal.component.mjs +120 -0
  110. package/esm2022/lib/modal/modal.module.mjs +21 -0
  111. package/esm2022/lib/option/option.component.mjs +77 -0
  112. package/esm2022/lib/option/option.module.mjs +18 -0
  113. package/esm2022/lib/progress-bar/progress-bar.component.mjs +95 -0
  114. package/esm2022/lib/progress-bar/progress-bar.directive.mjs +14 -0
  115. package/esm2022/lib/progress-bar/progress-bar.module.mjs +19 -0
  116. package/esm2022/lib/progress-bar/progress-bar.types.mjs +19 -0
  117. package/esm2022/lib/progress-circle/progress-circle.component.mjs +94 -0
  118. package/esm2022/lib/progress-circle/progress-circle.directive.mjs +14 -0
  119. package/esm2022/lib/progress-circle/progress-circle.module.mjs +19 -0
  120. package/esm2022/lib/progress-circle/progress-circle.types.mjs +10 -0
  121. package/esm2022/lib/radio/radio/radio.component.mjs +53 -0
  122. package/esm2022/lib/radio/radio-group.component.mjs +207 -0
  123. package/esm2022/lib/radio/radio.module.mjs +19 -0
  124. package/esm2022/lib/search-functions.mjs +64 -0
  125. package/esm2022/lib/segment/segment.component.mjs +168 -0
  126. package/esm2022/lib/segment/segment.directives.mjs +14 -0
  127. package/esm2022/lib/segment/segment.module.mjs +19 -0
  128. package/esm2022/lib/segment/segment.types.mjs +12 -0
  129. package/esm2022/lib/select/select.component.mjs +1160 -0
  130. package/esm2022/lib/select/select.directive.mjs +171 -0
  131. package/esm2022/lib/select/select.module.mjs +112 -0
  132. package/esm2022/lib/select/select.types.mjs +2 -0
  133. package/esm2022/lib/slide-toggle/slide-toggle.component.mjs +46 -0
  134. package/esm2022/lib/slide-toggle/slide-toggle.module.mjs +18 -0
  135. package/esm2022/lib/slider/abstract-slider.mjs +330 -0
  136. package/esm2022/lib/slider/range-slider/range-slider.component.mjs +143 -0
  137. package/esm2022/lib/slider/range-slider/range-slider.module.mjs +18 -0
  138. package/esm2022/lib/slider/slider.component.mjs +93 -0
  139. package/esm2022/lib/slider/slider.directive.mjs +16 -0
  140. package/esm2022/lib/slider/slider.module.mjs +20 -0
  141. package/esm2022/lib/slider/slider.types.mjs +10 -0
  142. package/esm2022/lib/snackbar/index.mjs +5 -0
  143. package/esm2022/lib/snackbar/snackbar-ref.mjs +51 -0
  144. package/esm2022/lib/snackbar/snackbar.component.mjs +48 -0
  145. package/esm2022/lib/snackbar/snackbar.service.mjs +227 -0
  146. package/esm2022/lib/snackbar/snackbar.token.mjs +20 -0
  147. package/esm2022/lib/snackbar/snackbar.types.mjs +25 -0
  148. package/esm2022/lib/spinner/spinner.component.mjs +22 -0
  149. package/esm2022/lib/spinner/spinner.module.mjs +18 -0
  150. package/esm2022/lib/star/star-button/star-button.component.mjs +53 -0
  151. package/esm2022/lib/star/star-button/star-button.module.mjs +19 -0
  152. package/esm2022/lib/star/star-display/star-display.component.mjs +66 -0
  153. package/esm2022/lib/star/star-display/star-display.module.mjs +19 -0
  154. package/esm2022/lib/star/star-input/star-input.component.mjs +221 -0
  155. package/esm2022/lib/star/star-input/star-input.module.mjs +19 -0
  156. package/esm2022/lib/star/star.component.mjs +28 -0
  157. package/esm2022/lib/star/star.module.mjs +18 -0
  158. package/esm2022/lib/star/star.types.mjs +23 -0
  159. package/esm2022/lib/statebox/statebox.component.mjs +158 -0
  160. package/esm2022/lib/statebox/statebox.module.mjs +18 -0
  161. package/esm2022/lib/statebox/statebox.types.mjs +2 -0
  162. package/esm2022/lib/table/table-item-storage.mjs +560 -0
  163. package/esm2022/lib/table/table.component.mjs +468 -0
  164. package/esm2022/lib/table/table.directives.mjs +64 -0
  165. package/esm2022/lib/table/table.module.mjs +46 -0
  166. package/esm2022/lib/table/table.types.mjs +30 -0
  167. package/esm2022/lib/table/utils.mjs +18 -0
  168. package/esm2022/lib/table-from-csv/table-from-csv.component.mjs +64 -0
  169. package/esm2022/lib/table-from-csv/table-from-csv.module.mjs +19 -0
  170. package/esm2022/lib/table-pagination/table-pagination.component.mjs +172 -0
  171. package/esm2022/lib/table-pagination/table-pagination.module.mjs +21 -0
  172. package/esm2022/lib/table-pagination/table-pagination.types.mjs +7 -0
  173. package/esm2022/lib/types/alignment.types.mjs +10 -0
  174. package/esm2022/lib/types/colors.types.mjs +43 -0
  175. package/esm2022/lib/types/item-storage.types.mjs +6 -0
  176. package/esm2022/lib/types/theming.types.mjs +48 -0
  177. package/esm2022/lib/types/utility.types.mjs +5 -0
  178. package/esm2022/public-api.mjs +194 -0
  179. package/fesm2022/ardium-ui-ui.mjs +14316 -0
  180. package/fesm2022/ardium-ui-ui.mjs.map +1 -0
  181. package/index.d.ts +5 -0
  182. package/lib/_internal/boolean-component.d.ts +50 -0
  183. package/lib/_internal/clear-button/clear-button.component.d.ts +6 -0
  184. package/lib/_internal/clear-button/clear-button.module.d.ts +8 -0
  185. package/lib/_internal/disablable-component.d.ts +11 -0
  186. package/lib/_internal/focusable-component.d.ts +52 -0
  187. package/lib/_internal/item-storages/dropdown-item-storage.d.ts +87 -0
  188. package/lib/_internal/item-storages/simple-item-storage.d.ts +159 -0
  189. package/lib/_internal/item-storages/simplest-item-storage.d.ts +70 -0
  190. package/lib/_internal/models/pagination.model.d.ts +53 -0
  191. package/lib/_internal/ngmodel-component.d.ts +42 -0
  192. package/lib/_internal/queue.d.ts +21 -0
  193. package/lib/_internal/selectable-list-component.d.ts +71 -0
  194. package/lib/badge/badge.directive.d.ts +31 -0
  195. package/lib/badge/badge.module.d.ts +8 -0
  196. package/lib/badge/badge.types.d.ts +17 -0
  197. package/lib/buttons/_button-base.d.ts +18 -0
  198. package/lib/buttons/button/button.component.d.ts +15 -0
  199. package/lib/buttons/button/button.module.d.ts +8 -0
  200. package/lib/buttons/fab/fab.component.d.ts +12 -0
  201. package/lib/buttons/fab/fab.module.d.ts +8 -0
  202. package/lib/buttons/general-button.types.d.ts +57 -0
  203. package/lib/buttons/icon-button/icon-button.component.d.ts +13 -0
  204. package/lib/buttons/icon-button/icon-button.module.d.ts +8 -0
  205. package/lib/calendar/calendar.component.d.ts +155 -0
  206. package/lib/calendar/calendar.directives.d.ts +51 -0
  207. package/lib/calendar/calendar.helpers.d.ts +15 -0
  208. package/lib/calendar/calendar.module.d.ts +11 -0
  209. package/lib/calendar/calendar.types.d.ts +80 -0
  210. package/lib/card/card.children.d.ts +43 -0
  211. package/lib/card/card.component.d.ts +13 -0
  212. package/lib/card/card.module.d.ts +9 -0
  213. package/lib/card/card.types.d.ts +10 -0
  214. package/lib/checkbox/checkbox.component.d.ts +21 -0
  215. package/lib/checkbox/checkbox.module.d.ts +8 -0
  216. package/lib/checkbox/checkbox.types.d.ts +6 -0
  217. package/lib/checkbox-list/checkbox-list.component.d.ts +50 -0
  218. package/lib/checkbox-list/checkbox-list.module.d.ts +9 -0
  219. package/lib/checkbox-list/checkbox-list.types.d.ts +7 -0
  220. package/lib/chip/chip.component.d.ts +18 -0
  221. package/lib/chip/chip.module.d.ts +11 -0
  222. package/lib/chip/deletable-chip/deletable-chip.component.d.ts +24 -0
  223. package/lib/chip/selectable-chip/selectable-chip.component.d.ts +24 -0
  224. package/lib/color/color-display/color-display.component.d.ts +17 -0
  225. package/lib/color/color-display/color-display.module.d.ts +8 -0
  226. package/lib/color/color-display/color-display.types.d.ts +9 -0
  227. package/lib/color/color-picker/color-picker.component.d.ts +125 -0
  228. package/lib/color/color-picker/color-picker.directives.d.ts +27 -0
  229. package/lib/color/color-picker/color-picker.module.d.ts +13 -0
  230. package/lib/color/color-picker/color-picker.types.d.ts +21 -0
  231. package/lib/dialog/dialog.component.d.ts +44 -0
  232. package/lib/dialog/dialog.directives.d.ts +9 -0
  233. package/lib/dialog/dialog.module.d.ts +11 -0
  234. package/lib/dialog/dialog.types.d.ts +28 -0
  235. package/lib/divider/divider.component.d.ts +8 -0
  236. package/lib/divider/divider.module.d.ts +8 -0
  237. package/lib/dropdown-panel/dropdown-panel.component.d.ts +37 -0
  238. package/lib/dropdown-panel/dropdown-panel.module.d.ts +8 -0
  239. package/lib/dropdown-panel/dropdown-panel.types.d.ts +12 -0
  240. package/lib/file-inputs/file-drop-area/file-drop-area.component.d.ts +22 -0
  241. package/lib/file-inputs/file-drop-area/file-drop-area.directives.d.ts +21 -0
  242. package/lib/file-inputs/file-drop-area/file-drop-area.module.d.ts +12 -0
  243. package/lib/file-inputs/file-input/file-input.component.d.ts +41 -0
  244. package/lib/file-inputs/file-input/file-input.directives.d.ts +39 -0
  245. package/lib/file-inputs/file-input/file-input.module.d.ts +11 -0
  246. package/lib/file-inputs/file-input-base.d.ts +43 -0
  247. package/lib/file-inputs/file-input-types.d.ts +10 -0
  248. package/lib/form-field-frame/form-field-frame.component.d.ts +32 -0
  249. package/lib/form-field-frame/form-field-frame.directives.d.ts +14 -0
  250. package/lib/form-field-frame/form-field-frame.module.d.ts +9 -0
  251. package/lib/icon/icon.component.d.ts +32 -0
  252. package/lib/icon/icon.module.d.ts +9 -0
  253. package/lib/icon/icon.pipe.d.ts +7 -0
  254. package/lib/inputs/color-input/color-input.component.d.ts +147 -0
  255. package/lib/inputs/color-input/color-input.directives.d.ts +52 -0
  256. package/lib/inputs/color-input/color-input.module.d.ts +16 -0
  257. package/lib/inputs/color-input/color-input.types.d.ts +5 -0
  258. package/lib/inputs/digit-input/digit-input.component.d.ts +50 -0
  259. package/lib/inputs/digit-input/digit-input.model.d.ts +26 -0
  260. package/lib/inputs/digit-input/digit-input.module.d.ts +8 -0
  261. package/lib/inputs/digit-input/digit-input.types.d.ts +27 -0
  262. package/lib/inputs/digit-input/digit-input.utils.d.ts +17 -0
  263. package/lib/inputs/hex-input/hex-input.component.d.ts +60 -0
  264. package/lib/inputs/hex-input/hex-input.directives.d.ts +20 -0
  265. package/lib/inputs/hex-input/hex-input.module.d.ts +11 -0
  266. package/lib/inputs/hex-input.model.d.ts +27 -0
  267. package/lib/inputs/input/input.component.d.ts +79 -0
  268. package/lib/inputs/input/input.directives.d.ts +33 -0
  269. package/lib/inputs/input/input.module.d.ts +13 -0
  270. package/lib/inputs/input-transformers.d.ts +24 -0
  271. package/lib/inputs/input-types.d.ts +6 -0
  272. package/lib/inputs/input-utils.d.ts +58 -0
  273. package/lib/inputs/number-input/number-input.component.d.ts +70 -0
  274. package/lib/inputs/number-input/number-input.directives.d.ts +8 -0
  275. package/lib/inputs/number-input/number-input.module.d.ts +11 -0
  276. package/lib/inputs/password-input/password-input.component.d.ts +54 -0
  277. package/lib/inputs/password-input/password-input.directives.d.ts +27 -0
  278. package/lib/inputs/password-input/password-input.module.d.ts +11 -0
  279. package/lib/inputs/password-input/password-input.types.d.ts +3 -0
  280. package/lib/inputs/simple-input/simple-input.component.d.ts +58 -0
  281. package/lib/inputs/simple-input/simple-input.directives.d.ts +20 -0
  282. package/lib/inputs/simple-input/simple-input.module.d.ts +11 -0
  283. package/lib/kbd/kbd.component.d.ts +15 -0
  284. package/lib/kbd/kbd.module.d.ts +9 -0
  285. package/lib/kbd/kbd.pipe.d.ts +7 -0
  286. package/lib/kbd-shortcut/kbd-shortcut.component.d.ts +18 -0
  287. package/lib/kbd-shortcut/kbd-shortcut.module.d.ts +9 -0
  288. package/lib/modal/modal.component.d.ts +36 -0
  289. package/lib/modal/modal.module.d.ts +11 -0
  290. package/lib/option/option.component.d.ts +29 -0
  291. package/lib/option/option.module.d.ts +8 -0
  292. package/lib/progress-bar/progress-bar.component.d.ts +26 -0
  293. package/lib/progress-bar/progress-bar.directive.d.ts +9 -0
  294. package/lib/progress-bar/progress-bar.module.d.ts +9 -0
  295. package/lib/progress-bar/progress-bar.types.d.ts +26 -0
  296. package/lib/progress-circle/progress-circle.component.d.ts +28 -0
  297. package/lib/progress-circle/progress-circle.directive.d.ts +9 -0
  298. package/lib/progress-circle/progress-circle.module.d.ts +9 -0
  299. package/lib/progress-circle/progress-circle.types.d.ts +17 -0
  300. package/lib/radio/radio/radio.component.d.ts +23 -0
  301. package/lib/radio/radio-group.component.d.ts +43 -0
  302. package/lib/radio/radio.module.d.ts +9 -0
  303. package/lib/search-functions.d.ts +10 -0
  304. package/lib/segment/segment.component.d.ts +48 -0
  305. package/lib/segment/segment.directives.d.ts +9 -0
  306. package/lib/segment/segment.module.d.ts +9 -0
  307. package/lib/segment/segment.types.d.ts +16 -0
  308. package/lib/select/select.component.d.ts +255 -0
  309. package/lib/select/select.directive.d.ts +94 -0
  310. package/lib/select/select.module.d.ts +14 -0
  311. package/lib/select/select.types.d.ts +109 -0
  312. package/lib/slide-toggle/slide-toggle.component.d.ts +14 -0
  313. package/lib/slide-toggle/slide-toggle.module.d.ts +8 -0
  314. package/lib/slider/abstract-slider.d.ts +88 -0
  315. package/lib/slider/range-slider/range-slider.component.d.ts +29 -0
  316. package/lib/slider/range-slider/range-slider.module.d.ts +8 -0
  317. package/lib/slider/slider.component.d.ts +18 -0
  318. package/lib/slider/slider.directive.d.ts +9 -0
  319. package/lib/slider/slider.module.d.ts +10 -0
  320. package/lib/slider/slider.types.d.ts +28 -0
  321. package/lib/snackbar/index.d.ts +4 -0
  322. package/lib/snackbar/snackbar-ref.d.ts +37 -0
  323. package/lib/snackbar/snackbar.component.d.ts +16 -0
  324. package/lib/snackbar/snackbar.service.d.ts +31 -0
  325. package/lib/snackbar/snackbar.token.d.ts +5 -0
  326. package/lib/snackbar/snackbar.types.d.ts +48 -0
  327. package/lib/spinner/spinner.component.d.ts +8 -0
  328. package/lib/spinner/spinner.module.d.ts +8 -0
  329. package/lib/star/star-button/star-button.component.d.ts +16 -0
  330. package/lib/star/star-button/star-button.module.d.ts +9 -0
  331. package/lib/star/star-display/star-display.component.d.ts +16 -0
  332. package/lib/star/star-display/star-display.module.d.ts +9 -0
  333. package/lib/star/star-input/star-input.component.d.ts +51 -0
  334. package/lib/star/star-input/star-input.module.d.ts +9 -0
  335. package/lib/star/star.component.d.ts +10 -0
  336. package/lib/star/star.module.d.ts +8 -0
  337. package/lib/star/star.types.d.ts +30 -0
  338. package/lib/statebox/statebox.component.d.ts +31 -0
  339. package/lib/statebox/statebox.module.d.ts +8 -0
  340. package/lib/statebox/statebox.types.d.ts +22 -0
  341. package/lib/table/table-item-storage.d.ts +266 -0
  342. package/lib/table/table.component.d.ts +127 -0
  343. package/lib/table/table.directives.d.ts +35 -0
  344. package/lib/table/table.module.d.ts +12 -0
  345. package/lib/table/table.types.d.ts +83 -0
  346. package/lib/table/utils.d.ts +4 -0
  347. package/lib/table-from-csv/table-from-csv.component.d.ts +16 -0
  348. package/lib/table-from-csv/table-from-csv.module.d.ts +9 -0
  349. package/lib/table-pagination/table-pagination.component.d.ts +48 -0
  350. package/lib/table-pagination/table-pagination.module.d.ts +11 -0
  351. package/lib/table-pagination/table-pagination.types.d.ts +9 -0
  352. package/lib/types/alignment.types.d.ts +11 -0
  353. package/lib/types/colors.types.d.ts +71 -0
  354. package/lib/types/item-storage.types.d.ts +98 -0
  355. package/lib/types/theming.types.d.ts +61 -0
  356. package/lib/types/utility.types.d.ts +11 -0
  357. package/package.json +36 -0
  358. package/prebuilt-themes/default/badge.css +208 -0
  359. package/prebuilt-themes/default/badge.css.map +1 -0
  360. package/prebuilt-themes/default/buttons/button.css +290 -0
  361. package/prebuilt-themes/default/buttons/button.css.map +1 -0
  362. package/prebuilt-themes/default/buttons/fab.css +307 -0
  363. package/prebuilt-themes/default/buttons/fab.css.map +1 -0
  364. package/prebuilt-themes/default/buttons/icon-button.css +288 -0
  365. package/prebuilt-themes/default/buttons/icon-button.css.map +1 -0
  366. package/prebuilt-themes/default/calendar.css +293 -0
  367. package/prebuilt-themes/default/calendar.css.map +1 -0
  368. package/prebuilt-themes/default/card.css +122 -0
  369. package/prebuilt-themes/default/card.css.map +1 -0
  370. package/prebuilt-themes/default/checkbox-list.css +65 -0
  371. package/prebuilt-themes/default/checkbox-list.css.map +1 -0
  372. package/prebuilt-themes/default/checkbox.css +365 -0
  373. package/prebuilt-themes/default/checkbox.css.map +1 -0
  374. package/prebuilt-themes/default/chips.css +367 -0
  375. package/prebuilt-themes/default/chips.css.map +1 -0
  376. package/prebuilt-themes/default/color-display.css +29 -0
  377. package/prebuilt-themes/default/color-display.css.map +1 -0
  378. package/prebuilt-themes/default/color-picker.css +106 -0
  379. package/prebuilt-themes/default/color-picker.css.map +1 -0
  380. package/prebuilt-themes/default/core.css +84 -0
  381. package/prebuilt-themes/default/core.css.map +1 -0
  382. package/prebuilt-themes/default/dialog.css +18 -0
  383. package/prebuilt-themes/default/dialog.css.map +1 -0
  384. package/prebuilt-themes/default/divider.css +11 -0
  385. package/prebuilt-themes/default/divider.css.map +1 -0
  386. package/prebuilt-themes/default/dropdown-panel.css +37 -0
  387. package/prebuilt-themes/default/dropdown-panel.css.map +1 -0
  388. package/prebuilt-themes/default/file-drop-area.css +279 -0
  389. package/prebuilt-themes/default/file-drop-area.css.map +1 -0
  390. package/prebuilt-themes/default/form-field-frame.css +84 -0
  391. package/prebuilt-themes/default/form-field-frame.css.map +1 -0
  392. package/prebuilt-themes/default/inputs/color-input.css +139 -0
  393. package/prebuilt-themes/default/inputs/color-input.css.map +1 -0
  394. package/prebuilt-themes/default/inputs/digit-input.css +45 -0
  395. package/prebuilt-themes/default/inputs/digit-input.css.map +1 -0
  396. package/prebuilt-themes/default/inputs/file-input.css +169 -0
  397. package/prebuilt-themes/default/inputs/file-input.css.map +1 -0
  398. package/prebuilt-themes/default/inputs/hex-input.css +119 -0
  399. package/prebuilt-themes/default/inputs/hex-input.css.map +1 -0
  400. package/prebuilt-themes/default/inputs/input.css +139 -0
  401. package/prebuilt-themes/default/inputs/input.css.map +1 -0
  402. package/prebuilt-themes/default/inputs/number-input.css +150 -0
  403. package/prebuilt-themes/default/inputs/number-input.css.map +1 -0
  404. package/prebuilt-themes/default/inputs/password-input.css +73 -0
  405. package/prebuilt-themes/default/inputs/password-input.css.map +1 -0
  406. package/prebuilt-themes/default/inputs/search-bar.css +114 -0
  407. package/prebuilt-themes/default/inputs/search-bar.css.map +1 -0
  408. package/prebuilt-themes/default/inputs/simple-input.css +114 -0
  409. package/prebuilt-themes/default/inputs/simple-input.css.map +1 -0
  410. package/prebuilt-themes/default/kbd-shortcut.css +12 -0
  411. package/prebuilt-themes/default/kbd-shortcut.css.map +1 -0
  412. package/prebuilt-themes/default/kbd.css +17 -0
  413. package/prebuilt-themes/default/kbd.css.map +1 -0
  414. package/prebuilt-themes/default/modal.css +73 -0
  415. package/prebuilt-themes/default/modal.css.map +1 -0
  416. package/prebuilt-themes/default/progress-bar.css +267 -0
  417. package/prebuilt-themes/default/progress-bar.css.map +1 -0
  418. package/prebuilt-themes/default/progress-circle.css +167 -0
  419. package/prebuilt-themes/default/progress-circle.css.map +1 -0
  420. package/prebuilt-themes/default/radio.css +226 -0
  421. package/prebuilt-themes/default/radio.css.map +1 -0
  422. package/prebuilt-themes/default/segment.css +391 -0
  423. package/prebuilt-themes/default/segment.css.map +1 -0
  424. package/prebuilt-themes/default/select.css +275 -0
  425. package/prebuilt-themes/default/select.css.map +1 -0
  426. package/prebuilt-themes/default/slide-toggle.css +264 -0
  427. package/prebuilt-themes/default/slide-toggle.css.map +1 -0
  428. package/prebuilt-themes/default/slider.css +354 -0
  429. package/prebuilt-themes/default/slider.css.map +1 -0
  430. package/prebuilt-themes/default/snackbar.css +183 -0
  431. package/prebuilt-themes/default/snackbar.css.map +1 -0
  432. package/prebuilt-themes/default/spinner.css +151 -0
  433. package/prebuilt-themes/default/spinner.css.map +1 -0
  434. package/prebuilt-themes/default/stars.css +291 -0
  435. package/prebuilt-themes/default/stars.css.map +1 -0
  436. package/prebuilt-themes/default/statebox.css +235 -0
  437. package/prebuilt-themes/default/statebox.css.map +1 -0
  438. package/prebuilt-themes/default/table-pagination.css +48 -0
  439. package/prebuilt-themes/default/table-pagination.css.map +1 -0
  440. package/prebuilt-themes/default/table.css +418 -0
  441. package/prebuilt-themes/default/table.css.map +1 -0
  442. package/public-api.d.ts +145 -0
  443. package/themes/_variables.scss +121 -0
  444. package/themes/default/_clear-button.scss +73 -0
  445. package/themes/default/_coloring.scss +137 -0
  446. package/themes/default/_dropdown-arrow.scss +12 -0
  447. package/themes/default/_mixins.scss +70 -0
  448. package/themes/default/badge.scss +94 -0
  449. package/themes/default/buttons/_button-mixins.scss +144 -0
  450. package/themes/default/buttons/button.scss +62 -0
  451. package/themes/default/buttons/fab.scss +72 -0
  452. package/themes/default/buttons/icon-button.scss +59 -0
  453. package/themes/default/calendar.scss +182 -0
  454. package/themes/default/card.scss +126 -0
  455. package/themes/default/checkbox-list.scss +83 -0
  456. package/themes/default/checkbox.scss +109 -0
  457. package/themes/default/chips.scss +206 -0
  458. package/themes/default/color-display.scss +41 -0
  459. package/themes/default/color-picker.scss +111 -0
  460. package/themes/default/core.scss +96 -0
  461. package/themes/default/dialog.scss +16 -0
  462. package/themes/default/divider.scss +13 -0
  463. package/themes/default/dropdown-panel.scss +45 -0
  464. package/themes/default/file-drop-area.scss +162 -0
  465. package/themes/default/form-field-frame.scss +78 -0
  466. package/themes/default/inputs/_shared.scss +46 -0
  467. package/themes/default/inputs/color-input.scss +46 -0
  468. package/themes/default/inputs/digit-input.scss +56 -0
  469. package/themes/default/inputs/file-input.scss +78 -0
  470. package/themes/default/inputs/hex-input.scss +27 -0
  471. package/themes/default/inputs/input.scss +52 -0
  472. package/themes/default/inputs/number-input.scss +121 -0
  473. package/themes/default/inputs/password-input.scss +43 -0
  474. package/themes/default/inputs/search-bar.scss +19 -0
  475. package/themes/default/inputs/simple-input.scss +19 -0
  476. package/themes/default/kbd-shortcut.scss +13 -0
  477. package/themes/default/kbd.scss +20 -0
  478. package/themes/default/modal.scss +93 -0
  479. package/themes/default/progress-bar.scss +166 -0
  480. package/themes/default/progress-circle.scss +56 -0
  481. package/themes/default/radio.scss +112 -0
  482. package/themes/default/segment.scss +339 -0
  483. package/themes/default/select.scss +253 -0
  484. package/themes/default/slide-toggle.scss +151 -0
  485. package/themes/default/slider.scss +224 -0
  486. package/themes/default/snackbar.scss +60 -0
  487. package/themes/default/spinner.scss +21 -0
  488. package/themes/default/stars.scss +122 -0
  489. package/themes/default/statebox.scss +109 -0
  490. package/themes/default/table-pagination.scss +56 -0
  491. package/themes/default/table.scss +403 -0
@@ -0,0 +1,1160 @@
1
+ import { OverlayConfig } from '@angular/cdk/overlay';
2
+ import { TemplatePortal } from '@angular/cdk/portal';
3
+ import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, TemplateRef, ViewChild, ViewEncapsulation, forwardRef, } from '@angular/core';
4
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
5
+ import { coerceArrayProperty, coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';
6
+ import { Subject, merge, startWith, takeUntil } from 'rxjs';
7
+ import { isAnyString, isArray, isFunction } from 'simple-bool';
8
+ import { ItemStorage } from '../_internal/item-storages/dropdown-item-storage';
9
+ import { _NgModelComponentBase } from '../_internal/ngmodel-component';
10
+ import { ArdiumDropdownPanelComponent } from '../dropdown-panel/dropdown-panel.component';
11
+ import { DropdownPanelAppearance, DropdownPanelVariant } from '../dropdown-panel/dropdown-panel.types';
12
+ import { ArdiumOptionComponent } from '../option/option.component';
13
+ import { searchFunctions } from '../search-functions';
14
+ import { ArdPanelPosition } from '../types/item-storage.types';
15
+ import { FormElementAppearance } from '../types/theming.types';
16
+ import { FormElementVariant } from './../types/theming.types';
17
+ import { ArdAddCustomTemplateDirective, ArdDropdownFooterTemplateDirective, ArdDropdownHeaderTemplateDirective, ArdItemDisplayLimitTemplateDirective, ArdItemLimitReachedTemplateDirective, ArdLoadingPlaceholderTemplateDirective, ArdLoadingSpinnerTemplateDirective, ArdNoItemsFoundTemplateDirective, ArdOptgroupTemplateDirective, ArdOptionTemplateDirective, ArdSelectPlaceholderTemplateDirective, ArdSelectPrefixTemplateDirective, ArdSelectSuffixTemplateDirective, ArdValueTemplateDirective, } from './select.directive';
18
+ import * as i0 from "@angular/core";
19
+ import * as i1 from "@angular/cdk/overlay";
20
+ import * as i2 from "@angular/common";
21
+ import * as i3 from "../form-field-frame/form-field-frame.component";
22
+ import * as i4 from "../dropdown-panel/dropdown-panel.component";
23
+ import * as i5 from "../chip/deletable-chip/deletable-chip.component";
24
+ import * as i6 from "@ardium-ui/devkit";
25
+ import * as i7 from "../_internal/clear-button/clear-button.component";
26
+ export class ArdiumSelectComponent extends _NgModelComponentBase {
27
+ get itemsAlreadyGrouped() {
28
+ return this._itemsAlreadyGrouped;
29
+ }
30
+ set itemsAlreadyGrouped(v) {
31
+ this._itemsAlreadyGrouped = coerceBooleanProperty(v);
32
+ }
33
+ get invertDisabled() {
34
+ return this._invertDisabled;
35
+ }
36
+ set invertDisabled(v) {
37
+ this._invertDisabled = coerceBooleanProperty(v);
38
+ }
39
+ get noGroupActions() {
40
+ return this._noGroupActions;
41
+ }
42
+ set noGroupActions(v) {
43
+ this._noGroupActions = coerceBooleanProperty(v);
44
+ }
45
+ get autoHighlightFirst() {
46
+ return this._autoHighlightFirst;
47
+ }
48
+ set autoHighlightFirst(v) {
49
+ this._autoHighlightFirst = coerceBooleanProperty(v);
50
+ }
51
+ get autoFocus() {
52
+ return this._autoFocus;
53
+ }
54
+ set autoFocus(v) {
55
+ this._autoFocus = coerceBooleanProperty(v);
56
+ }
57
+ get keepOpen() {
58
+ return this._keepOpen;
59
+ }
60
+ set keepOpen(v) {
61
+ this._keepOpen = coerceBooleanProperty(v);
62
+ }
63
+ get hideSelected() {
64
+ return this._hideSelected;
65
+ }
66
+ set hideSelected(v) {
67
+ this._hideSelected = coerceBooleanProperty(v);
68
+ }
69
+ get noBackspaceClear() {
70
+ return this._clearOnBackspace;
71
+ }
72
+ set noBackspaceClear(v) {
73
+ this._clearOnBackspace = coerceBooleanProperty(v);
74
+ }
75
+ get sortMultipleValues() {
76
+ return this._sortMultipleValues;
77
+ }
78
+ set sortMultipleValues(v) {
79
+ this._sortMultipleValues = coerceBooleanProperty(v);
80
+ }
81
+ get searchCaseSensitive() {
82
+ return this._searchCaseSensitive;
83
+ }
84
+ set searchCaseSensitive(v) {
85
+ this._searchCaseSensitive = coerceBooleanProperty(v);
86
+ }
87
+ get keepSearchAfterSelect() {
88
+ return this._keepSearchAfterSelect;
89
+ }
90
+ set keepSearchAfterSelect(v) {
91
+ this._keepSearchAfterSelect = coerceBooleanProperty(v);
92
+ }
93
+ get maxSelectedItems() {
94
+ return this._maxSelectedItems;
95
+ }
96
+ set maxSelectedItems(v) {
97
+ this._maxSelectedItems = coerceNumberProperty(v, undefined);
98
+ }
99
+ get itemDisplayLimit() {
100
+ return this._itemDisplayLimit;
101
+ }
102
+ set itemDisplayLimit(v) {
103
+ this._itemDisplayLimit = coerceNumberProperty(v, Infinity);
104
+ }
105
+ get searchFn() {
106
+ return this._searchFn;
107
+ }
108
+ set searchFn(fn) {
109
+ if (fn !== undefined && fn !== null && !isFunction(fn)) {
110
+ throw Error('`searchFn` must be a function.');
111
+ }
112
+ this._searchFn = fn;
113
+ }
114
+ get compareWith() {
115
+ return this._compareWith;
116
+ }
117
+ set compareWith(fn) {
118
+ if (fn !== undefined && fn !== null && !isFunction(fn)) {
119
+ throw Error('`compareWith` must be a function.');
120
+ }
121
+ this._compareWith = fn;
122
+ }
123
+ get compact() {
124
+ return this._compact;
125
+ }
126
+ set compact(v) {
127
+ this._compact = coerceBooleanProperty(v);
128
+ }
129
+ get ngClasses() {
130
+ return [
131
+ //appearance, variant handled in ard-form-field-frame component
132
+ this.compact ? 'ard-compact' : '',
133
+ this.multiselectable ? 'ard-multiselect' : 'ard-singleselect',
134
+ this.clearable ? 'ard-clearable' : '',
135
+ this.searchable ? 'ard-searchable' : '',
136
+ this.filtered ? 'ard-filtered' : '',
137
+ this.touched ? 'ard-touched' : '',
138
+ this.isDropdownOpen ? 'ard-dropdown-open' : '',
139
+ this._searchBarFocused ? 'ard-select-focused' : '',
140
+ this._searchBarFocused ? 'ard-select-focused' : '',
141
+ ].join(' ');
142
+ }
143
+ set dropdowonAppearance(v) {
144
+ this._dropdownAppearance = v;
145
+ }
146
+ get dropdownAppearance() {
147
+ if (this._dropdownAppearance)
148
+ return this._dropdownAppearance;
149
+ if (this.appearance == FormElementAppearance.Outlined)
150
+ return DropdownPanelAppearance.Outlined;
151
+ return DropdownPanelAppearance.Raised;
152
+ }
153
+ set dropdowonVariant(v) {
154
+ this._dropdownVariant = v;
155
+ }
156
+ get dropdownVariant() {
157
+ if (this._dropdownVariant)
158
+ return this._dropdownVariant;
159
+ if (this.variant == FormElementVariant.Pill)
160
+ return DropdownPanelVariant.Rounded;
161
+ return this.variant;
162
+ }
163
+ //! items setter/getter
164
+ get items() {
165
+ return this._items;
166
+ }
167
+ set items(value) {
168
+ this.isItemsInputUsed = true;
169
+ if (value === null) {
170
+ value = [];
171
+ this.isItemsInputUsed = false;
172
+ }
173
+ else if (isAnyString(value)) {
174
+ value = coerceArrayProperty(value);
175
+ }
176
+ let printErrors = this.itemStorage.setItems(value);
177
+ if (printErrors) {
178
+ this._printPrimitiveWarnings();
179
+ }
180
+ }
181
+ _setItemsFromComponents() {
182
+ const handleOptionChange = () => {
183
+ const changedOrDestroyed = merge(this.optionComponents.changes, this._destroy$);
184
+ merge(...this.optionComponents.map(option => option.stateChange$))
185
+ .pipe(takeUntil(changedOrDestroyed))
186
+ .subscribe(option => {
187
+ setTimeout(() => {
188
+ const item = this.itemStorage.findItemByValue(option.oldValue ?? option.value);
189
+ if (item) {
190
+ item.disabled = option.disabled;
191
+ item.label = option.label || item.label;
192
+ item.value = option.value;
193
+ item.itemData.disabled = option.disabled;
194
+ item.itemData.label = option.label || item.label;
195
+ item.itemData.value = option.value;
196
+ }
197
+ this.detectChanges();
198
+ }, 0);
199
+ });
200
+ };
201
+ this.optionComponents.changes
202
+ .pipe(startWith(this.optionComponents), takeUntil(this._destroy$))
203
+ .subscribe((options) => {
204
+ if (options.length == 0)
205
+ return;
206
+ setTimeout(() => {
207
+ this.items = options.map(option => ({
208
+ value: option.value,
209
+ label: option.label,
210
+ disabled: option.disabled,
211
+ }));
212
+ handleOptionChange();
213
+ this.detectChanges();
214
+ }, 0);
215
+ });
216
+ }
217
+ get multiselectable() {
218
+ return this._multiselectable;
219
+ }
220
+ set multiselectable(v) {
221
+ this._multiselectable = coerceBooleanProperty(v);
222
+ }
223
+ get singleselectable() {
224
+ return !this._multiselectable;
225
+ }
226
+ get clearable() {
227
+ return this._clearable;
228
+ }
229
+ set clearable(v) {
230
+ this._clearable = coerceBooleanProperty(v);
231
+ }
232
+ get searchable() {
233
+ return this._searchable;
234
+ }
235
+ set searchable(v) {
236
+ this._searchable = coerceBooleanProperty(v);
237
+ }
238
+ get filtered() {
239
+ return this._searchable && this.searchTerm != '';
240
+ }
241
+ get touched() {
242
+ return this._touched;
243
+ }
244
+ set touched(state) {
245
+ this._touched = state;
246
+ }
247
+ get addCustom() {
248
+ return this._addCustom;
249
+ }
250
+ set addCustom(v) {
251
+ if (isFunction(v)) {
252
+ this._addCustom = v;
253
+ return;
254
+ }
255
+ //coerce the value into a boolean
256
+ //if "true", use the default function. Otherwise, just set to "false".
257
+ this._addCustom = coerceBooleanProperty(v) && this._defaultAddCustomFn;
258
+ }
259
+ get shouldShowAddCustom() {
260
+ return this.addCustom != false && this.searchTerm.length > 0 && this.itemStorage.isNoItemsFound;
261
+ }
262
+ async addCustomOption(value) {
263
+ if (!this.addCustom)
264
+ return;
265
+ const newOptionObj = await this.itemStorage.addCustomOption(value, this.addCustom);
266
+ this.selectItem(newOptionObj);
267
+ }
268
+ //! control value accessor
269
+ //override the writeValue and setDisabledState defined in _NgModelComponent
270
+ setDisabledState(state) {
271
+ this._disabled = state;
272
+ this._cd.markForCheck();
273
+ }
274
+ writeValue(ngModel) {
275
+ this.itemStorage.handleWriteValue(ngModel);
276
+ this._cd.markForCheck();
277
+ }
278
+ //* change & touch event emitters
279
+ _emitChange() {
280
+ let value = this.itemStorage.value;
281
+ this._onChangeRegistered?.(value);
282
+ this.changeEvent.emit(value);
283
+ this.valueChange.emit(value);
284
+ }
285
+ _onTouched() {
286
+ this.touched = true;
287
+ this._onTouchedRegistered?.();
288
+ }
289
+ //! value input & output
290
+ set value(newValue) {
291
+ //if is a string, coerce it into array of strings
292
+ if (isAnyString(newValue))
293
+ newValue = coerceArrayProperty(newValue);
294
+ //if it is not a string and not an array, just put it in an array
295
+ else if (!isArray(newValue))
296
+ newValue = [newValue];
297
+ this.writeValue(newValue);
298
+ }
299
+ get value() {
300
+ return this.itemStorage.value;
301
+ }
302
+ //! context providers
303
+ getValueContext(item) {
304
+ const $this = this;
305
+ return {
306
+ $implicit: item,
307
+ item,
308
+ itemData: item.itemData,
309
+ unselect() {
310
+ $this.unselectItem(item);
311
+ },
312
+ };
313
+ }
314
+ getStatsContext() {
315
+ return {
316
+ totalItems: this.totalItems,
317
+ foundItems: this.foundItems,
318
+ };
319
+ }
320
+ getSearchContext() {
321
+ return {
322
+ $implicit: this.searchTerm,
323
+ searchTerm: this.searchTerm,
324
+ totalItems: this.totalItems,
325
+ foundItems: this.foundItems,
326
+ };
327
+ }
328
+ getPlaceholderContext() {
329
+ const placeholder = this.placeholderForCurrentContext;
330
+ return {
331
+ placeholder,
332
+ $implicit: placeholder,
333
+ };
334
+ }
335
+ getCustomOptionContext() {
336
+ return {
337
+ $implicit: this.searchTerm,
338
+ searchTerm: this.searchTerm,
339
+ };
340
+ }
341
+ getGroupContext(group) {
342
+ return {
343
+ $implicit: group,
344
+ group,
345
+ selectedChildren: group.children.filter(v => v.selected).length,
346
+ totalChildren: group.children.length,
347
+ };
348
+ }
349
+ getOptionContext(item) {
350
+ return {
351
+ $implicit: item,
352
+ item,
353
+ itemData: item.itemData,
354
+ };
355
+ }
356
+ getItemLimitContext() {
357
+ return {
358
+ totalItems: this.totalItems,
359
+ selectedItems: this.itemStorage.selectedItems.length,
360
+ itemLimit: this.maxSelectedItems,
361
+ };
362
+ }
363
+ getItemDisplayLimitContext() {
364
+ let selectedItems = this.itemStorage.selectedItems.length;
365
+ return {
366
+ totalItems: this.totalItems,
367
+ selectedItems,
368
+ itemLimit: this.maxSelectedItems,
369
+ overflowCount: selectedItems - (this.itemDisplayLimit ?? 0),
370
+ };
371
+ }
372
+ constructor(_elementRef, _cd, overlay, viewContainerRef, scrollStrategyOpts) {
373
+ super();
374
+ this._cd = _cd;
375
+ this.overlay = overlay;
376
+ this.viewContainerRef = viewContainerRef;
377
+ this.scrollStrategyOpts = scrollStrategyOpts;
378
+ //! public constants
379
+ this.itemStorage = new ItemStorage(this);
380
+ this.DEFAULTS = {
381
+ valueFrom: 'value',
382
+ labelFrom: 'label',
383
+ disabledFrom: 'disabled',
384
+ groupLabelFrom: 'group',
385
+ groupDisabledFrom: 'disabled',
386
+ childrenFrom: 'children',
387
+ searchFn: searchFunctions.byLabel,
388
+ clearButtonTitle: 'Clear',
389
+ noItemsFoundText: 'No items found.',
390
+ loadingPlaceholderText: 'Loading...',
391
+ };
392
+ //! privates
393
+ this._items = [];
394
+ this._isMouseBeingUsed = false;
395
+ this._searchBarFocused = false;
396
+ this._destroy$ = new Subject();
397
+ //! publics
398
+ this.searchTerm = '';
399
+ this.isItemsInputUsed = false;
400
+ //! settings
401
+ this.placeholder = 'Select item';
402
+ this.searchPlaceholder = 'Search...';
403
+ this.dropdownPosition = ArdPanelPosition.Auto;
404
+ this.clearButtonTitle = this.DEFAULTS.clearButtonTitle;
405
+ //! template-related settings
406
+ this.noItemsFoundText = this.DEFAULTS.noItemsFoundText;
407
+ this.loadingPlaceholderText = this.DEFAULTS.loadingPlaceholderText;
408
+ //! other inputs
409
+ this.isLoading = false;
410
+ this.inputAttrs = {};
411
+ this.htmlId = crypto.randomUUID();
412
+ //! boolean settings
413
+ this._itemsAlreadyGrouped = false;
414
+ //should the value that the "disabledFrom" path lead to be inverted?
415
+ //useful when the property is e.g. "active", which is the oposite of "disabled"
416
+ this._invertDisabled = false;
417
+ this._noGroupActions = false;
418
+ this._autoHighlightFirst = true;
419
+ this._autoFocus = false;
420
+ this._keepOpen = false;
421
+ this._hideSelected = false;
422
+ this._clearOnBackspace = false;
423
+ this._sortMultipleValues = false;
424
+ this._searchCaseSensitive = false;
425
+ this._keepSearchAfterSelect = false;
426
+ //! number inputs
427
+ this._maxSelectedItems = undefined;
428
+ this._itemDisplayLimit = Infinity;
429
+ //! function inputs
430
+ this._searchFn = this.DEFAULTS.searchFn;
431
+ //! appearance
432
+ this.appearance = FormElementAppearance.Outlined;
433
+ this.variant = FormElementVariant.Rounded;
434
+ this._compact = false;
435
+ this._dropdownAppearance = undefined;
436
+ this._dropdownVariant = undefined;
437
+ //! class-based inputs
438
+ this.groupItems = false; //default value may be changed to "true" in ngOnChanges if this.groupBy is defined or this.itemsAlreadyGrouped is set to "true"
439
+ //! attribute and/or class setters/getters
440
+ this._multiselectable = false;
441
+ this._clearable = true;
442
+ this._searchable = false;
443
+ this._touched = false;
444
+ //! custom options
445
+ this._defaultAddCustomFn = (value) => value;
446
+ this._addCustom = false;
447
+ this.valueChange = new EventEmitter();
448
+ //! output events
449
+ this.changeEvent = new EventEmitter();
450
+ this.addEvent = new EventEmitter();
451
+ this.failedToAddEvent = new EventEmitter();
452
+ this.removeEvent = new EventEmitter();
453
+ this.clearEvent = new EventEmitter();
454
+ this.openEvent = new EventEmitter();
455
+ this.closeEvent = new EventEmitter();
456
+ this.scrollEvent = new EventEmitter();
457
+ this.scrollToEndEvent = new EventEmitter();
458
+ this.searchEvent = new EventEmitter();
459
+ this.isDropdownOpenChange = new EventEmitter();
460
+ //! click handlers
461
+ this._isClickedWithin = false;
462
+ this.element = _elementRef.nativeElement;
463
+ }
464
+ _createOverlay() {
465
+ const strategy = this.overlay
466
+ .position()
467
+ .flexibleConnectedTo(this.dropdownHost)
468
+ .withPositions([
469
+ {
470
+ originX: 'start',
471
+ originY: 'bottom',
472
+ overlayX: 'start',
473
+ overlayY: 'top',
474
+ },
475
+ {
476
+ originX: 'start',
477
+ originY: 'top',
478
+ overlayX: 'start',
479
+ overlayY: 'bottom',
480
+ },
481
+ ]);
482
+ const config = new OverlayConfig({
483
+ positionStrategy: strategy,
484
+ scrollStrategy: this.scrollStrategyOpts.block(),
485
+ hasBackdrop: false,
486
+ });
487
+ this.dropdownOverlay = this.overlay.create(config);
488
+ const portal = new TemplatePortal(this.dropdownTemplate, this.viewContainerRef);
489
+ this.dropdownOverlay.attach(portal);
490
+ this.setOverlaySize();
491
+ }
492
+ _destroyOverlay() {
493
+ if (!this.dropdownOverlay)
494
+ return;
495
+ this.dropdownOverlay.dispose();
496
+ delete this.dropdownOverlay;
497
+ }
498
+ setOverlaySize() {
499
+ if (!this.dropdownOverlay)
500
+ return;
501
+ const rect = this.dropdownHost.nativeElement.getBoundingClientRect();
502
+ this.dropdownOverlay.updateSize({ width: rect.width });
503
+ }
504
+ onWindowResize() {
505
+ this.setOverlaySize();
506
+ }
507
+ //! hooks
508
+ ngOnInit() {
509
+ this._setSearchInputAttributes();
510
+ }
511
+ ngOnDestroy() {
512
+ this._destroy$.next();
513
+ this._destroy$.complete();
514
+ }
515
+ ngAfterViewInit() {
516
+ if (this.autoFocus) {
517
+ this.focus();
518
+ }
519
+ }
520
+ ngAfterContentInit() {
521
+ if (!this.isItemsInputUsed) {
522
+ this._setItemsFromComponents();
523
+ }
524
+ }
525
+ ngOnChanges(changes) {
526
+ //fire items load handler when loading is set to false
527
+ if (changes['loading']) {
528
+ if (changes['loading'].currentValue == false) {
529
+ this._onItemsLoad();
530
+ }
531
+ }
532
+ //set groupItems to true by default if groupLabelFrom or itemsAlreadyGrouped is set to true as the first change
533
+ if ((changes['groupLabelFrom']?.firstChange || changes['itemsAlreadyGrouped']?.firstChange) && !changes['groupItems']) {
534
+ this.groupItems = true;
535
+ }
536
+ }
537
+ _onItemsLoad() {
538
+ if (!this._searchBarFocused)
539
+ return;
540
+ this.open();
541
+ }
542
+ _printPrimitiveWarnings() {
543
+ function makeWarning(str) {
544
+ console.warn(`Skipped using [${str}] property bound to <ard-select>, as some provided items are of primitive type`);
545
+ }
546
+ if (this.valueFrom) {
547
+ makeWarning('valueFrom');
548
+ }
549
+ if (this.labelFrom) {
550
+ makeWarning('labelFrom');
551
+ }
552
+ if (this.disabledFrom) {
553
+ makeWarning('disabledFrom');
554
+ }
555
+ if (this.groupLabelFrom) {
556
+ makeWarning('groupLabelFrom');
557
+ }
558
+ if (this.groupDisabledFrom) {
559
+ makeWarning('groupDisabledFrom');
560
+ }
561
+ if (this.childrenFrom) {
562
+ makeWarning('childrenFrom');
563
+ }
564
+ if (this.invertDisabled) {
565
+ makeWarning('invertDisabled');
566
+ }
567
+ }
568
+ //! getters
569
+ get firstHighlightedItem() {
570
+ return this.itemStorage.highlightedItems?.first();
571
+ }
572
+ get shouldDisplayPlaceholder() {
573
+ return !this.itemStorage.isAnyItemSelected && !this.searchTerm;
574
+ }
575
+ get shouldDisplayValue() {
576
+ return this.itemStorage.isAnyItemSelected && (!this.searchTerm || this.multiselectable);
577
+ }
578
+ get shouldShowClearButton() {
579
+ return this._clearable && !this._disabled && (this.itemStorage.isAnyItemSelected || this.searchTerm != '');
580
+ }
581
+ get itemsToDisplay() {
582
+ return this.itemStorage.groups.values();
583
+ }
584
+ get shouldShowNoItemsFound() {
585
+ return this.itemStorage.isNoItemsFound && !this.isLoading && !this.shouldShowAddCustom;
586
+ }
587
+ get totalItems() {
588
+ return this.itemStorage.items.length;
589
+ }
590
+ get foundItems() {
591
+ if (!this.searchable)
592
+ return undefined;
593
+ return this.itemStorage.filteredItems.length;
594
+ }
595
+ get shouldShowItemDisplayLimit() {
596
+ return this.multiselectable && this.itemDisplayLimit != Infinity && this.itemStorage.selectedItems.length > this.itemDisplayLimit;
597
+ }
598
+ get isInputElementReadonly() {
599
+ return !this.addCustom && (!this.searchable || this.itemStorage.isItemLimitReached);
600
+ }
601
+ isValueWithinDisplayLimit(i) {
602
+ return !this.multiselectable || this.itemDisplayLimit == Infinity || i < this.itemDisplayLimit;
603
+ }
604
+ get placeholderForCurrentContext() {
605
+ if (this.searchPlaceholder && this.searchable && (this._searchBarFocused || this._isClickedWithin))
606
+ return this.searchPlaceholder;
607
+ return this.placeholder;
608
+ }
609
+ //! search input event handlers
610
+ filter(filterTerm, suppressSearchEvent = false) {
611
+ this.searchTerm = filterTerm;
612
+ let matching = this.itemStorage.filter(filterTerm);
613
+ if (!suppressSearchEvent)
614
+ this.searchEvent.emit({ search: filterTerm, matching });
615
+ this.open();
616
+ }
617
+ onSearchInputFocus(event) {
618
+ this._searchBarFocused = true;
619
+ }
620
+ onSearchInputBlur(event) {
621
+ if (!this._searchBarFocused)
622
+ return;
623
+ this._onTouched();
624
+ this._searchBarFocused = false;
625
+ }
626
+ //! item selection handlers
627
+ toggleItem(item) {
628
+ if (item.selected) {
629
+ this.unselectItem(item);
630
+ return;
631
+ }
632
+ this.selectItem(item);
633
+ }
634
+ selectItem(...items) {
635
+ let [selected, unselected, failedToSelect] = this.itemStorage.selectItem(...items);
636
+ if (unselected.length > 0)
637
+ this.removeEvent.emit(unselected);
638
+ if (failedToSelect.length > 0) {
639
+ this.failedToAddEvent.emit(failedToSelect);
640
+ }
641
+ if (selected.length > 0) {
642
+ this.addEvent.emit(selected);
643
+ this._emitChange();
644
+ this.focus();
645
+ if (!this.keepSearchAfterSelect)
646
+ this._clearSearch(true);
647
+ if (!this.keepOpen || this.itemStorage.isNoItemsToSelect) {
648
+ this.close();
649
+ }
650
+ }
651
+ }
652
+ unselectItem(...items) {
653
+ let unselected = this.itemStorage.unselectItem(...items);
654
+ this.removeEvent.emit(unselected);
655
+ this._emitChange();
656
+ if (!this.keepSearchAfterSelect)
657
+ this._clearSearch();
658
+ this.focus();
659
+ if (!this.keepOpen || this.itemStorage.isNoItemsToSelect) {
660
+ this.close();
661
+ }
662
+ }
663
+ _clearAllItems() {
664
+ let cleared = this.itemStorage.clearAllSelected(true);
665
+ this.focus();
666
+ this.clearEvent.emit();
667
+ this.removeEvent.emit(cleared);
668
+ this._emitChange();
669
+ }
670
+ _clearLastItem() {
671
+ let clearedValue = this.itemStorage.clearLastSelected().value;
672
+ this.focus();
673
+ this.removeEvent.emit([clearedValue]);
674
+ this._emitChange();
675
+ }
676
+ //! highligh-related
677
+ onMouseMove() {
678
+ this._isMouseBeingUsed = true;
679
+ }
680
+ onGroupMouseover(group) {
681
+ if (!this.multiselectable || this.noGroupActions)
682
+ return;
683
+ this.itemStorage.highlightGroup(group);
684
+ }
685
+ onItemMouseOver(event) {
686
+ event.stopPropagation();
687
+ }
688
+ onItemMouseEnter(option, event) {
689
+ if (!this._isMouseBeingUsed)
690
+ return;
691
+ this.itemStorage.highlightSingleItem(option);
692
+ event.stopPropagation();
693
+ }
694
+ onItemMouseLeave(option, event) {
695
+ if (!this._isMouseBeingUsed)
696
+ return;
697
+ this.itemStorage.unhighlightItem(option);
698
+ event.stopPropagation();
699
+ }
700
+ onItemClick(option, event) {
701
+ event.stopPropagation();
702
+ if (this.clearable)
703
+ this.toggleItem(option);
704
+ else
705
+ this.selectItem(option);
706
+ this._isClickedWithin = true;
707
+ }
708
+ onGroupClick(group) {
709
+ if (!this.multiselectable || this.noGroupActions)
710
+ return;
711
+ if (group.children.every(o => o.selected)) {
712
+ this.unselectItem(...group.children);
713
+ return;
714
+ }
715
+ this.selectItem(...group.children);
716
+ this._isClickedWithin = true;
717
+ }
718
+ handleClearButtonClick(event) {
719
+ event.stopPropagation();
720
+ if (this.searchTerm) {
721
+ this._clearSearch();
722
+ return;
723
+ }
724
+ this._clearAllItems();
725
+ }
726
+ handleDropdownArrowClick(event) {
727
+ event.stopPropagation();
728
+ this._isClickedWithin = true;
729
+ this.toggle();
730
+ }
731
+ handleOutsideClick(event) {
732
+ if (!this.isDropdownOpen)
733
+ return;
734
+ const target = event.target;
735
+ if (this.element.contains(target))
736
+ return;
737
+ this.close();
738
+ }
739
+ handleAnywhereClick(event) {
740
+ const target = event.target;
741
+ if (target.tagName != 'INPUT') {
742
+ event.preventDefault();
743
+ }
744
+ this._isClickedWithin = true;
745
+ if (!this._searchBarFocused) {
746
+ this.focus();
747
+ }
748
+ if (this._searchable) {
749
+ this.open();
750
+ }
751
+ else {
752
+ this.toggle();
753
+ }
754
+ }
755
+ onMouseup() {
756
+ this._isClickedWithin = false;
757
+ }
758
+ //! dropdown state handlers
759
+ toggle() {
760
+ if (this.isDropdownOpen) {
761
+ this.close();
762
+ return;
763
+ }
764
+ this.open();
765
+ }
766
+ open() {
767
+ if (this.disabled || this.isDropdownOpen)
768
+ return;
769
+ this.isDropdownOpen = true;
770
+ if (this.autoHighlightFirst)
771
+ this.itemStorage.highlightFirstItem();
772
+ this._createOverlay();
773
+ this.focus();
774
+ this.openEvent.emit();
775
+ this.isDropdownOpenChange.emit(this.isDropdownOpen);
776
+ this.detectChanges();
777
+ }
778
+ close() {
779
+ if (!this.isDropdownOpen)
780
+ return;
781
+ this.isDropdownOpen = false;
782
+ this._destroyOverlay();
783
+ this._onTouched();
784
+ this.closeEvent.emit();
785
+ this.isDropdownOpenChange.emit(this.isDropdownOpen);
786
+ this._cd.markForCheck();
787
+ }
788
+ //! ChangeDetectorRef
789
+ detectChanges() {
790
+ if (!this._cd.destroyed) {
791
+ this._cd.detectChanges();
792
+ }
793
+ }
794
+ //! search
795
+ _clearSearch(suppressSearchEvent = false) {
796
+ this._setSearch('', suppressSearchEvent);
797
+ }
798
+ _setSearch(searchTerm, suppressSearchEvent = false) {
799
+ this.searchTerm = searchTerm;
800
+ this.filter(searchTerm, suppressSearchEvent);
801
+ }
802
+ _setSearchInputAttributes() {
803
+ const input = this.searchInput.nativeElement;
804
+ const attributes = {
805
+ type: 'text',
806
+ autocorrect: 'off',
807
+ autocapitalize: 'off',
808
+ autocomplete: 'off',
809
+ ...this.inputAttrs,
810
+ };
811
+ for (const key of Object.keys(attributes)) {
812
+ input.setAttribute(key, attributes[key]);
813
+ }
814
+ }
815
+ //! key press handlers
816
+ onKeyPress(event) {
817
+ switch (event.code) {
818
+ case 'Enter': {
819
+ this._onEnterPress(event);
820
+ return;
821
+ }
822
+ case 'Space': {
823
+ this._onSpacePress(event);
824
+ return;
825
+ }
826
+ case 'ArrowDown': {
827
+ this._onArrowDownPress(event);
828
+ return;
829
+ }
830
+ case 'ArrowUp': {
831
+ this._onArrowUpPress(event);
832
+ return;
833
+ }
834
+ case 'Home': {
835
+ this._onHomePress(event);
836
+ return;
837
+ }
838
+ case 'End': {
839
+ this._onEndPress(event);
840
+ return;
841
+ }
842
+ case 'Backspace':
843
+ case 'Delete': {
844
+ this._onBackspaceOrDeletePress(event);
845
+ return;
846
+ }
847
+ case 'KeyA': {
848
+ if (event.ctrlKey) {
849
+ this._onCtrlAPress(event);
850
+ return;
851
+ }
852
+ }
853
+ }
854
+ }
855
+ async _onEnterPress(event) {
856
+ event.preventDefault();
857
+ let shouldClose = true;
858
+ //select the currently highlighted option
859
+ if (this.isDropdownOpen && this.firstHighlightedItem) {
860
+ if (this.clearable && this.itemStorage.highlightedItems.every(item => item.selected)) {
861
+ this.unselectItem(...this.itemStorage.highlightedItems);
862
+ }
863
+ else {
864
+ this.selectItem(...this.itemStorage.highlightedItems);
865
+ }
866
+ }
867
+ //add a custom option
868
+ else if (this.isDropdownOpen && this.shouldShowAddCustom) {
869
+ await this.addCustomOption(this.searchTerm);
870
+ }
871
+ //in case of no action, open the dropdown (or keep it open)
872
+ else
873
+ shouldClose = false;
874
+ if (!this.keepOpen && shouldClose) {
875
+ this.itemStorage.clearAllHighlights();
876
+ this.close();
877
+ }
878
+ else {
879
+ this.open();
880
+ }
881
+ }
882
+ _onSpacePress(event) {
883
+ if (this.isDropdownOpen)
884
+ return;
885
+ event.preventDefault();
886
+ this.open();
887
+ }
888
+ _onArrowDownPress(event) {
889
+ event.preventDefault();
890
+ this.open();
891
+ this._isMouseBeingUsed = false;
892
+ const recentlyHighlighted = this.itemStorage.highlightNextItem(+1, event.shiftKey);
893
+ if (recentlyHighlighted) {
894
+ this.itemStorage.setRecentlyHighlighted(recentlyHighlighted);
895
+ }
896
+ this.dropdownPanel.scrollToRecentlyHighlighted('bottom');
897
+ }
898
+ _onArrowUpPress(event) {
899
+ if (!this.isDropdownOpen)
900
+ return;
901
+ event.preventDefault();
902
+ this._isMouseBeingUsed = false;
903
+ const recentlyHighlighted = this.itemStorage.highlightNextItem(-1, event.shiftKey);
904
+ if (recentlyHighlighted) {
905
+ this.itemStorage.setRecentlyHighlighted(recentlyHighlighted);
906
+ }
907
+ this.dropdownPanel.scrollToRecentlyHighlighted('top');
908
+ }
909
+ _onHomePress(event) {
910
+ if (!this.isDropdownOpen || (this.searchInput.nativeElement.selectionEnd != 0 && this.searchInput.nativeElement.selectionStart != 0))
911
+ return;
912
+ event.preventDefault();
913
+ this._isMouseBeingUsed = false;
914
+ const recentlyHighlighted = this.itemStorage.highlightFirstItem();
915
+ if (!recentlyHighlighted)
916
+ return;
917
+ this.itemStorage.setRecentlyHighlighted(recentlyHighlighted);
918
+ this.dropdownPanel.scrollToRecentlyHighlighted('top');
919
+ }
920
+ _onEndPress(event) {
921
+ if (!this.isDropdownOpen ||
922
+ (this.searchInput.nativeElement.selectionEnd != this.searchTerm.length && this.searchInput.nativeElement.selectionStart != this.searchTerm.length))
923
+ return;
924
+ event.preventDefault();
925
+ this._isMouseBeingUsed = false;
926
+ const recentlyHighlighted = this.itemStorage.highlightLastItem();
927
+ if (!recentlyHighlighted)
928
+ return;
929
+ this.itemStorage.setRecentlyHighlighted(recentlyHighlighted);
930
+ this.dropdownPanel.scrollToRecentlyHighlighted('bottom');
931
+ }
932
+ _onBackspaceOrDeletePress(event) {
933
+ if (this.searchTerm || !this._clearable || this.noBackspaceClear || !this.itemStorage.isAnyItemSelected)
934
+ return;
935
+ event.preventDefault();
936
+ if (this.multiselectable && this.itemStorage.selectedItems.length > 1) {
937
+ this._clearLastItem();
938
+ return;
939
+ }
940
+ this._clearAllItems();
941
+ }
942
+ _onCtrlAPress(event) {
943
+ this.itemStorage.highlightAllItems();
944
+ }
945
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ArdiumSelectComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.Overlay }, { token: i0.ViewContainerRef }, { token: i1.ScrollStrategyOptions }], target: i0.ɵɵFactoryTarget.Component }); }
946
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.7", type: ArdiumSelectComponent, selector: "ard-select", inputs: { valueFrom: "valueFrom", labelFrom: "labelFrom", disabledFrom: "disabledFrom", groupLabelFrom: "groupLabelFrom", groupDisabledFrom: "groupDisabledFrom", childrenFrom: "childrenFrom", placeholder: "placeholder", searchPlaceholder: "searchPlaceholder", dropdownPosition: "dropdownPosition", clearButtonTitle: "clearButtonTitle", noItemsFoundText: "noItemsFoundText", loadingPlaceholderText: "loadingPlaceholderText", searchInputId: "searchInputId", isLoading: "isLoading", inputAttrs: "inputAttrs", htmlId: "htmlId", itemsAlreadyGrouped: "itemsAlreadyGrouped", invertDisabled: "invertDisabled", noGroupActions: "noGroupActions", autoHighlightFirst: "autoHighlightFirst", autoFocus: "autoFocus", keepOpen: "keepOpen", hideSelected: "hideSelected", noBackspaceClear: "noBackspaceClear", sortMultipleValues: "sortMultipleValues", searchCaseSensitive: "searchCaseSensitive", keepSearchAfterSelect: "keepSearchAfterSelect", maxSelectedItems: "maxSelectedItems", itemDisplayLimit: "itemDisplayLimit", searchFn: "searchFn", compareWith: "compareWith", appearance: "appearance", variant: "variant", compact: "compact", dropdowonAppearance: "dropdowonAppearance", dropdowonVariant: "dropdowonVariant", groupItems: "groupItems", items: "items", multiselectable: "multiselectable", clearable: "clearable", searchable: "searchable", addCustom: "addCustom", value: "value", isDropdownOpen: ["isOpen", "isDropdownOpen"] }, outputs: { valueChange: "valueChange", changeEvent: "change", addEvent: "add", failedToAddEvent: "failedToAdd", removeEvent: "remove", clearEvent: "clear", openEvent: "open", closeEvent: "close", scrollEvent: "scroll", scrollToEndEvent: "scrollToEnd", searchEvent: "search", isDropdownOpenChange: "isOpenChange" }, host: { listeners: { "window:resize": "onWindowResize()", "mouseup": "onMouseup()", "keydown": "onKeyPress($event)" }, properties: { "class.ard-group-items": "this.groupItems", "attr.multiple": "this.multiselectable" } }, providers: [
947
+ {
948
+ provide: NG_VALUE_ACCESSOR,
949
+ useExisting: forwardRef(() => ArdiumSelectComponent),
950
+ multi: true,
951
+ },
952
+ ], queries: [{ propertyName: "optionTemplate", first: true, predicate: ArdOptionTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "optgroupTemplate", first: true, predicate: ArdOptgroupTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "valueTemplate", first: true, predicate: ArdValueTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "placeholderTemplate", first: true, predicate: ArdSelectPlaceholderTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "loadingSpinnerTemplate", first: true, predicate: ArdLoadingSpinnerTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "loadingPlaceholderTemplate", first: true, predicate: ArdLoadingPlaceholderTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "dropdownHeaderTemplate", first: true, predicate: ArdDropdownHeaderTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "dropdownFooterTemplate", first: true, predicate: ArdDropdownFooterTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "noItemsFoundTemplate", first: true, predicate: ArdNoItemsFoundTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "addCustomTemplate", first: true, predicate: ArdAddCustomTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "itemLimitReachedTemplate", first: true, predicate: ArdItemLimitReachedTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "itemDisplayLimitTemplate", first: true, predicate: ArdItemDisplayLimitTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "prefixTemplate", first: true, predicate: ArdSelectPrefixTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "suffixTemplate", first: true, predicate: ArdSelectSuffixTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "optionComponents", predicate: ArdiumOptionComponent }], viewQueries: [{ propertyName: "searchInput", first: true, predicate: ["searchInput"], descendants: true, static: true }, { propertyName: "dropdownPanel", first: true, predicate: i0.forwardRef(() => ArdiumDropdownPanelComponent), descendants: true }, { propertyName: "dropdownHost", first: true, predicate: ["dropdownHost"], descendants: true, read: ElementRef }, { propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true, read: TemplateRef }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ard-form-field-frame\r\n [appearance]=\"appearance\"\r\n [variant]=\"variant\"\r\n [compact]=\"compact\"\r\n [isFocused]=\"isFocused\"\r\n [prefixTemplate]=\"prefixTemplate\"\r\n [suffixTemplate]=\"suffixTemplate\"\r\n>\r\n <div class=\"ard-select\"\r\n #dropdownHost\r\n (click)=\"handleAnywhereClick($event)\"\r\n [class.ard-has-value]=\"itemStorage.isAnyItemSelected\"\r\n [ngClass]=\"ngClasses\"\r\n >\r\n <div class=\"ard-select-value-container\">\r\n <ng-container *ngIf=\"shouldDisplayPlaceholder\">\r\n <ng-template #defaultPlaceholderTemplate let-plhldr>\r\n <div class=\"ard-placeholder\">{{ plhldr }}</div>\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"placeholderTemplate || defaultPlaceholderTemplate\"\r\n [ngTemplateOutletContext]=\"getPlaceholderContext()\"\r\n ></ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"shouldDisplayValue\">\r\n <div class=\"ard-select-value\"\r\n *ngFor=\"let item of itemStorage.selectedItems; let i = index\"\r\n [class.ard-value-disabled]=\"item.disabled\"\r\n [attr.hidden]=\"!isValueWithinDisplayLimit(i) ? true : null\"\r\n >\r\n <ng-template *ngIf=\"isValueWithinDisplayLimit(i)\"\r\n [ngTemplateOutlet]=\"valueTemplate || (multiselectable ? defaultMultiValueTemplate : defaultValueTemplate)\"\r\n [ngTemplateOutletContext]=\"getValueContext(item)\"\r\n ></ng-template>\r\n </div>\r\n\r\n <ng-template #defaultValueTemplate let-item>\r\n <div [ardInnerHTML]=\"item.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></div>\r\n </ng-template>\r\n <ng-template #defaultMultiValueTemplate let-item let-unselect=\"unselect\">\r\n <ard-deletable-chip\r\n (delete)=\"unselect(item)\"\r\n [variant]=\"variant\"\r\n compact\r\n appearance=\"outlined-strong\"\r\n >\r\n <div [ardInnerHTML]=\"item.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></div>\r\n </ard-deletable-chip>\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"itemStorage.isAnyItemSelected && shouldShowItemDisplayLimit\">\r\n <div class=\"ard-overflow-indicator\">\r\n <ng-template\r\n [ngTemplateOutlet]=\"itemDisplayLimitTemplate || defaultItemDisplayLimitTemplate\"\r\n [ngTemplateOutletContext]=\"getItemDisplayLimitContext()\"\r\n ></ng-template>\r\n\r\n <ng-template #defaultItemDisplayLimitTemplate let-count=\"overflowCount\">\r\n <div>{{count}} more...</div>\r\n </ng-template>\r\n </div>\r\n </ng-container>\r\n \r\n <div class=\"ard-search-input\"\r\n role=\"combobox\"\r\n aria-haspopup=\"listbox\"\r\n [attr.aria-expanded]=\"isDropdownOpen\"\r\n [attr.aria-owns]=\"isDropdownOpen ? htmlId : null\"\r\n >\r\n <input #searchInput\r\n #focusableElement\r\n type=\"text\"\r\n [attr.id]=\"searchInputId\"\r\n [attr.tabindex]=\"tabIndex\"\r\n [readonly]=\"isInputElementReadonly\"\r\n [disabled]=\"disabled\"\r\n [value]=\"searchTerm\"\r\n aria-autocomplete=\"list\"\r\n [attr.aria-controls]=\"isDropdownOpen ? htmlId : null\"\r\n (input)=\"filter(searchInput.value)\"\r\n (change)=\"$event.stopPropagation()\"\r\n (focus)=\"onFocus($event)\"\r\n (focus)=\"onSearchInputFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (blur)=\"onSearchInputBlur($event)\"\r\n >\r\n </div>\r\n </div>\r\n\r\n <div class=\"ard-select-controls\">\r\n <ng-container *ngIf=\"isLoading\">\r\n <ng-template #defaultLoadingSpinnerTemplate>\r\n <div class=\"ard-simple-spinner\"></div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"loadingSpinnerTemplate || defaultLoadingSpinnerTemplate\">\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ard-_clear-button *ngIf=\"shouldShowClearButton\"\r\n [title]=\"clearButtonTitle\"\r\n (click)=\"handleClearButtonClick($event)\"\r\n ></ard-_clear-button>\r\n\r\n <div class=\"ard-dropdown-arrow-wrapper\"\r\n role=\"button\"\r\n (click)=\"handleDropdownArrowClick($event)\"\r\n >\r\n <span class=\"ard-dropdown-arrow\"></span>\r\n <div class=\"ard-hitbox\"></div>\r\n </div>\r\n </div>\r\n </div>\r\n</ard-form-field-frame>\r\n\r\n\r\n<ng-template #dropdownTemplate>\r\n <ard-dropdown-panel\r\n class=\"ard-dropdown-panel ard-select-dropdown-panel\"\r\n role=\"listbox\"\r\n aria-label=\"Options list\"\r\n [headerTemplate]=\"dropdownHeaderTemplate\"\r\n [footerTemplate]=\"dropdownFooterTemplate\"\r\n [appearance]=\"dropdownAppearance\"\r\n [variant]=\"dropdownVariant\"\r\n [isOpen]=\"true\"\r\n [filterValue]=\"searchTerm\"\r\n [panelId]=\"htmlId\"\r\n [compact]=\"compact\"\r\n (ardClickOutside)=\"handleOutsideClick($event)\"\r\n (mousemove)=\"onMouseMove()\"\r\n (scroll)=\"scrollEvent.emit($event)\"\r\n (scrollToEnd)=\"scrollToEndEvent.emit($event)\"\r\n >\r\n <ng-container *ngIf=\"!shouldShowNoItemsFound\">\r\n <div\r\n class=\"ard-optgroup\"\r\n role=\"group\"\r\n *ngFor=\"let group of itemStorage.groups\"\r\n [class.ard-group-disabled]=\"group.disabled\"\r\n [class.ard-group-selected]=\"group.selected\"\r\n [class.ard-group-highlighted]=\"group.highlighted\"\r\n (mouseover)=\"onGroupMouseover(group)\"\r\n (click)=\"onGroupClick(group)\"\r\n >\r\n <ng-container *ngIf=\"group.label !== '' && group.label !== undefined\">\r\n <ng-template #defaultOptgroupTemplate>\r\n <span class=\"ard-optgroup-label\" [ardInnerHTML]=\"group.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></span>\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"optgroupTemplate || defaultOptgroupTemplate\"\r\n [ngTemplateOutletContext]=\"getGroupContext(group)\"\r\n ></ng-template>\r\n </ng-container>\r\n\r\n <div class=\"ard-optgroup-children\">\r\n <div\r\n class=\"ard-option\"\r\n role=\"option\"\r\n *ngFor=\"let option of group.children\"\r\n [class.ard-option-disabled]=\"option.disabled\"\r\n [class.ard-option-selected]=\"option.selected\"\r\n [class.ard-option-highlighted]=\"option.highlighted\"\r\n [class.ard-option-highlighted-recent]=\"option.highlighted_recently\"\r\n [attr.aria-selected]=\"option.selected\"\r\n [attr.id]=\"htmlId + '-' + option.index\"\r\n (click)=\"onItemClick(option, $event)\"\r\n (mouseover)=\"onItemMouseOver($event)\"\r\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\r\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\r\n >\r\n <div class=\"ard-option-label\">\r\n <ng-template #defaultOptionTemplate>\r\n <span [ardInnerHTML]=\"option.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></span>\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"optionTemplate || defaultOptionTemplate\"\r\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\r\n ></ng-template>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"shouldShowNoItemsFound\">\r\n <ng-template #defaultNoItemsFoundTemplate>\r\n <div class=\"ard-option ard-option-disabled\">{{noItemsFoundText}}</div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"noItemsFoundTemplate || defaultNoItemsFoundTemplate\"\r\n [ngTemplateOutletContext]=\"getSearchContext()\">\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"shouldShowAddCustom\">\r\n <ng-template #defaultAddCustomTemplate let-searchTerm>\r\n <div class=\"ard-option ard-option-highlighted ard-add-custom\" (click)=\"addCustomOption(searchTerm)\">\r\n <span class=\"ard-add-custom-label\">Add option</span>\r\n <span class=\"ard-add-custom-value\">\"{{searchTerm}}\"</span>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"addCustomTemplate || defaultAddCustomTemplate\"\r\n [ngTemplateOutletContext]=\"getCustomOptionContext()\">\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"isLoading\">\r\n <ng-template #defaultLoadingPlaceholderTemplate>\r\n <div class=\"ard-option ard-option-disabled\">{{loadingPlaceholderText}}</div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"loadingPlaceholderTemplate || defaultLoadingPlaceholderTemplate\"\r\n [ngTemplateOutletContext]=\"getSearchContext()\">\r\n </ng-template>\r\n </ng-container>\r\n </ard-dropdown-panel>\r\n</ng-template>", styles: ["@import\"@angular/cdk/overlay-prebuilt.css\";.ard-select .ard-select-container{display:flex;cursor:pointer}.ard-select .ard-placeholder,.ard-select .ard-value,.ard-select .ard-dropdown-arrow-wrapper,.ard-select .ard-clear-btn-wrapper{-webkit-user-select:none;user-select:none}.ard-select .ard-clear-btn,.ard-select .ard-dropdown-arrow{border:none;background:transparent;padding:0;box-sizing:content-box}.ard-select .ard-option-disabled{pointer-events:none}.ard-select .ard-value[hidden]{display:none}.ard-select .ard-searchable .ard-select-value-container{cursor:text}.ard-select .ard-dropdown-arrow-wrapper{position:relative}.ard-select .ard-dropdown-arrow-wrapper .ard-hitbox{position:absolute;left:-4px;right:-4px;aspect-ratio:1}.ard-select-dropdown-panel .ard-optgroup,.ard-select-dropdown-panel .ard-option{-webkit-user-select:none;user-select:none}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.ArdiumFormFieldFrameComponent, selector: "ard-form-field-frame", inputs: ["isFocused", "appearance", "variant", "compact", "prefixTemplate", "suffixTemplate"] }, { kind: "component", type: i4.ArdiumDropdownPanelComponent, selector: "ard-dropdown-panel", inputs: ["panelId", "headerTemplate", "footerTemplate", "filterValue", "appearance", "variant", "compact", "isOpen"], outputs: ["scroll", "scrollToEnd"] }, { kind: "component", type: i5.ArdiumDeletableChipComponent, selector: "ard-deletable-chip", inputs: ["deleteButtonTitle", "contentAlignment", "appearance", "variant", "color", "compact", "wrapperClasses"], outputs: ["delete"] }, { kind: "directive", type: i6.ClickOutsideDirective, selector: "[ardClickOutside]", outputs: ["ardClickOutside"] }, { kind: "component", type: i7._ClearButtonComponent, selector: "ard-_clear-button" }, { kind: "directive", type: i6.ArdiumInnerHTMLDirective, selector: "[ardInnerHTML]", inputs: ["ardInnerHTML", "ardEscapeInnerHTML"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
953
+ }
954
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ArdiumSelectComponent, decorators: [{
955
+ type: Component,
956
+ args: [{ selector: 'ard-select', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
957
+ {
958
+ provide: NG_VALUE_ACCESSOR,
959
+ useExisting: forwardRef(() => ArdiumSelectComponent),
960
+ multi: true,
961
+ },
962
+ ], template: "<ard-form-field-frame\r\n [appearance]=\"appearance\"\r\n [variant]=\"variant\"\r\n [compact]=\"compact\"\r\n [isFocused]=\"isFocused\"\r\n [prefixTemplate]=\"prefixTemplate\"\r\n [suffixTemplate]=\"suffixTemplate\"\r\n>\r\n <div class=\"ard-select\"\r\n #dropdownHost\r\n (click)=\"handleAnywhereClick($event)\"\r\n [class.ard-has-value]=\"itemStorage.isAnyItemSelected\"\r\n [ngClass]=\"ngClasses\"\r\n >\r\n <div class=\"ard-select-value-container\">\r\n <ng-container *ngIf=\"shouldDisplayPlaceholder\">\r\n <ng-template #defaultPlaceholderTemplate let-plhldr>\r\n <div class=\"ard-placeholder\">{{ plhldr }}</div>\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"placeholderTemplate || defaultPlaceholderTemplate\"\r\n [ngTemplateOutletContext]=\"getPlaceholderContext()\"\r\n ></ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"shouldDisplayValue\">\r\n <div class=\"ard-select-value\"\r\n *ngFor=\"let item of itemStorage.selectedItems; let i = index\"\r\n [class.ard-value-disabled]=\"item.disabled\"\r\n [attr.hidden]=\"!isValueWithinDisplayLimit(i) ? true : null\"\r\n >\r\n <ng-template *ngIf=\"isValueWithinDisplayLimit(i)\"\r\n [ngTemplateOutlet]=\"valueTemplate || (multiselectable ? defaultMultiValueTemplate : defaultValueTemplate)\"\r\n [ngTemplateOutletContext]=\"getValueContext(item)\"\r\n ></ng-template>\r\n </div>\r\n\r\n <ng-template #defaultValueTemplate let-item>\r\n <div [ardInnerHTML]=\"item.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></div>\r\n </ng-template>\r\n <ng-template #defaultMultiValueTemplate let-item let-unselect=\"unselect\">\r\n <ard-deletable-chip\r\n (delete)=\"unselect(item)\"\r\n [variant]=\"variant\"\r\n compact\r\n appearance=\"outlined-strong\"\r\n >\r\n <div [ardInnerHTML]=\"item.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></div>\r\n </ard-deletable-chip>\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"itemStorage.isAnyItemSelected && shouldShowItemDisplayLimit\">\r\n <div class=\"ard-overflow-indicator\">\r\n <ng-template\r\n [ngTemplateOutlet]=\"itemDisplayLimitTemplate || defaultItemDisplayLimitTemplate\"\r\n [ngTemplateOutletContext]=\"getItemDisplayLimitContext()\"\r\n ></ng-template>\r\n\r\n <ng-template #defaultItemDisplayLimitTemplate let-count=\"overflowCount\">\r\n <div>{{count}} more...</div>\r\n </ng-template>\r\n </div>\r\n </ng-container>\r\n \r\n <div class=\"ard-search-input\"\r\n role=\"combobox\"\r\n aria-haspopup=\"listbox\"\r\n [attr.aria-expanded]=\"isDropdownOpen\"\r\n [attr.aria-owns]=\"isDropdownOpen ? htmlId : null\"\r\n >\r\n <input #searchInput\r\n #focusableElement\r\n type=\"text\"\r\n [attr.id]=\"searchInputId\"\r\n [attr.tabindex]=\"tabIndex\"\r\n [readonly]=\"isInputElementReadonly\"\r\n [disabled]=\"disabled\"\r\n [value]=\"searchTerm\"\r\n aria-autocomplete=\"list\"\r\n [attr.aria-controls]=\"isDropdownOpen ? htmlId : null\"\r\n (input)=\"filter(searchInput.value)\"\r\n (change)=\"$event.stopPropagation()\"\r\n (focus)=\"onFocus($event)\"\r\n (focus)=\"onSearchInputFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (blur)=\"onSearchInputBlur($event)\"\r\n >\r\n </div>\r\n </div>\r\n\r\n <div class=\"ard-select-controls\">\r\n <ng-container *ngIf=\"isLoading\">\r\n <ng-template #defaultLoadingSpinnerTemplate>\r\n <div class=\"ard-simple-spinner\"></div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"loadingSpinnerTemplate || defaultLoadingSpinnerTemplate\">\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ard-_clear-button *ngIf=\"shouldShowClearButton\"\r\n [title]=\"clearButtonTitle\"\r\n (click)=\"handleClearButtonClick($event)\"\r\n ></ard-_clear-button>\r\n\r\n <div class=\"ard-dropdown-arrow-wrapper\"\r\n role=\"button\"\r\n (click)=\"handleDropdownArrowClick($event)\"\r\n >\r\n <span class=\"ard-dropdown-arrow\"></span>\r\n <div class=\"ard-hitbox\"></div>\r\n </div>\r\n </div>\r\n </div>\r\n</ard-form-field-frame>\r\n\r\n\r\n<ng-template #dropdownTemplate>\r\n <ard-dropdown-panel\r\n class=\"ard-dropdown-panel ard-select-dropdown-panel\"\r\n role=\"listbox\"\r\n aria-label=\"Options list\"\r\n [headerTemplate]=\"dropdownHeaderTemplate\"\r\n [footerTemplate]=\"dropdownFooterTemplate\"\r\n [appearance]=\"dropdownAppearance\"\r\n [variant]=\"dropdownVariant\"\r\n [isOpen]=\"true\"\r\n [filterValue]=\"searchTerm\"\r\n [panelId]=\"htmlId\"\r\n [compact]=\"compact\"\r\n (ardClickOutside)=\"handleOutsideClick($event)\"\r\n (mousemove)=\"onMouseMove()\"\r\n (scroll)=\"scrollEvent.emit($event)\"\r\n (scrollToEnd)=\"scrollToEndEvent.emit($event)\"\r\n >\r\n <ng-container *ngIf=\"!shouldShowNoItemsFound\">\r\n <div\r\n class=\"ard-optgroup\"\r\n role=\"group\"\r\n *ngFor=\"let group of itemStorage.groups\"\r\n [class.ard-group-disabled]=\"group.disabled\"\r\n [class.ard-group-selected]=\"group.selected\"\r\n [class.ard-group-highlighted]=\"group.highlighted\"\r\n (mouseover)=\"onGroupMouseover(group)\"\r\n (click)=\"onGroupClick(group)\"\r\n >\r\n <ng-container *ngIf=\"group.label !== '' && group.label !== undefined\">\r\n <ng-template #defaultOptgroupTemplate>\r\n <span class=\"ard-optgroup-label\" [ardInnerHTML]=\"group.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></span>\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"optgroupTemplate || defaultOptgroupTemplate\"\r\n [ngTemplateOutletContext]=\"getGroupContext(group)\"\r\n ></ng-template>\r\n </ng-container>\r\n\r\n <div class=\"ard-optgroup-children\">\r\n <div\r\n class=\"ard-option\"\r\n role=\"option\"\r\n *ngFor=\"let option of group.children\"\r\n [class.ard-option-disabled]=\"option.disabled\"\r\n [class.ard-option-selected]=\"option.selected\"\r\n [class.ard-option-highlighted]=\"option.highlighted\"\r\n [class.ard-option-highlighted-recent]=\"option.highlighted_recently\"\r\n [attr.aria-selected]=\"option.selected\"\r\n [attr.id]=\"htmlId + '-' + option.index\"\r\n (click)=\"onItemClick(option, $event)\"\r\n (mouseover)=\"onItemMouseOver($event)\"\r\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\r\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\r\n >\r\n <div class=\"ard-option-label\">\r\n <ng-template #defaultOptionTemplate>\r\n <span [ardInnerHTML]=\"option.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></span>\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"optionTemplate || defaultOptionTemplate\"\r\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\r\n ></ng-template>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"shouldShowNoItemsFound\">\r\n <ng-template #defaultNoItemsFoundTemplate>\r\n <div class=\"ard-option ard-option-disabled\">{{noItemsFoundText}}</div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"noItemsFoundTemplate || defaultNoItemsFoundTemplate\"\r\n [ngTemplateOutletContext]=\"getSearchContext()\">\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"shouldShowAddCustom\">\r\n <ng-template #defaultAddCustomTemplate let-searchTerm>\r\n <div class=\"ard-option ard-option-highlighted ard-add-custom\" (click)=\"addCustomOption(searchTerm)\">\r\n <span class=\"ard-add-custom-label\">Add option</span>\r\n <span class=\"ard-add-custom-value\">\"{{searchTerm}}\"</span>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"addCustomTemplate || defaultAddCustomTemplate\"\r\n [ngTemplateOutletContext]=\"getCustomOptionContext()\">\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"isLoading\">\r\n <ng-template #defaultLoadingPlaceholderTemplate>\r\n <div class=\"ard-option ard-option-disabled\">{{loadingPlaceholderText}}</div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"loadingPlaceholderTemplate || defaultLoadingPlaceholderTemplate\"\r\n [ngTemplateOutletContext]=\"getSearchContext()\">\r\n </ng-template>\r\n </ng-container>\r\n </ard-dropdown-panel>\r\n</ng-template>", styles: ["@import\"@angular/cdk/overlay-prebuilt.css\";.ard-select .ard-select-container{display:flex;cursor:pointer}.ard-select .ard-placeholder,.ard-select .ard-value,.ard-select .ard-dropdown-arrow-wrapper,.ard-select .ard-clear-btn-wrapper{-webkit-user-select:none;user-select:none}.ard-select .ard-clear-btn,.ard-select .ard-dropdown-arrow{border:none;background:transparent;padding:0;box-sizing:content-box}.ard-select .ard-option-disabled{pointer-events:none}.ard-select .ard-value[hidden]{display:none}.ard-select .ard-searchable .ard-select-value-container{cursor:text}.ard-select .ard-dropdown-arrow-wrapper{position:relative}.ard-select .ard-dropdown-arrow-wrapper .ard-hitbox{position:absolute;left:-4px;right:-4px;aspect-ratio:1}.ard-select-dropdown-panel .ard-optgroup,.ard-select-dropdown-panel .ard-option{-webkit-user-select:none;user-select:none}\n"] }]
963
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.Overlay }, { type: i0.ViewContainerRef }, { type: i1.ScrollStrategyOptions }], propDecorators: { valueFrom: [{
964
+ type: Input
965
+ }], labelFrom: [{
966
+ type: Input
967
+ }], disabledFrom: [{
968
+ type: Input
969
+ }], groupLabelFrom: [{
970
+ type: Input
971
+ }], groupDisabledFrom: [{
972
+ type: Input
973
+ }], childrenFrom: [{
974
+ type: Input
975
+ }], placeholder: [{
976
+ type: Input
977
+ }], searchPlaceholder: [{
978
+ type: Input
979
+ }], dropdownPosition: [{
980
+ type: Input
981
+ }], clearButtonTitle: [{
982
+ type: Input
983
+ }], noItemsFoundText: [{
984
+ type: Input
985
+ }], loadingPlaceholderText: [{
986
+ type: Input
987
+ }], searchInputId: [{
988
+ type: Input
989
+ }], isLoading: [{
990
+ type: Input
991
+ }], inputAttrs: [{
992
+ type: Input
993
+ }], htmlId: [{
994
+ type: Input
995
+ }], itemsAlreadyGrouped: [{
996
+ type: Input
997
+ }], invertDisabled: [{
998
+ type: Input
999
+ }], noGroupActions: [{
1000
+ type: Input
1001
+ }], autoHighlightFirst: [{
1002
+ type: Input
1003
+ }], autoFocus: [{
1004
+ type: Input
1005
+ }], keepOpen: [{
1006
+ type: Input
1007
+ }], hideSelected: [{
1008
+ type: Input
1009
+ }], noBackspaceClear: [{
1010
+ type: Input
1011
+ }], sortMultipleValues: [{
1012
+ type: Input
1013
+ }], searchCaseSensitive: [{
1014
+ type: Input
1015
+ }], keepSearchAfterSelect: [{
1016
+ type: Input
1017
+ }], maxSelectedItems: [{
1018
+ type: Input
1019
+ }], itemDisplayLimit: [{
1020
+ type: Input
1021
+ }], searchFn: [{
1022
+ type: Input
1023
+ }], compareWith: [{
1024
+ type: Input
1025
+ }], appearance: [{
1026
+ type: Input
1027
+ }], variant: [{
1028
+ type: Input
1029
+ }], compact: [{
1030
+ type: Input
1031
+ }], dropdowonAppearance: [{
1032
+ type: Input
1033
+ }], dropdowonVariant: [{
1034
+ type: Input
1035
+ }], groupItems: [{
1036
+ type: Input
1037
+ }, {
1038
+ type: HostBinding,
1039
+ args: ['class.ard-group-items']
1040
+ }], items: [{
1041
+ type: Input
1042
+ }], optionComponents: [{
1043
+ type: ContentChildren,
1044
+ args: [ArdiumOptionComponent]
1045
+ }], multiselectable: [{
1046
+ type: Input
1047
+ }, {
1048
+ type: HostBinding,
1049
+ args: ['attr.multiple']
1050
+ }], clearable: [{
1051
+ type: Input
1052
+ }], searchable: [{
1053
+ type: Input
1054
+ }], addCustom: [{
1055
+ type: Input
1056
+ }], value: [{
1057
+ type: Input
1058
+ }], valueChange: [{
1059
+ type: Output
1060
+ }], changeEvent: [{
1061
+ type: Output,
1062
+ args: ['change']
1063
+ }], addEvent: [{
1064
+ type: Output,
1065
+ args: ['add']
1066
+ }], failedToAddEvent: [{
1067
+ type: Output,
1068
+ args: ['failedToAdd']
1069
+ }], removeEvent: [{
1070
+ type: Output,
1071
+ args: ['remove']
1072
+ }], clearEvent: [{
1073
+ type: Output,
1074
+ args: ['clear']
1075
+ }], openEvent: [{
1076
+ type: Output,
1077
+ args: ['open']
1078
+ }], closeEvent: [{
1079
+ type: Output,
1080
+ args: ['close']
1081
+ }], scrollEvent: [{
1082
+ type: Output,
1083
+ args: ['scroll']
1084
+ }], scrollToEndEvent: [{
1085
+ type: Output,
1086
+ args: ['scrollToEnd']
1087
+ }], searchEvent: [{
1088
+ type: Output,
1089
+ args: ['search']
1090
+ }], isDropdownOpen: [{
1091
+ type: Input,
1092
+ args: ['isOpen']
1093
+ }], isDropdownOpenChange: [{
1094
+ type: Output,
1095
+ args: ['isOpenChange']
1096
+ }], searchInput: [{
1097
+ type: ViewChild,
1098
+ args: ['searchInput', { static: true }]
1099
+ }], dropdownPanel: [{
1100
+ type: ViewChild,
1101
+ args: [forwardRef(() => ArdiumDropdownPanelComponent)]
1102
+ }], optionTemplate: [{
1103
+ type: ContentChild,
1104
+ args: [ArdOptionTemplateDirective, { read: TemplateRef }]
1105
+ }], optgroupTemplate: [{
1106
+ type: ContentChild,
1107
+ args: [ArdOptgroupTemplateDirective, { read: TemplateRef }]
1108
+ }], valueTemplate: [{
1109
+ type: ContentChild,
1110
+ args: [ArdValueTemplateDirective, { read: TemplateRef }]
1111
+ }], placeholderTemplate: [{
1112
+ type: ContentChild,
1113
+ args: [ArdSelectPlaceholderTemplateDirective, { read: TemplateRef }]
1114
+ }], loadingSpinnerTemplate: [{
1115
+ type: ContentChild,
1116
+ args: [ArdLoadingSpinnerTemplateDirective, { read: TemplateRef }]
1117
+ }], loadingPlaceholderTemplate: [{
1118
+ type: ContentChild,
1119
+ args: [ArdLoadingPlaceholderTemplateDirective, { read: TemplateRef }]
1120
+ }], dropdownHeaderTemplate: [{
1121
+ type: ContentChild,
1122
+ args: [ArdDropdownHeaderTemplateDirective, { read: TemplateRef }]
1123
+ }], dropdownFooterTemplate: [{
1124
+ type: ContentChild,
1125
+ args: [ArdDropdownFooterTemplateDirective, { read: TemplateRef }]
1126
+ }], noItemsFoundTemplate: [{
1127
+ type: ContentChild,
1128
+ args: [ArdNoItemsFoundTemplateDirective, { read: TemplateRef }]
1129
+ }], addCustomTemplate: [{
1130
+ type: ContentChild,
1131
+ args: [ArdAddCustomTemplateDirective, { read: TemplateRef }]
1132
+ }], itemLimitReachedTemplate: [{
1133
+ type: ContentChild,
1134
+ args: [ArdItemLimitReachedTemplateDirective, { read: TemplateRef }]
1135
+ }], itemDisplayLimitTemplate: [{
1136
+ type: ContentChild,
1137
+ args: [ArdItemDisplayLimitTemplateDirective, { read: TemplateRef }]
1138
+ }], prefixTemplate: [{
1139
+ type: ContentChild,
1140
+ args: [ArdSelectPrefixTemplateDirective, { read: TemplateRef }]
1141
+ }], suffixTemplate: [{
1142
+ type: ContentChild,
1143
+ args: [ArdSelectSuffixTemplateDirective, { read: TemplateRef }]
1144
+ }], dropdownHost: [{
1145
+ type: ViewChild,
1146
+ args: ['dropdownHost', { read: ElementRef }]
1147
+ }], dropdownTemplate: [{
1148
+ type: ViewChild,
1149
+ args: ['dropdownTemplate', { read: TemplateRef }]
1150
+ }], onWindowResize: [{
1151
+ type: HostListener,
1152
+ args: ['window:resize']
1153
+ }], onMouseup: [{
1154
+ type: HostListener,
1155
+ args: ['mouseup']
1156
+ }], onKeyPress: [{
1157
+ type: HostListener,
1158
+ args: ['keydown', ['$event']]
1159
+ }] } });
1160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/select/select.component.ts","../../../../../projects/ui/src/lib/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef, ScrollStrategyOptions } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef,\n    ViewEncapsulation,\n    forwardRef,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { coerceArrayProperty, coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\nimport { Subject, merge, startWith, takeUntil } from 'rxjs';\nimport { isAnyString, isArray, isFunction } from 'simple-bool';\nimport { ItemStorage } from '../_internal/item-storages/dropdown-item-storage';\nimport { _NgModelComponentBase } from '../_internal/ngmodel-component';\nimport { ArdiumDropdownPanelComponent } from '../dropdown-panel/dropdown-panel.component';\nimport { DropdownPanelAppearance, DropdownPanelVariant } from '../dropdown-panel/dropdown-panel.types';\nimport { ArdiumOptionComponent } from '../option/option.component';\nimport { searchFunctions } from '../search-functions';\nimport { ArdOption, ArdOptionGroup, ArdPanelPosition, CompareWithFn, GroupByFn, OptionContext, SearchFn } from '../types/item-storage.types';\nimport { FormElementAppearance } from '../types/theming.types';\nimport { FormElementVariant } from './../types/theming.types';\nimport {\n    ArdAddCustomTemplateDirective,\n    ArdDropdownFooterTemplateDirective,\n    ArdDropdownHeaderTemplateDirective,\n    ArdItemDisplayLimitTemplateDirective,\n    ArdItemLimitReachedTemplateDirective,\n    ArdLoadingPlaceholderTemplateDirective,\n    ArdLoadingSpinnerTemplateDirective,\n    ArdNoItemsFoundTemplateDirective,\n    ArdOptgroupTemplateDirective,\n    ArdOptionTemplateDirective,\n    ArdSelectPlaceholderTemplateDirective,\n    ArdSelectPrefixTemplateDirective,\n    ArdSelectSuffixTemplateDirective,\n    ArdValueTemplateDirective,\n} from './select.directive';\nimport {\n    AddCustomFn,\n    CustomOptionContext,\n    GroupContext,\n    ItemDisplayLimitContext,\n    ItemLimitContext,\n    PlaceholderContext,\n    SearchContext,\n    StatsContext,\n    ValueContext,\n} from './select.types';\n\n@Component({\n    selector: 'ard-select',\n    templateUrl: './select.component.html',\n    styleUrls: ['./select.component.scss'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => ArdiumSelectComponent),\n            multi: true,\n        },\n    ],\n})\nexport class ArdiumSelectComponent\n    extends _NgModelComponentBase\n    implements OnChanges, AfterViewInit, AfterContentInit, OnInit, OnDestroy, ControlValueAccessor\n{\n    //! public constants\n    readonly itemStorage = new ItemStorage(this);\n    readonly element!: HTMLElement;\n    readonly DEFAULTS = {\n        valueFrom: 'value',\n        labelFrom: 'label',\n        disabledFrom: 'disabled',\n        groupLabelFrom: 'group',\n        groupDisabledFrom: 'disabled',\n        childrenFrom: 'children',\n        searchFn: searchFunctions.byLabel,\n        clearButtonTitle: 'Clear',\n        noItemsFoundText: 'No items found.',\n        loadingPlaceholderText: 'Loading...',\n    };\n\n    //! privates\n    private _items: any[] | null = [];\n    private _isMouseBeingUsed = false;\n    private _searchBarFocused = false;\n    private readonly _destroy$ = new Subject<void>();\n\n    //! publics\n    public searchTerm: string = '';\n    isItemsInputUsed: boolean = false;\n\n    //! binding-related inputs\n    //value/label/disabled/group/pre-grouped children paths\n    @Input() valueFrom?: string;\n    @Input() labelFrom?: string;\n    @Input() disabledFrom?: string;\n    //! group-related inputs\n    @Input() groupLabelFrom?: string | GroupByFn;\n    @Input() groupDisabledFrom?: string;\n    @Input() childrenFrom?: string;\n    //! settings\n    @Input() placeholder: string = 'Select item';\n    @Input() searchPlaceholder: string = 'Search...';\n    @Input() dropdownPosition: ArdPanelPosition = ArdPanelPosition.Auto;\n    @Input() clearButtonTitle: string = this.DEFAULTS.clearButtonTitle;\n    //! template-related settings\n    @Input() noItemsFoundText: string = this.DEFAULTS.noItemsFoundText;\n    @Input() loadingPlaceholderText: string = this.DEFAULTS.loadingPlaceholderText;\n    //! search-related options\n    @Input() searchInputId?: string;\n    //! other inputs\n    @Input() isLoading: boolean = false;\n    @Input() inputAttrs: { [key: string]: any } = {};\n    @Input() htmlId: string = crypto.randomUUID();\n\n    //! boolean settings\n    private _itemsAlreadyGrouped: boolean = false;\n    @Input()\n    get itemsAlreadyGrouped(): boolean {\n        return this._itemsAlreadyGrouped;\n    }\n    set itemsAlreadyGrouped(v: any) {\n        this._itemsAlreadyGrouped = coerceBooleanProperty(v);\n    }\n\n    //should the value that the \"disabledFrom\" path lead to be inverted?\n    //useful when the property is e.g. \"active\", which is the oposite of \"disabled\"\n    private _invertDisabled: boolean = false;\n    @Input()\n    get invertDisabled(): boolean {\n        return this._invertDisabled;\n    }\n    set invertDisabled(v: any) {\n        this._invertDisabled = coerceBooleanProperty(v);\n    }\n\n    private _noGroupActions: boolean = false;\n    @Input()\n    get noGroupActions(): boolean {\n        return this._noGroupActions;\n    }\n    set noGroupActions(v: any) {\n        this._noGroupActions = coerceBooleanProperty(v);\n    }\n\n    private _autoHighlightFirst: boolean = true;\n    @Input()\n    get autoHighlightFirst(): boolean {\n        return this._autoHighlightFirst;\n    }\n    set autoHighlightFirst(v: any) {\n        this._autoHighlightFirst = coerceBooleanProperty(v);\n    }\n\n    private _autoFocus: boolean = false;\n    @Input()\n    get autoFocus(): boolean {\n        return this._autoFocus;\n    }\n    set autoFocus(v: any) {\n        this._autoFocus = coerceBooleanProperty(v);\n    }\n\n    private _keepOpen: boolean = false;\n    @Input()\n    get keepOpen(): boolean {\n        return this._keepOpen;\n    }\n    set keepOpen(v: any) {\n        this._keepOpen = coerceBooleanProperty(v);\n    }\n\n    private _hideSelected: boolean = false;\n    @Input()\n    get hideSelected(): boolean {\n        return this._hideSelected;\n    }\n    set hideSelected(v: any) {\n        this._hideSelected = coerceBooleanProperty(v);\n    }\n\n    private _clearOnBackspace: boolean = false;\n    @Input()\n    get noBackspaceClear(): boolean {\n        return this._clearOnBackspace;\n    }\n    set noBackspaceClear(v: any) {\n        this._clearOnBackspace = coerceBooleanProperty(v);\n    }\n\n    private _sortMultipleValues: boolean = false;\n    @Input()\n    get sortMultipleValues(): boolean {\n        return this._sortMultipleValues;\n    }\n    set sortMultipleValues(v: any) {\n        this._sortMultipleValues = coerceBooleanProperty(v);\n    }\n\n    private _searchCaseSensitive: boolean = false;\n    @Input()\n    get searchCaseSensitive(): boolean {\n        return this._searchCaseSensitive;\n    }\n    set searchCaseSensitive(v: any) {\n        this._searchCaseSensitive = coerceBooleanProperty(v);\n    }\n\n    private _keepSearchAfterSelect: boolean = false;\n    @Input()\n    get keepSearchAfterSelect(): boolean {\n        return this._keepSearchAfterSelect;\n    }\n    set keepSearchAfterSelect(v: any) {\n        this._keepSearchAfterSelect = coerceBooleanProperty(v);\n    }\n\n    //! number inputs\n    private _maxSelectedItems: number | undefined = undefined;\n    @Input()\n    get maxSelectedItems(): number | undefined {\n        return this._maxSelectedItems;\n    }\n    set maxSelectedItems(v: any) {\n        this._maxSelectedItems = coerceNumberProperty(v, undefined);\n    }\n\n    private _itemDisplayLimit: number = Infinity;\n    @Input()\n    get itemDisplayLimit(): number {\n        return this._itemDisplayLimit;\n    }\n    set itemDisplayLimit(v: any) {\n        this._itemDisplayLimit = coerceNumberProperty(v, Infinity);\n    }\n\n    //! function inputs\n    private _searchFn: SearchFn = this.DEFAULTS.searchFn;\n    @Input()\n    get searchFn(): SearchFn {\n        return this._searchFn;\n    }\n    set searchFn(fn: SearchFn) {\n        if (fn !== undefined && fn !== null && !isFunction(fn)) {\n            throw Error('`searchFn` must be a function.');\n        }\n        this._searchFn = fn;\n    }\n    private _compareWith?: CompareWithFn;\n    @Input()\n    get compareWith(): CompareWithFn | undefined {\n        return this._compareWith;\n    }\n    set compareWith(fn: CompareWithFn | undefined) {\n        if (fn !== undefined && fn !== null && !isFunction(fn)) {\n            throw Error('`compareWith` must be a function.');\n        }\n        this._compareWith = fn;\n    }\n\n    //! appearance\n    @Input() appearance: FormElementAppearance = FormElementAppearance.Outlined;\n    @Input() variant: FormElementVariant = FormElementVariant.Rounded;\n\n    private _compact: boolean = false;\n    @Input()\n    get compact(): boolean {\n        return this._compact;\n    }\n    set compact(v: any) {\n        this._compact = coerceBooleanProperty(v);\n    }\n\n    get ngClasses(): string {\n        return [\n            //appearance, variant handled in ard-form-field-frame component\n            this.compact ? 'ard-compact' : '',\n            this.multiselectable ? 'ard-multiselect' : 'ard-singleselect',\n            this.clearable ? 'ard-clearable' : '',\n            this.searchable ? 'ard-searchable' : '',\n            this.filtered ? 'ard-filtered' : '',\n            this.touched ? 'ard-touched' : '',\n            this.isDropdownOpen ? 'ard-dropdown-open' : '',\n            this._searchBarFocused ? 'ard-select-focused' : '',\n            this._searchBarFocused ? 'ard-select-focused' : '',\n        ].join(' ');\n    }\n\n    private _dropdownAppearance?: DropdownPanelAppearance = undefined;\n    @Input()\n    set dropdowonAppearance(v: DropdownPanelAppearance) {\n        this._dropdownAppearance = v;\n    }\n    get dropdownAppearance(): DropdownPanelAppearance {\n        if (this._dropdownAppearance) return this._dropdownAppearance;\n        if (this.appearance == FormElementAppearance.Outlined) return DropdownPanelAppearance.Outlined;\n        return DropdownPanelAppearance.Raised;\n    }\n    private _dropdownVariant?: DropdownPanelVariant = undefined;\n    @Input()\n    set dropdowonVariant(v: DropdownPanelVariant) {\n        this._dropdownVariant = v;\n    }\n    get dropdownVariant(): DropdownPanelVariant {\n        if (this._dropdownVariant) return this._dropdownVariant;\n        if (this.variant == FormElementVariant.Pill) return DropdownPanelVariant.Rounded;\n        return this.variant;\n    }\n\n    //! class-based inputs\n    @Input() @HostBinding('class.ard-group-items') groupItems: boolean = false; //default value may be changed to \"true\" in ngOnChanges if this.groupBy is defined or this.itemsAlreadyGrouped is set to \"true\"\n\n    //! items setter/getter\n    @Input()\n    get items() {\n        return this._items;\n    }\n    set items(value: string | any[] | null) {\n        this.isItemsInputUsed = true;\n        if (value === null) {\n            value = [];\n            this.isItemsInputUsed = false;\n        } else if (isAnyString(value)) {\n            value = coerceArrayProperty(value);\n        }\n        let printErrors = this.itemStorage.setItems(value);\n        if (printErrors) {\n            this._printPrimitiveWarnings();\n        }\n    }\n\n    @ContentChildren(ArdiumOptionComponent)\n    optionComponents!: QueryList<ArdiumOptionComponent>;\n\n    private _setItemsFromComponents() {\n        const handleOptionChange = () => {\n            const changedOrDestroyed = merge(this.optionComponents.changes, this._destroy$);\n            merge(...this.optionComponents.map(option => option.stateChange$))\n                .pipe(takeUntil(changedOrDestroyed))\n                .subscribe(option => {\n                    setTimeout(() => {\n                        const item = this.itemStorage.findItemByValue(option.oldValue ?? option.value);\n                        if (item) {\n                            item.disabled = option.disabled;\n                            item.label = option.label || item.label;\n                            item.value = option.value;\n                            item.itemData.disabled = option.disabled;\n                            item.itemData.label = option.label || item.label;\n                            item.itemData.value = option.value;\n                        }\n                        this.detectChanges();\n                    }, 0);\n                });\n        };\n        this.optionComponents.changes\n            .pipe(startWith(this.optionComponents), takeUntil(this._destroy$))\n            .subscribe((options: QueryList<ArdiumOptionComponent>) => {\n                if (options.length == 0) return;\n                setTimeout(() => {\n                    this.items = options.map(option => ({\n                        value: option.value,\n                        label: option.label,\n                        disabled: option.disabled,\n                    }));\n                    handleOptionChange();\n                    this.detectChanges();\n                }, 0);\n            });\n    }\n\n    //! attribute and/or class setters/getters\n    private _multiselectable: boolean = false;\n    @Input()\n    @HostBinding('attr.multiple')\n    get multiselectable(): boolean {\n        return this._multiselectable;\n    }\n    set multiselectable(v: any) {\n        this._multiselectable = coerceBooleanProperty(v);\n    }\n    get singleselectable(): boolean {\n        return !this._multiselectable;\n    }\n\n    private _clearable: boolean = true;\n    @Input()\n    get clearable(): boolean {\n        return this._clearable;\n    }\n    set clearable(v: any) {\n        this._clearable = coerceBooleanProperty(v);\n    }\n\n    private _searchable: boolean = false;\n    @Input()\n    get searchable(): boolean {\n        return this._searchable;\n    }\n    set searchable(v: any) {\n        this._searchable = coerceBooleanProperty(v);\n    }\n\n    get filtered(): boolean {\n        return this._searchable && this.searchTerm != '';\n    }\n\n    private _touched: boolean = false;\n    get touched(): boolean {\n        return this._touched;\n    }\n    private set touched(state: boolean) {\n        this._touched = state;\n    }\n\n    //! custom options\n    private _defaultAddCustomFn: AddCustomFn<any> = (value: string) => value;\n    private _addCustom: false | AddCustomFn<any> | AddCustomFn<Promise<any>> = false;\n    @Input()\n    get addCustom(): false | AddCustomFn<any> | AddCustomFn<Promise<any>> {\n        return this._addCustom;\n    }\n    set addCustom(v: string | boolean | AddCustomFn<any> | AddCustomFn<Promise<any>>) {\n        if (isFunction(v)) {\n            this._addCustom = v;\n            return;\n        }\n        //coerce the value into a boolean\n        //if \"true\", use the default function. Otherwise, just set to \"false\".\n        this._addCustom = coerceBooleanProperty(v) && this._defaultAddCustomFn;\n    }\n\n    get shouldShowAddCustom(): boolean {\n        return this.addCustom != false && this.searchTerm.length > 0 && this.itemStorage.isNoItemsFound;\n    }\n\n    async addCustomOption(value: string) {\n        if (!this.addCustom) return;\n\n        const newOptionObj = await this.itemStorage.addCustomOption(value, this.addCustom);\n\n        this.selectItem(newOptionObj);\n    }\n\n    //! control value accessor\n    //override the writeValue and setDisabledState defined in _NgModelComponent\n    override setDisabledState(state: boolean): void {\n        this._disabled = state;\n        this._cd.markForCheck();\n    }\n    writeValue(ngModel: any[]): void {\n        this.itemStorage.handleWriteValue(ngModel);\n        this._cd.markForCheck();\n    }\n    //* change & touch event emitters\n    protected _emitChange(): void {\n        let value = this.itemStorage.value;\n        this._onChangeRegistered?.(value);\n        this.changeEvent.emit(value);\n        this.valueChange.emit(value);\n    }\n    private _onTouched(): void {\n        this.touched = true;\n        this._onTouchedRegistered?.();\n    }\n\n    //! value input & output\n    @Input()\n    set value(newValue: any) {\n        //if is a string, coerce it into array of strings\n        if (isAnyString(newValue)) newValue = coerceArrayProperty(newValue);\n        //if it is not a string and not an array, just put it in an array\n        else if (!isArray(newValue)) newValue = [newValue];\n\n        this.writeValue(newValue);\n    }\n    get value(): any[] {\n        return this.itemStorage.value;\n    }\n    @Output() valueChange = new EventEmitter<any[]>();\n\n    //! output events\n    @Output('change') changeEvent = new EventEmitter<any[]>();\n    @Output('add') addEvent = new EventEmitter<any[]>();\n    @Output('failedToAdd') failedToAddEvent = new EventEmitter<any[]>();\n    @Output('remove') removeEvent = new EventEmitter<any[]>();\n    @Output('clear') clearEvent = new EventEmitter<null>();\n    @Output('open') openEvent = new EventEmitter<null>();\n    @Output('close') closeEvent = new EventEmitter<null>();\n    @Output('scroll') scrollEvent = new EventEmitter<{\n        start: number;\n        end: number;\n    }>();\n    @Output('scrollToEnd') scrollToEndEvent = new EventEmitter();\n    @Output('search') searchEvent = new EventEmitter<{\n        search: string;\n        matching: any[];\n    }>();\n\n    @Input('isOpen')\n    isDropdownOpen!: boolean;\n    @Output('isOpenChange') isDropdownOpenChange = new EventEmitter<boolean>();\n\n    //! view children\n    @ViewChild('searchInput', { static: true })\n    searchInput!: ElementRef<HTMLInputElement>;\n    @ViewChild(forwardRef(() => ArdiumDropdownPanelComponent))\n    dropdownPanel!: ArdiumDropdownPanelComponent;\n\n    //! templates\n    @ContentChild(ArdOptionTemplateDirective, { read: TemplateRef })\n    optionTemplate?: TemplateRef<any>;\n    @ContentChild(ArdOptgroupTemplateDirective, { read: TemplateRef })\n    optgroupTemplate?: TemplateRef<any>;\n    @ContentChild(ArdValueTemplateDirective, { read: TemplateRef })\n    valueTemplate?: TemplateRef<any>;\n    @ContentChild(ArdSelectPlaceholderTemplateDirective, { read: TemplateRef })\n    placeholderTemplate?: TemplateRef<any>;\n    @ContentChild(ArdLoadingSpinnerTemplateDirective, { read: TemplateRef })\n    loadingSpinnerTemplate?: TemplateRef<any>;\n    @ContentChild(ArdLoadingPlaceholderTemplateDirective, { read: TemplateRef })\n    loadingPlaceholderTemplate?: TemplateRef<any>;\n    @ContentChild(ArdDropdownHeaderTemplateDirective, { read: TemplateRef })\n    dropdownHeaderTemplate?: TemplateRef<any>;\n    @ContentChild(ArdDropdownFooterTemplateDirective, { read: TemplateRef })\n    dropdownFooterTemplate?: TemplateRef<any>;\n    @ContentChild(ArdNoItemsFoundTemplateDirective, { read: TemplateRef })\n    noItemsFoundTemplate?: TemplateRef<any>;\n    @ContentChild(ArdAddCustomTemplateDirective, { read: TemplateRef })\n    addCustomTemplate?: TemplateRef<any>;\n    @ContentChild(ArdItemLimitReachedTemplateDirective, { read: TemplateRef })\n    itemLimitReachedTemplate?: TemplateRef<any>;\n    @ContentChild(ArdItemDisplayLimitTemplateDirective, { read: TemplateRef })\n    itemDisplayLimitTemplate?: TemplateRef<any>;\n\n    @ContentChild(ArdSelectPrefixTemplateDirective, { read: TemplateRef })\n    prefixTemplate?: TemplateRef<any>;\n    @ContentChild(ArdSelectSuffixTemplateDirective, { read: TemplateRef })\n    suffixTemplate?: TemplateRef<any>;\n\n    //! context providers\n    getValueContext(item: ArdOption): ValueContext {\n        const $this = this;\n        return {\n            $implicit: item,\n            item,\n            itemData: item.itemData,\n            unselect() {\n                $this.unselectItem(item);\n            },\n        };\n    }\n    getStatsContext(): StatsContext {\n        return {\n            totalItems: this.totalItems,\n            foundItems: this.foundItems,\n        };\n    }\n    getSearchContext(): SearchContext {\n        return {\n            $implicit: this.searchTerm,\n            searchTerm: this.searchTerm,\n            totalItems: this.totalItems,\n            foundItems: this.foundItems,\n        };\n    }\n    getPlaceholderContext(): PlaceholderContext {\n        const placeholder = this.placeholderForCurrentContext;\n        return {\n            placeholder,\n            $implicit: placeholder,\n        };\n    }\n    getCustomOptionContext(): CustomOptionContext {\n        return {\n            $implicit: this.searchTerm,\n            searchTerm: this.searchTerm,\n        };\n    }\n    getGroupContext(group: ArdOptionGroup): GroupContext {\n        return {\n            $implicit: group,\n            group,\n            selectedChildren: group.children.filter(v => v.selected).length,\n            totalChildren: group.children.length,\n        };\n    }\n    getOptionContext(item: ArdOption): OptionContext {\n        return {\n            $implicit: item,\n            item,\n            itemData: item.itemData,\n        };\n    }\n    getItemLimitContext(): ItemLimitContext {\n        return {\n            totalItems: this.totalItems,\n            selectedItems: this.itemStorage.selectedItems.length,\n            itemLimit: this.maxSelectedItems,\n        };\n    }\n    getItemDisplayLimitContext(): ItemDisplayLimitContext {\n        let selectedItems = this.itemStorage.selectedItems.length;\n        return {\n            totalItems: this.totalItems,\n            selectedItems,\n            itemLimit: this.maxSelectedItems,\n            overflowCount: selectedItems - (this.itemDisplayLimit ?? 0),\n        };\n    }\n\n    constructor(\n        _elementRef: ElementRef<HTMLElement>,\n        private _cd: ChangeDetectorRef,\n        private overlay: Overlay,\n        private viewContainerRef: ViewContainerRef,\n        private scrollStrategyOpts: ScrollStrategyOptions\n    ) {\n        super();\n        this.element = _elementRef.nativeElement;\n    }\n\n    //! dropdown overlay\n    @ViewChild('dropdownHost', { read: ElementRef })\n    dropdownHost!: ElementRef<HTMLDivElement>;\n    @ViewChild('dropdownTemplate', { read: TemplateRef })\n    dropdownTemplate!: TemplateRef<any>;\n\n    private dropdownOverlay?: OverlayRef;\n\n    private _createOverlay(): void {\n        const strategy = this.overlay\n            .position()\n            .flexibleConnectedTo(this.dropdownHost)\n            .withPositions([\n                {\n                    originX: 'start',\n                    originY: 'bottom',\n                    overlayX: 'start',\n                    overlayY: 'top',\n                },\n                {\n                    originX: 'start',\n                    originY: 'top',\n                    overlayX: 'start',\n                    overlayY: 'bottom',\n                },\n            ]);\n\n        const config = new OverlayConfig({\n            positionStrategy: strategy,\n            scrollStrategy: this.scrollStrategyOpts.block(),\n            hasBackdrop: false,\n        });\n\n        this.dropdownOverlay = this.overlay.create(config);\n\n        const portal = new TemplatePortal(this.dropdownTemplate, this.viewContainerRef);\n        this.dropdownOverlay.attach(portal);\n        this.setOverlaySize();\n    }\n    private _destroyOverlay(): void {\n        if (!this.dropdownOverlay) return;\n\n        this.dropdownOverlay.dispose();\n        delete this.dropdownOverlay;\n    }\n\n    setOverlaySize(): void {\n        if (!this.dropdownOverlay) return;\n\n        const rect = this.dropdownHost.nativeElement.getBoundingClientRect();\n        this.dropdownOverlay.updateSize({ width: rect.width });\n    }\n\n    @HostListener('window:resize')\n    onWindowResize(): void {\n        this.setOverlaySize();\n    }\n\n    //! hooks\n    ngOnInit(): void {\n        this._setSearchInputAttributes();\n    }\n    ngOnDestroy() {\n        this._destroy$.next();\n        this._destroy$.complete();\n    }\n    ngAfterViewInit(): void {\n        if (this.autoFocus) {\n            this.focus();\n        }\n    }\n    ngAfterContentInit(): void {\n        if (!this.isItemsInputUsed) {\n            this._setItemsFromComponents();\n        }\n    }\n    ngOnChanges(changes: SimpleChanges): void {\n        //fire items load handler when loading is set to false\n        if (changes['loading']) {\n            if (changes['loading'].currentValue == false) {\n                this._onItemsLoad();\n            }\n        }\n        //set groupItems to true by default if groupLabelFrom or itemsAlreadyGrouped is set to true as the first change\n        if ((changes['groupLabelFrom']?.firstChange || changes['itemsAlreadyGrouped']?.firstChange) && !changes['groupItems']) {\n            this.groupItems = true;\n        }\n    }\n    private _onItemsLoad() {\n        if (!this._searchBarFocused) return;\n        this.open();\n    }\n    private _printPrimitiveWarnings() {\n        function makeWarning(str: string): void {\n            console.warn(`Skipped using [${str}] property bound to <ard-select>, as some provided items are of primitive type`);\n        }\n        if (this.valueFrom) {\n            makeWarning('valueFrom');\n        }\n        if (this.labelFrom) {\n            makeWarning('labelFrom');\n        }\n        if (this.disabledFrom) {\n            makeWarning('disabledFrom');\n        }\n        if (this.groupLabelFrom) {\n            makeWarning('groupLabelFrom');\n        }\n        if (this.groupDisabledFrom) {\n            makeWarning('groupDisabledFrom');\n        }\n        if (this.childrenFrom) {\n            makeWarning('childrenFrom');\n        }\n        if (this.invertDisabled) {\n            makeWarning('invertDisabled');\n        }\n    }\n\n    //! getters\n    get firstHighlightedItem(): ArdOption | undefined {\n        return this.itemStorage.highlightedItems?.first();\n    }\n    get shouldDisplayPlaceholder(): boolean {\n        return !this.itemStorage.isAnyItemSelected && !this.searchTerm;\n    }\n    get shouldDisplayValue(): boolean {\n        return this.itemStorage.isAnyItemSelected && (!this.searchTerm || this.multiselectable);\n    }\n    get shouldShowClearButton(): boolean {\n        return this._clearable && !this._disabled && (this.itemStorage.isAnyItemSelected || this.searchTerm != '');\n    }\n    get itemsToDisplay(): IterableIterator<ArdOptionGroup> {\n        return this.itemStorage.groups.values();\n    }\n    get shouldShowNoItemsFound(): boolean {\n        return this.itemStorage.isNoItemsFound && !this.isLoading && !this.shouldShowAddCustom;\n    }\n    get totalItems(): number {\n        return this.itemStorage.items.length;\n    }\n    get foundItems(): number | undefined {\n        if (!this.searchable) return undefined;\n        return this.itemStorage.filteredItems.length;\n    }\n    get shouldShowItemDisplayLimit(): boolean {\n        return this.multiselectable && this.itemDisplayLimit != Infinity && this.itemStorage.selectedItems.length > this.itemDisplayLimit;\n    }\n    get isInputElementReadonly(): boolean {\n        return !this.addCustom && (!this.searchable || this.itemStorage.isItemLimitReached);\n    }\n    isValueWithinDisplayLimit(i: number): boolean {\n        return !this.multiselectable || this.itemDisplayLimit == Infinity || i < this.itemDisplayLimit;\n    }\n    get placeholderForCurrentContext(): string {\n        if (this.searchPlaceholder && this.searchable && (this._searchBarFocused || this._isClickedWithin)) return this.searchPlaceholder;\n        return this.placeholder;\n    }\n\n    //! search input event handlers\n    filter(filterTerm: string, suppressSearchEvent: boolean = false): void {\n        this.searchTerm = filterTerm;\n        let matching = this.itemStorage.filter(filterTerm);\n        if (!suppressSearchEvent) this.searchEvent.emit({ search: filterTerm, matching });\n        this.open();\n    }\n    onSearchInputFocus(event: FocusEvent): void {\n        this._searchBarFocused = true;\n    }\n    onSearchInputBlur(event: FocusEvent): void {\n        if (!this._searchBarFocused) return;\n\n        this._onTouched();\n\n        this._searchBarFocused = false;\n    }\n    //! item selection handlers\n    toggleItem(item: ArdOption): void {\n        if (item.selected) {\n            this.unselectItem(item);\n            return;\n        }\n        this.selectItem(item);\n    }\n    selectItem(...items: ArdOption[]): void {\n        let [selected, unselected, failedToSelect] = this.itemStorage.selectItem(...items);\n\n        if (unselected.length > 0) this.removeEvent.emit(unselected);\n\n        if (failedToSelect.length > 0) {\n            this.failedToAddEvent.emit(failedToSelect);\n        }\n\n        if (selected.length > 0) {\n            this.addEvent.emit(selected);\n            this._emitChange();\n\n            this.focus();\n            if (!this.keepSearchAfterSelect) this._clearSearch(true);\n\n            if (!this.keepOpen || this.itemStorage.isNoItemsToSelect) {\n                this.close();\n            }\n        }\n    }\n    unselectItem(...items: ArdOption[]): void {\n        let unselected = this.itemStorage.unselectItem(...items);\n\n        this.removeEvent.emit(unselected);\n        this._emitChange();\n        if (!this.keepSearchAfterSelect) this._clearSearch();\n\n        this.focus();\n\n        if (!this.keepOpen || this.itemStorage.isNoItemsToSelect) {\n            this.close();\n        }\n    }\n    private _clearAllItems(): void {\n        let cleared = this.itemStorage.clearAllSelected(true);\n\n        this.focus();\n\n        this.clearEvent.emit();\n        this.removeEvent.emit(cleared);\n        this._emitChange();\n    }\n    private _clearLastItem(): void {\n        let clearedValue = this.itemStorage.clearLastSelected().value;\n\n        this.focus();\n\n        this.removeEvent.emit([clearedValue]);\n        this._emitChange();\n    }\n    //! highligh-related\n    onMouseMove() {\n        this._isMouseBeingUsed = true;\n    }\n    onGroupMouseover(group: ArdOptionGroup): void {\n        if (!this.multiselectable || this.noGroupActions) return;\n        this.itemStorage.highlightGroup(group);\n    }\n    onItemMouseOver(event: MouseEvent): void {\n        event.stopPropagation();\n    }\n    onItemMouseEnter(option: ArdOption, event: MouseEvent): void {\n        if (!this._isMouseBeingUsed) return;\n        this.itemStorage.highlightSingleItem(option);\n        event.stopPropagation();\n    }\n    onItemMouseLeave(option: ArdOption, event: MouseEvent): void {\n        if (!this._isMouseBeingUsed) return;\n        this.itemStorage.unhighlightItem(option);\n        event.stopPropagation();\n    }\n    //! click handlers\n    private _isClickedWithin: boolean = false;\n    onItemClick(option: ArdOption, event: MouseEvent): void {\n        event.stopPropagation();\n        if (this.clearable) this.toggleItem(option);\n        else this.selectItem(option);\n\n        this._isClickedWithin = true;\n    }\n    onGroupClick(group: ArdOptionGroup): void {\n        if (!this.multiselectable || this.noGroupActions) return;\n        if (group.children.every(o => o.selected)) {\n            this.unselectItem(...group.children);\n            return;\n        }\n        this.selectItem(...group.children);\n\n        this._isClickedWithin = true;\n    }\n    handleClearButtonClick(event: MouseEvent): void {\n        event.stopPropagation();\n        if (this.searchTerm) {\n            this._clearSearch();\n            return;\n        }\n        this._clearAllItems();\n    }\n    handleDropdownArrowClick(event: MouseEvent): void {\n        event.stopPropagation();\n\n        this._isClickedWithin = true;\n\n        this.toggle();\n    }\n    handleOutsideClick(event: MouseEvent): void {\n        if (!this.isDropdownOpen) return;\n        const target = event.target as HTMLElement;\n        if (this.element.contains(target)) return;\n\n        this.close();\n    }\n    handleAnywhereClick(event: MouseEvent): void {\n        const target = event.target as HTMLElement;\n        if (target.tagName != 'INPUT') {\n            event.preventDefault();\n        }\n\n        this._isClickedWithin = true;\n\n        if (!this._searchBarFocused) {\n            this.focus();\n        }\n\n        if (this._searchable) {\n            this.open();\n        } else {\n            this.toggle();\n        }\n    }\n    @HostListener('mouseup')\n    onMouseup(): void {\n        this._isClickedWithin = false;\n    }\n    //! dropdown state handlers\n    toggle(): void {\n        if (this.isDropdownOpen) {\n            this.close();\n            return;\n        }\n        this.open();\n    }\n    open(): void {\n        if (this.disabled || this.isDropdownOpen) return;\n\n        this.isDropdownOpen = true;\n        if (this.autoHighlightFirst) this.itemStorage.highlightFirstItem();\n\n        this._createOverlay();\n        this.focus();\n\n        this.openEvent.emit();\n        this.isDropdownOpenChange.emit(this.isDropdownOpen);\n        this.detectChanges();\n    }\n    close(): void {\n        if (!this.isDropdownOpen) return;\n\n        this.isDropdownOpen = false;\n\n        this._destroyOverlay();\n\n        this._onTouched();\n        this.closeEvent.emit();\n        this.isDropdownOpenChange.emit(this.isDropdownOpen);\n        this._cd.markForCheck();\n    }\n    //! ChangeDetectorRef\n    detectChanges(): void {\n        if (!(<any>this._cd).destroyed) {\n            this._cd.detectChanges();\n        }\n    }\n    //! search\n    private _clearSearch(suppressSearchEvent: boolean = false): void {\n        this._setSearch('', suppressSearchEvent);\n    }\n    private _setSearch(searchTerm: string, suppressSearchEvent: boolean = false): void {\n        this.searchTerm = searchTerm;\n        this.filter(searchTerm, suppressSearchEvent);\n    }\n    private _setSearchInputAttributes() {\n        const input = this.searchInput.nativeElement;\n        const attributes: { [key: string]: string } = {\n            type: 'text',\n            autocorrect: 'off',\n            autocapitalize: 'off',\n            autocomplete: 'off',\n            ...this.inputAttrs,\n        };\n\n        for (const key of Object.keys(attributes)) {\n            input.setAttribute(key, attributes[key]);\n        }\n    }\n\n    //! key press handlers\n    @HostListener('keydown', ['$event'])\n    onKeyPress(event: KeyboardEvent): void {\n        switch (event.code) {\n            case 'Enter': {\n                this._onEnterPress(event);\n                return;\n            }\n            case 'Space': {\n                this._onSpacePress(event);\n                return;\n            }\n            case 'ArrowDown': {\n                this._onArrowDownPress(event);\n                return;\n            }\n            case 'ArrowUp': {\n                this._onArrowUpPress(event);\n                return;\n            }\n            case 'Home': {\n                this._onHomePress(event);\n                return;\n            }\n            case 'End': {\n                this._onEndPress(event);\n                return;\n            }\n            case 'Backspace':\n            case 'Delete': {\n                this._onBackspaceOrDeletePress(event);\n                return;\n            }\n            case 'KeyA': {\n                if (event.ctrlKey) {\n                    this._onCtrlAPress(event);\n                    return;\n                }\n            }\n        }\n    }\n    private async _onEnterPress(event: KeyboardEvent) {\n        event.preventDefault();\n        let shouldClose = true;\n\n        //select the currently highlighted option\n        if (this.isDropdownOpen && this.firstHighlightedItem) {\n            if (this.clearable && this.itemStorage.highlightedItems.every(item => item.selected)) {\n                this.unselectItem(...this.itemStorage.highlightedItems);\n            } else {\n                this.selectItem(...this.itemStorage.highlightedItems);\n            }\n        }\n        //add a custom option\n        else if (this.isDropdownOpen && this.shouldShowAddCustom) {\n            await this.addCustomOption(this.searchTerm);\n        }\n        //in case of no action, open the dropdown (or keep it open)\n        else shouldClose = false;\n\n        if (!this.keepOpen && shouldClose) {\n            this.itemStorage.clearAllHighlights();\n            this.close();\n        } else {\n            this.open();\n        }\n    }\n    private _onSpacePress(event: KeyboardEvent): void {\n        if (this.isDropdownOpen) return;\n\n        event.preventDefault();\n        this.open();\n    }\n    private _onArrowDownPress(event: KeyboardEvent): void {\n        event.preventDefault();\n        this.open();\n\n        this._isMouseBeingUsed = false;\n\n        const recentlyHighlighted = this.itemStorage.highlightNextItem(+1, event.shiftKey);\n        if (recentlyHighlighted) {\n            this.itemStorage.setRecentlyHighlighted(recentlyHighlighted);\n        }\n\n        this.dropdownPanel.scrollToRecentlyHighlighted('bottom');\n    }\n    private _onArrowUpPress(event: KeyboardEvent): void {\n        if (!this.isDropdownOpen) return;\n        event.preventDefault();\n\n        this._isMouseBeingUsed = false;\n\n        const recentlyHighlighted = this.itemStorage.highlightNextItem(-1, event.shiftKey);\n        if (recentlyHighlighted) {\n            this.itemStorage.setRecentlyHighlighted(recentlyHighlighted);\n        }\n\n        this.dropdownPanel.scrollToRecentlyHighlighted('top');\n    }\n    private _onHomePress(event: KeyboardEvent): void {\n        if (!this.isDropdownOpen || (this.searchInput.nativeElement.selectionEnd != 0 && this.searchInput.nativeElement.selectionStart != 0)) return;\n        event.preventDefault();\n\n        this._isMouseBeingUsed = false;\n\n        const recentlyHighlighted = this.itemStorage.highlightFirstItem();\n        if (!recentlyHighlighted) return;\n\n        this.itemStorage.setRecentlyHighlighted(recentlyHighlighted);\n        this.dropdownPanel.scrollToRecentlyHighlighted('top');\n    }\n    private _onEndPress(event: KeyboardEvent): void {\n        if (\n            !this.isDropdownOpen ||\n            (this.searchInput.nativeElement.selectionEnd != this.searchTerm.length && this.searchInput.nativeElement.selectionStart != this.searchTerm.length)\n        )\n            return;\n        event.preventDefault();\n\n        this._isMouseBeingUsed = false;\n\n        const recentlyHighlighted = this.itemStorage.highlightLastItem();\n        if (!recentlyHighlighted) return;\n\n        this.itemStorage.setRecentlyHighlighted(recentlyHighlighted);\n        this.dropdownPanel.scrollToRecentlyHighlighted('bottom');\n    }\n    private _onBackspaceOrDeletePress(event: KeyboardEvent): void {\n        if (this.searchTerm || !this._clearable || this.noBackspaceClear || !this.itemStorage.isAnyItemSelected) return;\n\n        event.preventDefault();\n        if (this.multiselectable && this.itemStorage.selectedItems.length > 1) {\n            this._clearLastItem();\n            return;\n        }\n        this._clearAllItems();\n    }\n    private _onCtrlAPress(event: KeyboardEvent): void {\n        this.itemStorage.highlightAllItems();\n    }\n}\n","<ard-form-field-frame\r\n    [appearance]=\"appearance\"\r\n    [variant]=\"variant\"\r\n    [compact]=\"compact\"\r\n    [isFocused]=\"isFocused\"\r\n    [prefixTemplate]=\"prefixTemplate\"\r\n    [suffixTemplate]=\"suffixTemplate\"\r\n>\r\n    <div class=\"ard-select\"\r\n        #dropdownHost\r\n        (click)=\"handleAnywhereClick($event)\"\r\n        [class.ard-has-value]=\"itemStorage.isAnyItemSelected\"\r\n        [ngClass]=\"ngClasses\"\r\n    >\r\n        <div class=\"ard-select-value-container\">\r\n            <ng-container *ngIf=\"shouldDisplayPlaceholder\">\r\n                <ng-template #defaultPlaceholderTemplate let-plhldr>\r\n                    <div class=\"ard-placeholder\">{{ plhldr }}</div>\r\n                </ng-template>\r\n\r\n                <ng-template\r\n                    [ngTemplateOutlet]=\"placeholderTemplate || defaultPlaceholderTemplate\"\r\n                    [ngTemplateOutletContext]=\"getPlaceholderContext()\"\r\n                ></ng-template>\r\n            </ng-container>\r\n\r\n            <ng-container *ngIf=\"shouldDisplayValue\">\r\n                <div class=\"ard-select-value\"\r\n                    *ngFor=\"let item of itemStorage.selectedItems; let i = index\"\r\n                    [class.ard-value-disabled]=\"item.disabled\"\r\n                    [attr.hidden]=\"!isValueWithinDisplayLimit(i) ? true : null\"\r\n                >\r\n                    <ng-template *ngIf=\"isValueWithinDisplayLimit(i)\"\r\n                        [ngTemplateOutlet]=\"valueTemplate || (multiselectable ? defaultMultiValueTemplate :  defaultValueTemplate)\"\r\n                        [ngTemplateOutletContext]=\"getValueContext(item)\"\r\n                    ></ng-template>\r\n                </div>\r\n\r\n                <ng-template #defaultValueTemplate let-item>\r\n                    <div [ardInnerHTML]=\"item.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></div>\r\n                </ng-template>\r\n                <ng-template #defaultMultiValueTemplate let-item let-unselect=\"unselect\">\r\n                    <ard-deletable-chip\r\n                        (delete)=\"unselect(item)\"\r\n                        [variant]=\"variant\"\r\n                        compact\r\n                        appearance=\"outlined-strong\"\r\n                    >\r\n                        <div [ardInnerHTML]=\"item.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></div>\r\n                    </ard-deletable-chip>\r\n                </ng-template>\r\n            </ng-container>\r\n\r\n            <ng-container *ngIf=\"itemStorage.isAnyItemSelected && shouldShowItemDisplayLimit\">\r\n                <div class=\"ard-overflow-indicator\">\r\n                    <ng-template\r\n                        [ngTemplateOutlet]=\"itemDisplayLimitTemplate || defaultItemDisplayLimitTemplate\"\r\n                        [ngTemplateOutletContext]=\"getItemDisplayLimitContext()\"\r\n                    ></ng-template>\r\n\r\n                    <ng-template #defaultItemDisplayLimitTemplate let-count=\"overflowCount\">\r\n                        <div>{{count}} more...</div>\r\n                    </ng-template>\r\n                </div>\r\n            </ng-container>\r\n            \r\n            <div class=\"ard-search-input\"\r\n                role=\"combobox\"\r\n                aria-haspopup=\"listbox\"\r\n                [attr.aria-expanded]=\"isDropdownOpen\"\r\n                [attr.aria-owns]=\"isDropdownOpen ? htmlId : null\"\r\n            >\r\n                <input #searchInput\r\n                    #focusableElement\r\n                    type=\"text\"\r\n                    [attr.id]=\"searchInputId\"\r\n                    [attr.tabindex]=\"tabIndex\"\r\n                    [readonly]=\"isInputElementReadonly\"\r\n                    [disabled]=\"disabled\"\r\n                    [value]=\"searchTerm\"\r\n                    aria-autocomplete=\"list\"\r\n                    [attr.aria-controls]=\"isDropdownOpen ? htmlId : null\"\r\n                    (input)=\"filter(searchInput.value)\"\r\n                    (change)=\"$event.stopPropagation()\"\r\n                    (focus)=\"onFocus($event)\"\r\n                    (focus)=\"onSearchInputFocus($event)\"\r\n                    (blur)=\"onBlur($event)\"\r\n                    (blur)=\"onSearchInputBlur($event)\"\r\n                >\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"ard-select-controls\">\r\n            <ng-container *ngIf=\"isLoading\">\r\n                <ng-template #defaultLoadingSpinnerTemplate>\r\n                    <div class=\"ard-simple-spinner\"></div>\r\n                </ng-template>\r\n\r\n                <ng-template [ngTemplateOutlet]=\"loadingSpinnerTemplate || defaultLoadingSpinnerTemplate\">\r\n                </ng-template>\r\n            </ng-container>\r\n\r\n            <ard-_clear-button *ngIf=\"shouldShowClearButton\"\r\n                [title]=\"clearButtonTitle\"\r\n                (click)=\"handleClearButtonClick($event)\"\r\n            ></ard-_clear-button>\r\n\r\n            <div class=\"ard-dropdown-arrow-wrapper\"\r\n                role=\"button\"\r\n                (click)=\"handleDropdownArrowClick($event)\"\r\n            >\r\n                <span class=\"ard-dropdown-arrow\"></span>\r\n                <div class=\"ard-hitbox\"></div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ard-form-field-frame>\r\n\r\n\r\n<ng-template #dropdownTemplate>\r\n    <ard-dropdown-panel\r\n        class=\"ard-dropdown-panel ard-select-dropdown-panel\"\r\n        role=\"listbox\"\r\n        aria-label=\"Options list\"\r\n        [headerTemplate]=\"dropdownHeaderTemplate\"\r\n        [footerTemplate]=\"dropdownFooterTemplate\"\r\n        [appearance]=\"dropdownAppearance\"\r\n        [variant]=\"dropdownVariant\"\r\n        [isOpen]=\"true\"\r\n        [filterValue]=\"searchTerm\"\r\n        [panelId]=\"htmlId\"\r\n        [compact]=\"compact\"\r\n        (ardClickOutside)=\"handleOutsideClick($event)\"\r\n        (mousemove)=\"onMouseMove()\"\r\n        (scroll)=\"scrollEvent.emit($event)\"\r\n        (scrollToEnd)=\"scrollToEndEvent.emit($event)\"\r\n    >\r\n        <ng-container *ngIf=\"!shouldShowNoItemsFound\">\r\n            <div\r\n                class=\"ard-optgroup\"\r\n                role=\"group\"\r\n                *ngFor=\"let group of itemStorage.groups\"\r\n                [class.ard-group-disabled]=\"group.disabled\"\r\n                [class.ard-group-selected]=\"group.selected\"\r\n                [class.ard-group-highlighted]=\"group.highlighted\"\r\n                (mouseover)=\"onGroupMouseover(group)\"\r\n                (click)=\"onGroupClick(group)\"\r\n            >\r\n                <ng-container *ngIf=\"group.label !== '' && group.label !== undefined\">\r\n                    <ng-template #defaultOptgroupTemplate>\r\n                        <span class=\"ard-optgroup-label\" [ardInnerHTML]=\"group.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></span>\r\n                    </ng-template>\r\n\r\n                    <ng-template\r\n                        [ngTemplateOutlet]=\"optgroupTemplate || defaultOptgroupTemplate\"\r\n                        [ngTemplateOutletContext]=\"getGroupContext(group)\"\r\n                    ></ng-template>\r\n                </ng-container>\r\n\r\n                <div class=\"ard-optgroup-children\">\r\n                    <div\r\n                        class=\"ard-option\"\r\n                        role=\"option\"\r\n                        *ngFor=\"let option of group.children\"\r\n                        [class.ard-option-disabled]=\"option.disabled\"\r\n                        [class.ard-option-selected]=\"option.selected\"\r\n                        [class.ard-option-highlighted]=\"option.highlighted\"\r\n                        [class.ard-option-highlighted-recent]=\"option.highlighted_recently\"\r\n                        [attr.aria-selected]=\"option.selected\"\r\n                        [attr.id]=\"htmlId + '-' + option.index\"\r\n                        (click)=\"onItemClick(option, $event)\"\r\n                        (mouseover)=\"onItemMouseOver($event)\"\r\n                        (mouseenter)=\"onItemMouseEnter(option, $event)\"\r\n                        (mouseleave)=\"onItemMouseLeave(option, $event)\"\r\n                    >\r\n                        <div class=\"ard-option-label\">\r\n                            <ng-template #defaultOptionTemplate>\r\n                                <span [ardInnerHTML]=\"option.label\" [ardEscapeInnerHTML]=\"isItemsInputUsed\"></span>\r\n                            </ng-template>\r\n\r\n                            <ng-template\r\n                                [ngTemplateOutlet]=\"optionTemplate || defaultOptionTemplate\"\r\n                                [ngTemplateOutletContext]=\"getOptionContext(option)\"\r\n                            ></ng-template>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"shouldShowNoItemsFound\">\r\n            <ng-template #defaultNoItemsFoundTemplate>\r\n                <div class=\"ard-option ard-option-disabled\">{{noItemsFoundText}}</div>\r\n            </ng-template>\r\n\r\n            <ng-template [ngTemplateOutlet]=\"noItemsFoundTemplate || defaultNoItemsFoundTemplate\"\r\n                [ngTemplateOutletContext]=\"getSearchContext()\">\r\n            </ng-template>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"shouldShowAddCustom\">\r\n            <ng-template #defaultAddCustomTemplate let-searchTerm>\r\n                <div class=\"ard-option ard-option-highlighted ard-add-custom\" (click)=\"addCustomOption(searchTerm)\">\r\n                    <span class=\"ard-add-custom-label\">Add option</span>\r\n                    <span class=\"ard-add-custom-value\">\"{{searchTerm}}\"</span>\r\n                </div>\r\n            </ng-template>\r\n\r\n            <ng-template [ngTemplateOutlet]=\"addCustomTemplate || defaultAddCustomTemplate\"\r\n                [ngTemplateOutletContext]=\"getCustomOptionContext()\">\r\n            </ng-template>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"isLoading\">\r\n            <ng-template #defaultLoadingPlaceholderTemplate>\r\n                <div class=\"ard-option ard-option-disabled\">{{loadingPlaceholderText}}</div>\r\n            </ng-template>\r\n\r\n            <ng-template [ngTemplateOutlet]=\"loadingPlaceholderTemplate || defaultLoadingPlaceholderTemplate\"\r\n                [ngTemplateOutletContext]=\"getSearchContext()\">\r\n            </ng-template>\r\n        </ng-container>\r\n    </ard-dropdown-panel>\r\n</ng-template>"]}