@ukic/web-components 2.3.0 → 2.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (650) hide show
  1. package/dist/cjs/{OpenInNew-f9958725.js → OpenInNew-d5d30e77.js} +1 -1
  2. package/dist/cjs/OpenInNew-d5d30e77.js.map +1 -0
  3. package/dist/cjs/{check-icon-b2f60716.js → check-icon-7225d79b.js} +1 -1
  4. package/dist/cjs/check-icon-7225d79b.js.map +1 -0
  5. package/dist/cjs/{chevron-icon-2bb3a907.js → chevron-icon-3bf07531.js} +1 -1
  6. package/dist/cjs/chevron-icon-3bf07531.js.map +1 -0
  7. package/dist/cjs/{close-icon-04be4880.js → close-icon-7f6ef8e4.js} +1 -1
  8. package/dist/cjs/close-icon-7f6ef8e4.js.map +1 -0
  9. package/dist/cjs/core.cjs.js +3 -6
  10. package/dist/cjs/core.cjs.js.map +1 -1
  11. package/dist/cjs/{helpers-3811d14b.js → helpers-d166f875.js} +27 -10
  12. package/dist/cjs/helpers-d166f875.js.map +1 -0
  13. package/dist/cjs/ic-alert.cjs.entry.js +4 -4
  14. package/dist/cjs/ic-alert.cjs.entry.js.map +1 -1
  15. package/dist/cjs/ic-back-to-top.cjs.entry.js +3 -3
  16. package/dist/cjs/ic-back-to-top.cjs.entry.js.map +1 -1
  17. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +3 -3
  18. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ic-breadcrumb.cjs.entry.js +4 -4
  20. package/dist/cjs/ic-breadcrumb.cjs.entry.js.map +1 -1
  21. package/dist/cjs/ic-button_3.cjs.entry.js +4 -4
  22. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  23. package/dist/cjs/ic-card.cjs.entry.js +4 -4
  24. package/dist/cjs/ic-card.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ic-checkbox-group.cjs.entry.js +3 -3
  26. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  27. package/dist/cjs/ic-checkbox.cjs.entry.js +3 -3
  28. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -1
  29. package/dist/cjs/ic-chip.cjs.entry.js +3 -3
  30. package/dist/cjs/ic-chip.cjs.entry.js.map +1 -1
  31. package/dist/cjs/ic-classification-banner.cjs.entry.js +1 -1
  32. package/dist/cjs/ic-classification-banner.cjs.entry.js.map +1 -1
  33. package/dist/cjs/ic-data-entity.cjs.entry.js +1 -1
  34. package/dist/cjs/ic-data-entity.cjs.entry.js.map +1 -1
  35. package/dist/cjs/ic-data-row.cjs.entry.js +3 -3
  36. package/dist/cjs/ic-data-row.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ic-dialog.cjs.entry.js +4 -4
  38. package/dist/cjs/ic-dialog.cjs.entry.js.map +1 -1
  39. package/dist/cjs/ic-divider.cjs.entry.js +3 -3
  40. package/dist/cjs/ic-divider.cjs.entry.js.map +1 -1
  41. package/dist/cjs/ic-empty-state.cjs.entry.js +3 -3
  42. package/dist/cjs/ic-empty-state.cjs.entry.js.map +1 -1
  43. package/dist/cjs/ic-footer-link-group.cjs.entry.js +3 -3
  44. package/dist/cjs/ic-footer-link-group.cjs.entry.js.map +1 -1
  45. package/dist/cjs/ic-footer-link.cjs.entry.js +4 -4
  46. package/dist/cjs/ic-footer-link.cjs.entry.js.map +1 -1
  47. package/dist/cjs/ic-footer.cjs.entry.js +3 -3
  48. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -1
  49. package/dist/cjs/ic-hero.cjs.entry.js +3 -3
  50. package/dist/cjs/ic-hero.cjs.entry.js.map +1 -1
  51. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +3 -3
  52. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js.map +1 -1
  53. package/dist/cjs/ic-input-component-container_3.cjs.entry.js +43 -37
  54. package/dist/cjs/ic-input-component-container_3.cjs.entry.js.map +1 -1
  55. package/dist/cjs/ic-input-label_2.cjs.entry.js +3 -3
  56. package/dist/cjs/ic-input-label_2.cjs.entry.js.map +1 -1
  57. package/dist/cjs/ic-link.cjs.entry.js +4 -4
  58. package/dist/cjs/ic-link.cjs.entry.js.map +1 -1
  59. package/dist/cjs/ic-menu-group.cjs.entry.js +1 -1
  60. package/dist/cjs/ic-menu-group.cjs.entry.js.map +1 -1
  61. package/dist/cjs/ic-menu-item.cjs.entry.js +5 -5
  62. package/dist/cjs/ic-menu-item.cjs.entry.js.map +1 -1
  63. package/dist/cjs/ic-navigation-button.cjs.entry.js +3 -3
  64. package/dist/cjs/ic-navigation-button.cjs.entry.js.map +1 -1
  65. package/dist/cjs/ic-navigation-group.cjs.entry.js +4 -4
  66. package/dist/cjs/ic-navigation-group.cjs.entry.js.map +1 -1
  67. package/dist/cjs/ic-navigation-item.cjs.entry.js +5 -5
  68. package/dist/cjs/ic-navigation-item.cjs.entry.js.map +1 -1
  69. package/dist/cjs/ic-navigation-menu.cjs.entry.js +3 -3
  70. package/dist/cjs/ic-navigation-menu.cjs.entry.js.map +1 -1
  71. package/dist/cjs/ic-page-header.cjs.entry.js +3 -3
  72. package/dist/cjs/ic-page-header.cjs.entry.js.map +1 -1
  73. package/dist/cjs/ic-pagination-item.cjs.entry.js +3 -3
  74. package/dist/cjs/ic-pagination-item.cjs.entry.js.map +1 -1
  75. package/dist/cjs/ic-pagination.cjs.entry.js +3 -3
  76. package/dist/cjs/ic-pagination.cjs.entry.js.map +1 -1
  77. package/dist/cjs/ic-popover-menu.cjs.entry.js +4 -4
  78. package/dist/cjs/ic-popover-menu.cjs.entry.js.map +1 -1
  79. package/dist/cjs/ic-radio-group.cjs.entry.js +3 -3
  80. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -1
  81. package/dist/cjs/ic-radio-option.cjs.entry.js +3 -3
  82. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  83. package/dist/cjs/ic-search-bar.cjs.entry.js +35 -19
  84. package/dist/cjs/ic-search-bar.cjs.entry.js.map +1 -1
  85. package/dist/cjs/ic-section-container.cjs.entry.js +1 -1
  86. package/dist/cjs/ic-section-container.cjs.entry.js.map +1 -1
  87. package/dist/cjs/ic-select.cjs.entry.js +71 -17
  88. package/dist/cjs/ic-select.cjs.entry.js.map +1 -1
  89. package/dist/cjs/ic-side-navigation.cjs.entry.js +5 -5
  90. package/dist/cjs/ic-side-navigation.cjs.entry.js.map +1 -1
  91. package/dist/cjs/ic-skeleton.cjs.entry.js +1 -1
  92. package/dist/cjs/ic-skeleton.cjs.entry.js.map +1 -1
  93. package/dist/cjs/ic-status-tag.cjs.entry.js +3 -3
  94. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -1
  95. package/dist/cjs/ic-step.cjs.entry.js +2 -2
  96. package/dist/cjs/ic-step.cjs.entry.js.map +1 -1
  97. package/dist/cjs/ic-stepper.cjs.entry.js +3 -3
  98. package/dist/cjs/ic-stepper.cjs.entry.js.map +1 -1
  99. package/dist/cjs/ic-switch.cjs.entry.js +3 -3
  100. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  101. package/dist/cjs/ic-tab-context.cjs.entry.js +2 -2
  102. package/dist/cjs/ic-tab-context.cjs.entry.js.map +1 -1
  103. package/dist/cjs/ic-tab-group.cjs.entry.js +3 -3
  104. package/dist/cjs/ic-tab-group.cjs.entry.js.map +1 -1
  105. package/dist/cjs/ic-tab-panel.cjs.entry.js +2 -2
  106. package/dist/cjs/ic-tab-panel.cjs.entry.js.map +1 -1
  107. package/dist/cjs/ic-tab.cjs.entry.js +3 -3
  108. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -1
  109. package/dist/cjs/ic-text-field.cjs.entry.js +3 -3
  110. package/dist/cjs/ic-text-field.cjs.entry.js.map +1 -1
  111. package/dist/cjs/ic-theme.cjs.entry.js +3 -3
  112. package/dist/cjs/ic-theme.cjs.entry.js.map +1 -1
  113. package/dist/cjs/ic-toast-region.cjs.entry.js +1 -1
  114. package/dist/cjs/ic-toast-region.cjs.entry.js.map +1 -1
  115. package/dist/cjs/ic-toast.cjs.entry.js +4 -4
  116. package/dist/cjs/ic-toast.cjs.entry.js.map +1 -1
  117. package/dist/cjs/ic-top-navigation.cjs.entry.js +3 -3
  118. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -1
  119. package/dist/cjs/ic-typography.cjs.entry.js +3 -3
  120. package/dist/cjs/ic-typography.cjs.entry.js.map +1 -1
  121. package/dist/cjs/{index-2a0c6769.js → index-54d2bed9.js} +98 -26
  122. package/dist/cjs/index-54d2bed9.js.map +1 -0
  123. package/dist/cjs/loader.cjs.js +3 -12
  124. package/dist/cjs/loader.cjs.js.map +1 -1
  125. package/dist/cjs/{popper-d7adcfc6.js → popper-31badbf8.js} +1 -1
  126. package/dist/cjs/popper-31badbf8.js.map +1 -0
  127. package/dist/cjs/{types-3eb02246.js → types-7d67439f.js} +1 -1
  128. package/dist/cjs/types-7d67439f.js.map +1 -0
  129. package/dist/collection/collection-manifest.json +61 -61
  130. package/dist/collection/components/ic-alert/ic-alert.js +2 -1
  131. package/dist/collection/components/ic-alert/ic-alert.js.map +1 -1
  132. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js +5 -1
  133. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js.map +1 -1
  134. package/dist/collection/components/ic-button/ic-button.js +16 -8
  135. package/dist/collection/components/ic-button/ic-button.js.map +1 -1
  136. package/dist/collection/components/ic-card/ic-card.js +4 -2
  137. package/dist/collection/components/ic-card/ic-card.js.map +1 -1
  138. package/dist/collection/components/ic-checkbox/ic-checkbox.js +8 -4
  139. package/dist/collection/components/ic-checkbox/ic-checkbox.js.map +1 -1
  140. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js +6 -3
  141. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js.map +1 -1
  142. package/dist/collection/components/ic-chip/ic-chip.js +6 -3
  143. package/dist/collection/components/ic-chip/ic-chip.js.map +1 -1
  144. package/dist/collection/components/ic-classification-banner/ic-classification-banner.js +2 -1
  145. package/dist/collection/components/ic-classification-banner/ic-classification-banner.js.map +1 -1
  146. package/dist/collection/components/ic-dialog/ic-dialog.js +13 -4
  147. package/dist/collection/components/ic-dialog/ic-dialog.js.map +1 -1
  148. package/dist/collection/components/ic-empty-state/ic-empty-state.js +4 -2
  149. package/dist/collection/components/ic-empty-state/ic-empty-state.js.map +1 -1
  150. package/dist/collection/components/ic-footer/ic-footer.js +4 -2
  151. package/dist/collection/components/ic-footer/ic-footer.js.map +1 -1
  152. package/dist/collection/components/ic-footer-link/ic-footer-link.js +2 -1
  153. package/dist/collection/components/ic-footer-link/ic-footer-link.js.map +1 -1
  154. package/dist/collection/components/ic-hero/ic-hero.js +4 -2
  155. package/dist/collection/components/ic-hero/ic-hero.js.map +1 -1
  156. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js +4 -2
  157. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js.map +1 -1
  158. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js +2 -1
  159. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js.map +1 -1
  160. package/dist/collection/components/ic-input-validation/ic-input-validation.js +4 -2
  161. package/dist/collection/components/ic-input-validation/ic-input-validation.js.map +1 -1
  162. package/dist/collection/components/ic-link/ic-link.js +6 -3
  163. package/dist/collection/components/ic-link/ic-link.js.map +1 -1
  164. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js +6 -3
  165. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js.map +1 -1
  166. package/dist/collection/components/ic-menu/ic-menu.css +17 -0
  167. package/dist/collection/components/ic-menu/ic-menu.js +107 -48
  168. package/dist/collection/components/ic-menu/ic-menu.js.map +1 -1
  169. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js +13 -2
  170. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js.map +1 -1
  171. package/dist/collection/components/ic-menu-item/ic-menu-item.js +4 -2
  172. package/dist/collection/components/ic-menu-item/ic-menu-item.js.map +1 -1
  173. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js +4 -2
  174. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js.map +1 -1
  175. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js +2 -1
  176. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js.map +1 -1
  177. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js +4 -2
  178. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js.map +1 -1
  179. package/dist/collection/components/ic-page-header/ic-page-header.js +2 -1
  180. package/dist/collection/components/ic-page-header/ic-page-header.js.map +1 -1
  181. package/dist/collection/components/ic-pagination/ic-pagination.js +8 -4
  182. package/dist/collection/components/ic-pagination/ic-pagination.js.map +1 -1
  183. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js +4 -2
  184. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js.map +1 -1
  185. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js +6 -3
  186. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js.map +1 -1
  187. package/dist/collection/components/ic-radio-group/ic-radio-group.js +6 -3
  188. package/dist/collection/components/ic-radio-group/ic-radio-group.js.map +1 -1
  189. package/dist/collection/components/ic-radio-option/ic-radio-option.js +8 -4
  190. package/dist/collection/components/ic-radio-option/ic-radio-option.js.map +1 -1
  191. package/dist/collection/components/ic-search-bar/ic-search-bar.js +100 -32
  192. package/dist/collection/components/ic-search-bar/ic-search-bar.js.map +1 -1
  193. package/dist/collection/components/ic-section-container/ic-section-container.js +2 -1
  194. package/dist/collection/components/ic-section-container/ic-section-container.js.map +1 -1
  195. package/dist/collection/components/ic-select/ic-select.js +85 -22
  196. package/dist/collection/components/ic-select/ic-select.js.map +1 -1
  197. package/dist/collection/components/ic-select/test/basic/ic-select.e2e.js +30 -0
  198. package/dist/collection/components/ic-select/test/basic/ic-select.e2e.js.map +1 -1
  199. package/dist/collection/components/ic-select/test/basic/ic-select.spec.js +51 -3
  200. package/dist/collection/components/ic-select/test/basic/ic-select.spec.js.map +1 -1
  201. package/dist/collection/components/ic-skeleton/ic-skeleton.js +2 -1
  202. package/dist/collection/components/ic-skeleton/ic-skeleton.js.map +1 -1
  203. package/dist/collection/components/ic-status-tag/ic-status-tag.js +4 -2
  204. package/dist/collection/components/ic-status-tag/ic-status-tag.js.map +1 -1
  205. package/dist/collection/components/ic-step/ic-step.js +8 -4
  206. package/dist/collection/components/ic-step/ic-step.js.map +1 -1
  207. package/dist/collection/components/ic-stepper/ic-stepper.js +4 -2
  208. package/dist/collection/components/ic-stepper/ic-stepper.js.map +1 -1
  209. package/dist/collection/components/ic-switch/ic-switch.js +4 -2
  210. package/dist/collection/components/ic-switch/ic-switch.js.map +1 -1
  211. package/dist/collection/components/ic-tab/ic-tab.js +10 -5
  212. package/dist/collection/components/ic-tab/ic-tab.js.map +1 -1
  213. package/dist/collection/components/ic-tab-context/ic-tab-context.js +10 -5
  214. package/dist/collection/components/ic-tab-context/ic-tab-context.js.map +1 -1
  215. package/dist/collection/components/ic-tab-group/ic-tab-group.js +2 -1
  216. package/dist/collection/components/ic-tab-group/ic-tab-group.js.map +1 -1
  217. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js +4 -2
  218. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js.map +1 -1
  219. package/dist/collection/components/ic-text-field/ic-text-field.js +26 -13
  220. package/dist/collection/components/ic-text-field/ic-text-field.js.map +1 -1
  221. package/dist/collection/components/ic-theme/ic-theme.js +2 -1
  222. package/dist/collection/components/ic-theme/ic-theme.js.map +1 -1
  223. package/dist/collection/components/ic-toast/ic-toast.js +8 -4
  224. package/dist/collection/components/ic-toast/ic-toast.js.map +1 -1
  225. package/dist/collection/components/ic-toast-region/ic-toast-region.js +4 -2
  226. package/dist/collection/components/ic-toast-region/ic-toast-region.js.map +1 -1
  227. package/dist/collection/components/ic-tooltip/ic-tooltip.js +4 -2
  228. package/dist/collection/components/ic-tooltip/ic-tooltip.js.map +1 -1
  229. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js +2 -1
  230. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js.map +1 -1
  231. package/dist/collection/components/ic-typography/ic-typography.js +2 -1
  232. package/dist/collection/components/ic-typography/ic-typography.js.map +1 -1
  233. package/dist/collection/utils/helpers.js +25 -8
  234. package/dist/collection/utils/helpers.js.map +1 -1
  235. package/dist/collection/utils/types.js.map +1 -1
  236. package/dist/components/helpers.js +25 -8
  237. package/dist/components/helpers.js.map +1 -1
  238. package/dist/components/ic-alert2.js.map +1 -1
  239. package/dist/components/ic-back-to-top.js.map +1 -1
  240. package/dist/components/ic-breadcrumb-group.js.map +1 -1
  241. package/dist/components/ic-breadcrumb2.js.map +1 -1
  242. package/dist/components/ic-button2.js.map +1 -1
  243. package/dist/components/ic-card.js.map +1 -1
  244. package/dist/components/ic-checkbox-group.js.map +1 -1
  245. package/dist/components/ic-checkbox.js.map +1 -1
  246. package/dist/components/ic-chip.js.map +1 -1
  247. package/dist/components/ic-classification-banner.js.map +1 -1
  248. package/dist/components/ic-data-entity.js.map +1 -1
  249. package/dist/components/ic-data-row.js.map +1 -1
  250. package/dist/components/ic-dialog.js.map +1 -1
  251. package/dist/components/ic-divider2.js.map +1 -1
  252. package/dist/components/ic-empty-state.js.map +1 -1
  253. package/dist/components/ic-footer-link-group.js.map +1 -1
  254. package/dist/components/ic-footer-link.js.map +1 -1
  255. package/dist/components/ic-footer.js.map +1 -1
  256. package/dist/components/ic-hero.js.map +1 -1
  257. package/dist/components/ic-horizontal-scroll2.js.map +1 -1
  258. package/dist/components/ic-input-component-container2.js.map +1 -1
  259. package/dist/components/ic-input-container2.js.map +1 -1
  260. package/dist/components/ic-input-label2.js.map +1 -1
  261. package/dist/components/ic-input-validation2.js.map +1 -1
  262. package/dist/components/ic-link2.js.map +1 -1
  263. package/dist/components/ic-loading-indicator2.js.map +1 -1
  264. package/dist/components/ic-menu-group.js.map +1 -1
  265. package/dist/components/ic-menu-item2.js.map +1 -1
  266. package/dist/components/ic-menu2.js +40 -32
  267. package/dist/components/ic-menu2.js.map +1 -1
  268. package/dist/components/ic-navigation-button.js.map +1 -1
  269. package/dist/components/ic-navigation-group.js.map +1 -1
  270. package/dist/components/ic-navigation-item.js.map +1 -1
  271. package/dist/components/ic-navigation-menu2.js.map +1 -1
  272. package/dist/components/ic-page-header.js.map +1 -1
  273. package/dist/components/ic-pagination-item2.js.map +1 -1
  274. package/dist/components/ic-pagination.js.map +1 -1
  275. package/dist/components/ic-popover-menu.js.map +1 -1
  276. package/dist/components/ic-radio-group.js.map +1 -1
  277. package/dist/components/ic-radio-option.js.map +1 -1
  278. package/dist/components/ic-search-bar.js +34 -16
  279. package/dist/components/ic-search-bar.js.map +1 -1
  280. package/dist/components/ic-section-container2.js.map +1 -1
  281. package/dist/components/ic-select.js +69 -14
  282. package/dist/components/ic-select.js.map +1 -1
  283. package/dist/components/ic-side-navigation.js.map +1 -1
  284. package/dist/components/ic-skeleton.js.map +1 -1
  285. package/dist/components/ic-status-tag.js.map +1 -1
  286. package/dist/components/ic-step.js.map +1 -1
  287. package/dist/components/ic-stepper.js.map +1 -1
  288. package/dist/components/ic-switch.js.map +1 -1
  289. package/dist/components/ic-tab-context.js.map +1 -1
  290. package/dist/components/ic-tab-group.js.map +1 -1
  291. package/dist/components/ic-tab-panel.js.map +1 -1
  292. package/dist/components/ic-tab.js.map +1 -1
  293. package/dist/components/ic-text-field2.js.map +1 -1
  294. package/dist/components/ic-theme.js.map +1 -1
  295. package/dist/components/ic-toast-region.js.map +1 -1
  296. package/dist/components/ic-toast.js.map +1 -1
  297. package/dist/components/ic-tooltip2.js.map +1 -1
  298. package/dist/components/ic-top-navigation.js.map +1 -1
  299. package/dist/components/ic-typography2.js.map +1 -1
  300. package/dist/components/index.d.ts +6 -0
  301. package/dist/components/index.js +1 -1
  302. package/dist/components/types.js.map +1 -1
  303. package/dist/core/core.esm.js +1 -1
  304. package/dist/core/core.esm.js.map +1 -1
  305. package/dist/core/{p-fbd3c432.entry.js → p-0dcc76b1.entry.js} +2 -2
  306. package/dist/core/p-0dcc76b1.entry.js.map +1 -0
  307. package/dist/core/{p-bbdd9770.entry.js → p-101bce17.entry.js} +2 -2
  308. package/dist/core/p-101bce17.entry.js.map +1 -0
  309. package/dist/core/{p-e2fdb944.entry.js → p-16e8bb5a.entry.js} +2 -2
  310. package/dist/core/p-16e8bb5a.entry.js.map +1 -0
  311. package/dist/core/p-18068237.js +3 -0
  312. package/dist/core/p-18068237.js.map +1 -0
  313. package/dist/core/p-1c54269e.entry.js +2 -0
  314. package/dist/core/p-1c54269e.entry.js.map +1 -0
  315. package/dist/core/{p-389c3913.entry.js → p-27897d29.entry.js} +2 -2
  316. package/dist/core/p-27897d29.entry.js.map +1 -0
  317. package/dist/core/{p-e14bc195.entry.js → p-27bf4783.entry.js} +2 -2
  318. package/dist/core/p-27bf4783.entry.js.map +1 -0
  319. package/dist/core/{p-ab4919d6.entry.js → p-3297713b.entry.js} +2 -2
  320. package/dist/core/p-3297713b.entry.js.map +1 -0
  321. package/dist/core/{p-06321d19.js → p-3b185c32.js} +1 -1
  322. package/dist/core/{p-919059e8.entry.js → p-3fc638fc.entry.js} +2 -2
  323. package/dist/core/p-3fc638fc.entry.js.map +1 -0
  324. package/dist/core/{p-103c761f.entry.js → p-414ff132.entry.js} +2 -2
  325. package/dist/core/p-414ff132.entry.js.map +1 -0
  326. package/dist/core/{p-8d4f7027.js → p-426ec638.js} +1 -1
  327. package/dist/core/{p-20fafec4.entry.js → p-433cfd47.entry.js} +2 -2
  328. package/dist/core/p-433cfd47.entry.js.map +1 -0
  329. package/dist/core/{p-da3bd896.entry.js → p-455bfed1.entry.js} +2 -2
  330. package/dist/core/p-455bfed1.entry.js.map +1 -0
  331. package/dist/core/{p-07877eb8.entry.js → p-4c4261e7.entry.js} +2 -2
  332. package/dist/core/p-4c4261e7.entry.js.map +1 -0
  333. package/dist/core/{p-75ac2fbf.entry.js → p-4f7c20b3.entry.js} +2 -2
  334. package/dist/core/p-4f7c20b3.entry.js.map +1 -0
  335. package/dist/core/{p-5e3a09d7.entry.js → p-521c8f40.entry.js} +2 -2
  336. package/dist/core/p-521c8f40.entry.js.map +1 -0
  337. package/dist/core/{p-041604fc.entry.js → p-5b8be53f.entry.js} +2 -2
  338. package/dist/core/p-5b8be53f.entry.js.map +1 -0
  339. package/dist/core/{p-14bea6c0.entry.js → p-5fcbcc3f.entry.js} +2 -2
  340. package/dist/core/p-5fcbcc3f.entry.js.map +1 -0
  341. package/dist/core/{p-3adb1167.entry.js → p-607e7bf2.entry.js} +2 -2
  342. package/dist/core/p-607e7bf2.entry.js.map +1 -0
  343. package/dist/core/{p-6f57b13c.js → p-613aa265.js} +1 -1
  344. package/dist/core/p-613aa265.js.map +1 -0
  345. package/dist/core/{p-c4b81d32.entry.js → p-62499150.entry.js} +2 -2
  346. package/dist/core/p-62499150.entry.js.map +1 -0
  347. package/dist/core/{p-5e685037.entry.js → p-630ae754.entry.js} +2 -2
  348. package/dist/core/p-630ae754.entry.js.map +1 -0
  349. package/dist/core/{p-24b88371.entry.js → p-65df7222.entry.js} +2 -2
  350. package/dist/core/p-65df7222.entry.js.map +1 -0
  351. package/dist/core/{p-8ca80000.entry.js → p-6781620e.entry.js} +2 -2
  352. package/dist/core/p-6781620e.entry.js.map +1 -0
  353. package/dist/core/p-67c18f72.entry.js +2 -0
  354. package/dist/core/p-67c18f72.entry.js.map +1 -0
  355. package/dist/core/{p-7c0dcd00.js → p-68a5aaff.js} +1 -1
  356. package/dist/core/p-68a5aaff.js.map +1 -0
  357. package/dist/core/{p-95992c98.entry.js → p-68fda79a.entry.js} +2 -2
  358. package/dist/core/p-68fda79a.entry.js.map +1 -0
  359. package/dist/core/{p-da5fc036.entry.js → p-7194c255.entry.js} +2 -2
  360. package/dist/core/p-7194c255.entry.js.map +1 -0
  361. package/dist/core/p-77266738.entry.js +2 -0
  362. package/dist/core/p-77266738.entry.js.map +1 -0
  363. package/dist/core/{p-516fd246.entry.js → p-7be2b1fd.entry.js} +2 -2
  364. package/dist/core/p-7be2b1fd.entry.js.map +1 -0
  365. package/dist/core/{p-b5d084c2.entry.js → p-831b0f3f.entry.js} +2 -2
  366. package/dist/core/p-831b0f3f.entry.js.map +1 -0
  367. package/dist/core/{p-2ae7687a.entry.js → p-83e535de.entry.js} +2 -2
  368. package/dist/core/p-83e535de.entry.js.map +1 -0
  369. package/dist/core/{p-441e7d98.entry.js → p-85dd5e5b.entry.js} +2 -2
  370. package/dist/core/p-85dd5e5b.entry.js.map +1 -0
  371. package/dist/core/{p-2f5a9d91.entry.js → p-87149cbd.entry.js} +2 -2
  372. package/dist/core/p-87149cbd.entry.js.map +1 -0
  373. package/dist/core/{p-43b529a5.entry.js → p-8e6169e0.entry.js} +2 -2
  374. package/dist/core/p-8e6169e0.entry.js.map +1 -0
  375. package/dist/core/{p-1b1dbb53.entry.js → p-9248228e.entry.js} +2 -2
  376. package/dist/core/p-9248228e.entry.js.map +1 -0
  377. package/dist/core/{p-8acd7207.entry.js → p-932a67ca.entry.js} +2 -2
  378. package/dist/core/p-932a67ca.entry.js.map +1 -0
  379. package/dist/core/{p-cfb87422.entry.js → p-937ecd5b.entry.js} +2 -2
  380. package/dist/core/p-937ecd5b.entry.js.map +1 -0
  381. package/dist/core/{p-9bde930d.entry.js → p-94903a21.entry.js} +2 -2
  382. package/dist/core/p-94903a21.entry.js.map +1 -0
  383. package/dist/core/{p-4dc6a83d.entry.js → p-96022913.entry.js} +2 -2
  384. package/dist/core/p-96022913.entry.js.map +1 -0
  385. package/dist/core/{p-c3da58eb.entry.js → p-9650e00e.entry.js} +2 -2
  386. package/dist/core/p-9650e00e.entry.js.map +1 -0
  387. package/dist/core/{p-50019c47.entry.js → p-99741b0f.entry.js} +2 -2
  388. package/dist/core/p-99741b0f.entry.js.map +1 -0
  389. package/dist/core/{p-e328bd2d.entry.js → p-a0a02a13.entry.js} +2 -2
  390. package/dist/core/p-a0a02a13.entry.js.map +1 -0
  391. package/dist/core/{p-d2994a71.entry.js → p-a421d3a1.entry.js} +2 -2
  392. package/dist/core/p-a421d3a1.entry.js.map +1 -0
  393. package/dist/core/{p-e9c864ac.entry.js → p-b0b1de0e.entry.js} +2 -2
  394. package/dist/core/p-b0b1de0e.entry.js.map +1 -0
  395. package/dist/core/p-b82776d0.entry.js +2 -0
  396. package/dist/core/p-b82776d0.entry.js.map +1 -0
  397. package/dist/core/{p-fb86da80.entry.js → p-c1859843.entry.js} +2 -2
  398. package/dist/core/p-c1859843.entry.js.map +1 -0
  399. package/dist/core/{p-8c7f4343.js → p-c2e091d7.js} +1 -1
  400. package/dist/core/{p-92868735.entry.js → p-c31e6dbb.entry.js} +2 -2
  401. package/dist/core/p-c31e6dbb.entry.js.map +1 -0
  402. package/dist/core/{p-96bcd466.entry.js → p-c390fbad.entry.js} +2 -2
  403. package/dist/core/p-c390fbad.entry.js.map +1 -0
  404. package/dist/core/{p-c2fc2b77.entry.js → p-cb2c18de.entry.js} +2 -2
  405. package/dist/core/p-cb2c18de.entry.js.map +1 -0
  406. package/dist/core/{p-6bad30aa.entry.js → p-d16100e8.entry.js} +2 -2
  407. package/dist/core/p-d16100e8.entry.js.map +1 -0
  408. package/dist/core/{p-07601b81.entry.js → p-d20917ae.entry.js} +2 -2
  409. package/dist/core/p-d20917ae.entry.js.map +1 -0
  410. package/dist/core/{p-a29fe0c6.entry.js → p-d65ace31.entry.js} +2 -2
  411. package/dist/core/p-d65ace31.entry.js.map +1 -0
  412. package/dist/core/{p-d592006b.entry.js → p-d78c90fe.entry.js} +2 -2
  413. package/dist/core/p-d78c90fe.entry.js.map +1 -0
  414. package/dist/core/{p-4fa9c6eb.entry.js → p-e2d0039d.entry.js} +2 -2
  415. package/dist/core/p-e2d0039d.entry.js.map +1 -0
  416. package/dist/core/{p-98d488aa.entry.js → p-e3923b67.entry.js} +2 -2
  417. package/dist/core/p-e3923b67.entry.js.map +1 -0
  418. package/dist/core/{p-1ac44a4e.entry.js → p-ebd60291.entry.js} +2 -2
  419. package/dist/core/p-ebd60291.entry.js.map +1 -0
  420. package/dist/core/p-ebe76390.js +2 -0
  421. package/dist/core/p-ebe76390.js.map +1 -0
  422. package/dist/core/{p-f2c6a143.js → p-f074ef5b.js} +1 -1
  423. package/dist/core/{p-93ee130d.entry.js → p-fedcfea3.entry.js} +2 -2
  424. package/dist/core/p-fedcfea3.entry.js.map +1 -0
  425. package/dist/esm/{OpenInNew-67a881e0.js → OpenInNew-cdeed5ce.js} +1 -1
  426. package/dist/esm/OpenInNew-cdeed5ce.js.map +1 -0
  427. package/dist/esm/{check-icon-abb210ec.js → check-icon-4a9f8371.js} +1 -1
  428. package/dist/esm/check-icon-4a9f8371.js.map +1 -0
  429. package/dist/esm/{chevron-icon-7927f709.js → chevron-icon-589e3b46.js} +1 -1
  430. package/dist/esm/chevron-icon-589e3b46.js.map +1 -0
  431. package/dist/esm/{close-icon-2ce5d375.js → close-icon-539ec8d1.js} +1 -1
  432. package/dist/esm/close-icon-539ec8d1.js.map +1 -0
  433. package/dist/esm/core.js +4 -7
  434. package/dist/esm/core.js.map +1 -1
  435. package/dist/esm/{helpers-d7d5bd08.js → helpers-b0e80358.js} +27 -10
  436. package/dist/esm/helpers-b0e80358.js.map +1 -0
  437. package/dist/esm/ic-alert.entry.js +4 -4
  438. package/dist/esm/ic-alert.entry.js.map +1 -1
  439. package/dist/esm/ic-back-to-top.entry.js +3 -3
  440. package/dist/esm/ic-back-to-top.entry.js.map +1 -1
  441. package/dist/esm/ic-breadcrumb-group.entry.js +3 -3
  442. package/dist/esm/ic-breadcrumb-group.entry.js.map +1 -1
  443. package/dist/esm/ic-breadcrumb.entry.js +4 -4
  444. package/dist/esm/ic-breadcrumb.entry.js.map +1 -1
  445. package/dist/esm/ic-button_3.entry.js +4 -4
  446. package/dist/esm/ic-button_3.entry.js.map +1 -1
  447. package/dist/esm/ic-card.entry.js +4 -4
  448. package/dist/esm/ic-card.entry.js.map +1 -1
  449. package/dist/esm/ic-checkbox-group.entry.js +3 -3
  450. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  451. package/dist/esm/ic-checkbox.entry.js +3 -3
  452. package/dist/esm/ic-checkbox.entry.js.map +1 -1
  453. package/dist/esm/ic-chip.entry.js +3 -3
  454. package/dist/esm/ic-chip.entry.js.map +1 -1
  455. package/dist/esm/ic-classification-banner.entry.js +1 -1
  456. package/dist/esm/ic-classification-banner.entry.js.map +1 -1
  457. package/dist/esm/ic-data-entity.entry.js +1 -1
  458. package/dist/esm/ic-data-entity.entry.js.map +1 -1
  459. package/dist/esm/ic-data-row.entry.js +3 -3
  460. package/dist/esm/ic-data-row.entry.js.map +1 -1
  461. package/dist/esm/ic-dialog.entry.js +4 -4
  462. package/dist/esm/ic-dialog.entry.js.map +1 -1
  463. package/dist/esm/ic-divider.entry.js +3 -3
  464. package/dist/esm/ic-divider.entry.js.map +1 -1
  465. package/dist/esm/ic-empty-state.entry.js +3 -3
  466. package/dist/esm/ic-empty-state.entry.js.map +1 -1
  467. package/dist/esm/ic-footer-link-group.entry.js +3 -3
  468. package/dist/esm/ic-footer-link-group.entry.js.map +1 -1
  469. package/dist/esm/ic-footer-link.entry.js +4 -4
  470. package/dist/esm/ic-footer-link.entry.js.map +1 -1
  471. package/dist/esm/ic-footer.entry.js +3 -3
  472. package/dist/esm/ic-footer.entry.js.map +1 -1
  473. package/dist/esm/ic-hero.entry.js +3 -3
  474. package/dist/esm/ic-hero.entry.js.map +1 -1
  475. package/dist/esm/ic-horizontal-scroll.entry.js +3 -3
  476. package/dist/esm/ic-horizontal-scroll.entry.js.map +1 -1
  477. package/dist/esm/ic-input-component-container_3.entry.js +43 -37
  478. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -1
  479. package/dist/esm/ic-input-label_2.entry.js +3 -3
  480. package/dist/esm/ic-input-label_2.entry.js.map +1 -1
  481. package/dist/esm/ic-link.entry.js +4 -4
  482. package/dist/esm/ic-link.entry.js.map +1 -1
  483. package/dist/esm/ic-menu-group.entry.js +1 -1
  484. package/dist/esm/ic-menu-group.entry.js.map +1 -1
  485. package/dist/esm/ic-menu-item.entry.js +5 -5
  486. package/dist/esm/ic-menu-item.entry.js.map +1 -1
  487. package/dist/esm/ic-navigation-button.entry.js +3 -3
  488. package/dist/esm/ic-navigation-button.entry.js.map +1 -1
  489. package/dist/esm/ic-navigation-group.entry.js +4 -4
  490. package/dist/esm/ic-navigation-group.entry.js.map +1 -1
  491. package/dist/esm/ic-navigation-item.entry.js +5 -5
  492. package/dist/esm/ic-navigation-item.entry.js.map +1 -1
  493. package/dist/esm/ic-navigation-menu.entry.js +3 -3
  494. package/dist/esm/ic-navigation-menu.entry.js.map +1 -1
  495. package/dist/esm/ic-page-header.entry.js +3 -3
  496. package/dist/esm/ic-page-header.entry.js.map +1 -1
  497. package/dist/esm/ic-pagination-item.entry.js +3 -3
  498. package/dist/esm/ic-pagination-item.entry.js.map +1 -1
  499. package/dist/esm/ic-pagination.entry.js +3 -3
  500. package/dist/esm/ic-pagination.entry.js.map +1 -1
  501. package/dist/esm/ic-popover-menu.entry.js +4 -4
  502. package/dist/esm/ic-popover-menu.entry.js.map +1 -1
  503. package/dist/esm/ic-radio-group.entry.js +3 -3
  504. package/dist/esm/ic-radio-group.entry.js.map +1 -1
  505. package/dist/esm/ic-radio-option.entry.js +3 -3
  506. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  507. package/dist/esm/ic-search-bar.entry.js +35 -19
  508. package/dist/esm/ic-search-bar.entry.js.map +1 -1
  509. package/dist/esm/ic-section-container.entry.js +1 -1
  510. package/dist/esm/ic-section-container.entry.js.map +1 -1
  511. package/dist/esm/ic-select.entry.js +71 -17
  512. package/dist/esm/ic-select.entry.js.map +1 -1
  513. package/dist/esm/ic-side-navigation.entry.js +5 -5
  514. package/dist/esm/ic-side-navigation.entry.js.map +1 -1
  515. package/dist/esm/ic-skeleton.entry.js +1 -1
  516. package/dist/esm/ic-skeleton.entry.js.map +1 -1
  517. package/dist/esm/ic-status-tag.entry.js +3 -3
  518. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  519. package/dist/esm/ic-step.entry.js +2 -2
  520. package/dist/esm/ic-step.entry.js.map +1 -1
  521. package/dist/esm/ic-stepper.entry.js +3 -3
  522. package/dist/esm/ic-stepper.entry.js.map +1 -1
  523. package/dist/esm/ic-switch.entry.js +3 -3
  524. package/dist/esm/ic-switch.entry.js.map +1 -1
  525. package/dist/esm/ic-tab-context.entry.js +2 -2
  526. package/dist/esm/ic-tab-context.entry.js.map +1 -1
  527. package/dist/esm/ic-tab-group.entry.js +3 -3
  528. package/dist/esm/ic-tab-group.entry.js.map +1 -1
  529. package/dist/esm/ic-tab-panel.entry.js +2 -2
  530. package/dist/esm/ic-tab-panel.entry.js.map +1 -1
  531. package/dist/esm/ic-tab.entry.js +3 -3
  532. package/dist/esm/ic-tab.entry.js.map +1 -1
  533. package/dist/esm/ic-text-field.entry.js +3 -3
  534. package/dist/esm/ic-text-field.entry.js.map +1 -1
  535. package/dist/esm/ic-theme.entry.js +3 -3
  536. package/dist/esm/ic-theme.entry.js.map +1 -1
  537. package/dist/esm/ic-toast-region.entry.js +1 -1
  538. package/dist/esm/ic-toast-region.entry.js.map +1 -1
  539. package/dist/esm/ic-toast.entry.js +4 -4
  540. package/dist/esm/ic-toast.entry.js.map +1 -1
  541. package/dist/esm/ic-top-navigation.entry.js +3 -3
  542. package/dist/esm/ic-top-navigation.entry.js.map +1 -1
  543. package/dist/esm/ic-typography.entry.js +3 -3
  544. package/dist/esm/ic-typography.entry.js.map +1 -1
  545. package/dist/esm/{index-fd30b77e.js → index-14c9f375.js} +98 -26
  546. package/dist/esm/index-14c9f375.js.map +1 -0
  547. package/dist/esm/loader.js +4 -13
  548. package/dist/esm/loader.js.map +1 -1
  549. package/dist/esm/{popper-15e448b4.js → popper-0fbeff6d.js} +1 -1
  550. package/dist/esm/popper-0fbeff6d.js.map +1 -0
  551. package/dist/esm/{types-dd515332.js → types-b2398b37.js} +1 -1
  552. package/dist/esm/types-b2398b37.js.map +1 -0
  553. package/dist/types/components/ic-breadcrumb/ic-breadcrumb.d.ts +3 -3
  554. package/dist/types/components/ic-dialog/ic-dialog.d.ts +5 -5
  555. package/dist/types/components/ic-menu/ic-menu.d.ts +8 -0
  556. package/dist/types/components/ic-search-bar/ic-search-bar.d.ts +8 -0
  557. package/dist/types/components/ic-select/ic-select.d.ts +14 -0
  558. package/dist/types/components.d.ts +32 -0
  559. package/dist/types/stencil-public-runtime.d.ts +17 -5
  560. package/dist/types/utils/helpers.d.ts +2 -2
  561. package/dist/types/utils/types.d.ts +11 -2
  562. package/hydrate/index.d.ts +6 -6
  563. package/hydrate/index.js +280 -164
  564. package/loader/index.d.ts +1 -1
  565. package/package.json +3 -3
  566. package/dist/cjs/OpenInNew-f9958725.js.map +0 -1
  567. package/dist/cjs/check-icon-b2f60716.js.map +0 -1
  568. package/dist/cjs/chevron-icon-2bb3a907.js.map +0 -1
  569. package/dist/cjs/close-icon-04be4880.js.map +0 -1
  570. package/dist/cjs/helpers-3811d14b.js.map +0 -1
  571. package/dist/cjs/index-2a0c6769.js.map +0 -1
  572. package/dist/cjs/popper-d7adcfc6.js.map +0 -1
  573. package/dist/cjs/types-3eb02246.js.map +0 -1
  574. package/dist/core/p-041604fc.entry.js.map +0 -1
  575. package/dist/core/p-07601b81.entry.js.map +0 -1
  576. package/dist/core/p-07877eb8.entry.js.map +0 -1
  577. package/dist/core/p-103c761f.entry.js.map +0 -1
  578. package/dist/core/p-14bea6c0.entry.js.map +0 -1
  579. package/dist/core/p-1ac44a4e.entry.js.map +0 -1
  580. package/dist/core/p-1b1dbb53.entry.js.map +0 -1
  581. package/dist/core/p-20fafec4.entry.js.map +0 -1
  582. package/dist/core/p-24b88371.entry.js.map +0 -1
  583. package/dist/core/p-2ae7687a.entry.js.map +0 -1
  584. package/dist/core/p-2f5a9d91.entry.js.map +0 -1
  585. package/dist/core/p-389c3913.entry.js.map +0 -1
  586. package/dist/core/p-3adb1167.entry.js.map +0 -1
  587. package/dist/core/p-43b529a5.entry.js.map +0 -1
  588. package/dist/core/p-441e7d98.entry.js.map +0 -1
  589. package/dist/core/p-4dc6a83d.entry.js.map +0 -1
  590. package/dist/core/p-4fa9c6eb.entry.js.map +0 -1
  591. package/dist/core/p-50019c47.entry.js.map +0 -1
  592. package/dist/core/p-516fd246.entry.js.map +0 -1
  593. package/dist/core/p-5e3a09d7.entry.js.map +0 -1
  594. package/dist/core/p-5e685037.entry.js.map +0 -1
  595. package/dist/core/p-69920d86.js +0 -3
  596. package/dist/core/p-69920d86.js.map +0 -1
  597. package/dist/core/p-69c1f172.entry.js +0 -2
  598. package/dist/core/p-69c1f172.entry.js.map +0 -1
  599. package/dist/core/p-6bad30aa.entry.js.map +0 -1
  600. package/dist/core/p-6f57b13c.js.map +0 -1
  601. package/dist/core/p-736489c6.entry.js +0 -2
  602. package/dist/core/p-736489c6.entry.js.map +0 -1
  603. package/dist/core/p-75ac2fbf.entry.js.map +0 -1
  604. package/dist/core/p-7c0dcd00.js.map +0 -1
  605. package/dist/core/p-8acd7207.entry.js.map +0 -1
  606. package/dist/core/p-8ca80000.entry.js.map +0 -1
  607. package/dist/core/p-919059e8.entry.js.map +0 -1
  608. package/dist/core/p-92868735.entry.js.map +0 -1
  609. package/dist/core/p-93ee130d.entry.js.map +0 -1
  610. package/dist/core/p-95992c98.entry.js.map +0 -1
  611. package/dist/core/p-96bcd466.entry.js.map +0 -1
  612. package/dist/core/p-98d488aa.entry.js.map +0 -1
  613. package/dist/core/p-9bde930d.entry.js.map +0 -1
  614. package/dist/core/p-9e896463.entry.js +0 -2
  615. package/dist/core/p-9e896463.entry.js.map +0 -1
  616. package/dist/core/p-a29fe0c6.entry.js.map +0 -1
  617. package/dist/core/p-ab4919d6.entry.js.map +0 -1
  618. package/dist/core/p-adf65f4a.entry.js +0 -2
  619. package/dist/core/p-adf65f4a.entry.js.map +0 -1
  620. package/dist/core/p-b5d084c2.entry.js.map +0 -1
  621. package/dist/core/p-bbdd9770.entry.js.map +0 -1
  622. package/dist/core/p-c2fc2b77.entry.js.map +0 -1
  623. package/dist/core/p-c3da58eb.entry.js.map +0 -1
  624. package/dist/core/p-c4b81d32.entry.js.map +0 -1
  625. package/dist/core/p-cfb87422.entry.js.map +0 -1
  626. package/dist/core/p-d2994a71.entry.js.map +0 -1
  627. package/dist/core/p-d592006b.entry.js.map +0 -1
  628. package/dist/core/p-da3bd896.entry.js.map +0 -1
  629. package/dist/core/p-da5fc036.entry.js.map +0 -1
  630. package/dist/core/p-dd980be4.js +0 -2
  631. package/dist/core/p-dd980be4.js.map +0 -1
  632. package/dist/core/p-e14bc195.entry.js.map +0 -1
  633. package/dist/core/p-e2fdb944.entry.js.map +0 -1
  634. package/dist/core/p-e328bd2d.entry.js.map +0 -1
  635. package/dist/core/p-e9c864ac.entry.js.map +0 -1
  636. package/dist/core/p-fb86da80.entry.js.map +0 -1
  637. package/dist/core/p-fbd3c432.entry.js.map +0 -1
  638. package/dist/esm/OpenInNew-67a881e0.js.map +0 -1
  639. package/dist/esm/check-icon-abb210ec.js.map +0 -1
  640. package/dist/esm/chevron-icon-7927f709.js.map +0 -1
  641. package/dist/esm/close-icon-2ce5d375.js.map +0 -1
  642. package/dist/esm/helpers-d7d5bd08.js.map +0 -1
  643. package/dist/esm/index-fd30b77e.js.map +0 -1
  644. package/dist/esm/polyfills/css-shim.js +0 -1
  645. package/dist/esm/popper-15e448b4.js.map +0 -1
  646. package/dist/esm/types-dd515332.js.map +0 -1
  647. /package/dist/core/{p-06321d19.js.map → p-3b185c32.js.map} +0 -0
  648. /package/dist/core/{p-8c7f4343.js.map → p-426ec638.js.map} +0 -0
  649. /package/dist/core/{p-8d4f7027.js.map → p-c2e091d7.js.map} +0 -0
  650. /package/dist/core/{p-f2c6a143.js.map → p-f074ef5b.js.map} +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"names":["icSelectCss","inputIds","Select","this","hasSetDefaultValue","inheritedAttributes","initialOptionsEmpty","inputId","menuId","searchableMenuItemSelected","ungroupedOptions","handleRetry","ev","detail","keyPressed","_a","searchableSelectElement","focus","blurredBecauseButtonPressed","retryButtonClick","icRetryLoad","emit","value","hiddenInputValue","emitIcChange","searchable","clearTimeout","debounceIcChange","window","setTimeout","icChange","currDebounce","emitImmediateIcChange","setOptionsValuesFromLabels","options","length","map","option","label","setUngroupedOptions","event","setTextColor","nativeSelectElement","selectedIndex","className","setMenuChange","open","getLabelFromValue","getFilteredChildMenuOptions","children","getFilteredMenuOptions","includeDescriptionsInSearch","searchableSelectInputValue","searchMatchPosition","pressedCharacters","newOption","Object","assign","handleNativeSelectChange","icOptionSelect","handleCustomSelectChange","emptyOptionListText","currValue","inputValueToFilter","getValueFromLabel","ariaActiveDescendant","optionId","handleMenuChange","handleFocusIndicatorDisplay","handleMenuKeyPress","cancelBubble","handleCharacterKeyDown","key","handleMenuValueChange","focusIndicator","host","shadowRoot","querySelector","classList","add","remove","handleMouseDown","preventDefault","isExternalFiltering","disableFilter","handleClick","menu","filteredOptions","hasTimedOut","loading","noOptions","handleClickOpen","handleExpandIconMouseDown","disabled","handleClear","stopPropagation","timeoutTimer","icClear","customSelectElement","characterKeyPressTimer","handleFilter","handleNativeSelectKeyDown","handleKeyDown","isArrowKey","handleKeyboardOpen","handleClearButtonFocus","clearButtonFocused","handleClearButtonBlur","retryButton","relatedTarget","isGrouped","newFilteredOptions","menuOptionsFiltered","includeGroupTitlesInSearch","indexOf","push","noChildOptionsWhenFiltered","triggerLoading","loadingLabel","timeout","loadingErrorLabel","timedOut","find","handleSearchableSelectInput","target","icInput","debounceAriaLiveUpdate","updateSearchableSelectResultAriaLive","searchableSelectResultsStatusEl","innerText","getDefaultValue","onFocus","icFocus","onBlur","tagName","includes","isSearchableAndNoFocusedInternalElements","Array","from","querySelectorAll","clearButton","icBlur","onTimeoutBlur","handleFormReset","initialValue","debounce","loadingHandler","newValue","watchOptionsHandler","setDefaultValue","debounceChangedHandler","updateOnChangeDebounce","valueChangedHandler","disconnectedCallback","removeFormResetListener","componentWillLoad","inheritAttributes","IC_INHERITED_ARIA","removeDisabledFalse","addFormResetListener","componentDidLoad","onComponentRequiredPropUndefined","prop","propName","componentDidRender","async","debounceAria","render","small","fullWidth","helperText","hideLabel","name","placeholder","readonly","required","showClearButton","validationStatus","validationText","noOptionSelect","inputValue","renderHiddenInput","invalid","IcInformationStatus","Error","describedBy","getInputDescribedByText","hasValidationStatus","trim","h","Host","class","for","ref","el","anchorEl","isMobileOrTablet","onChange","id","onKeyDown","selected","role","autocomplete","onInput","onClick","innerHTML","Clear","size","variant","appearance","IcThemeForegroundEnum","Light","Dark","onMouseDown","Expand","undefined","inputEl","inputLabel","onMenuStateChange","onMenuOptionSelect","onMenuKeyPress","onMenuValueChange","onUngroupedOptionsSet","onRetryButtonClicked","parentEl","activationType","ariaLiveMode","status","message"],"sources":["./src/components/ic-select/ic-select.css?tag=ic-select&encapsulation=shadow","./src/components/ic-select/ic-select.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n/**\n * @prop --input-width: Width of the input field\n * @prop --ic-z-index-menu: z-index of select menu\n */\n\n:host {\n position: relative;\n}\n\n:host(.full-width) {\n width: 100%;\n}\n\nic-input-component-container:hover {\n --border-color: var(--ic-action-dark-hover);\n}\n\nic-input-component-container:active {\n --border-color: var(--ic-action-dark-active);\n\n color: var(--ic-action-dark-active);\n}\n\nic-input-component-container.menu-open {\n --border-color: var(--ic-architectural-400);\n\n color: var(--ic-action-dark);\n}\n\nic-input-validation .status-icon,\nic-input-validation .statustext {\n visibility: visible;\n}\n\nic-input-validation.menu-open .status-icon,\nic-input-validation.menu-open .statustext {\n visibility: hidden;\n transition: visibility 0s;\n}\n\nic-input-label {\n margin-bottom: var(--ic-space-xs) !important;\n}\n\nselect {\n border: 0;\n border-radius: var(--ic-border-radius);\n background-color: var(--ic-architectural-white);\n color: var(--ic-color-primary-text);\n line-height: 1.5rem;\n letter-spacing: 0.005rem;\n width: 100%;\n height: 100%;\n padding-left: 0.375rem;\n appearance: none;\n background-repeat: no-repeat;\n background-position: right 0.375rem center;\n background-image: url(\"data:image/svg+xml;utf8,<svg fill='black' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/><path d='M0 0h24v24H0z' fill='none'/></svg>\");\n}\n\nselect option,\n.select-option-selected {\n color: var(--ic-color-primary-text);\n}\n\nselect:disabled {\n color: var(--ic-architectural-200);\n background-image: url(\"data:image/svg+xml;utf8,<svg fill='grey' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/><path d='M0 0h24v24H0z' fill='none'/></svg>\");\n}\n\nselect:focus {\n border: 0;\n outline: 0;\n}\n\nselect:not([disabled]) {\n cursor: pointer;\n}\n\n.select-container {\n width: 100%;\n display: flex;\n align-items: center;\n position: relative;\n}\n\n.select-input {\n width: 100%;\n height: 100%;\n padding: 0 0.375rem;\n display: flex;\n cursor: pointer;\n align-items: center;\n justify-content: space-between;\n background: none;\n border: none;\n}\n\n.select-input:focus {\n outline: var(--ic-hc-focus-outline);\n}\n\n:host(:not(.disabled)) ic-input-component-container:hover .select-input {\n background-color: var(--ic-architectural-white);\n}\n\n.select-input[disabled] {\n pointer-events: none;\n}\n\n:host(.searchable) .select-input {\n cursor: auto;\n}\n\n.searchable-select-container {\n align-items: center;\n display: flex;\n width: 100%;\n position: relative;\n}\n\n.expand-icon {\n height: var(--ic-space-lg);\n padding-left: var(--ic-space-xs);\n color: var(--ic-action-dark);\n}\n\n.expand-icon > svg {\n display: inline-block;\n width: var(--ic-space-lg);\n height: var(--ic-space-lg);\n}\n\n:host(.disabled) .expand-icon,\n:host(.disabled) .expand-icon > svg > path {\n color: var(--ic-architectural-200);\n}\n\n:host(.searchable) .expand-icon {\n padding-left: var(--ic-space-xxs);\n height: 2.25rem;\n}\n\n:host(.searchable) .expand-icon > svg {\n height: 2.25rem;\n padding: 0 0.375rem;\n}\n\n:host(.searchable:not(.disabled)) .expand-icon > svg {\n cursor: pointer;\n}\n\n.expand-icon-open {\n color: var(--ic-action-dark);\n}\n\n.expand-icon-filled {\n color: var(--ic-action-dark);\n}\n\n.expand-icon-open,\n:host(.searchable) .expand-icon-open {\n transform: rotateX(180deg);\n}\n\n:host(.disabled) .value-text,\n.placeholder {\n color: var(--ic-color-tertiary-text);\n}\n\n.select-input-end {\n display: flex;\n align-items: center;\n}\n\n.clear-button-container {\n display: flex;\n gap: var(--ic-space-xxs);\n padding-left: 2.375rem;\n}\n\n:host(.small) .clear-button-container {\n padding-left: 1.875rem;\n}\n\n.divider {\n width: var(--ic-space-1px);\n background-color: var(--ic-architectural-400);\n margin: var(--ic-space-xxs) 0;\n border-radius: var(--ic-space-1px);\n height: var(--ic-space-lg);\n}\n\n:host(.small) .divider {\n height: var(--ic-space-md);\n}\n\n.clear-button {\n position: absolute;\n right: 2.75rem;\n border-radius: var(--ic-border-radius);\n transition: box-shadow var(--ic-easing-transition),\n border-radius var(--ic-easing-transition);\n}\n\n.clear-button:focus {\n background-color: var(--ic-focus-blue);\n box-shadow: inset 0 0 0 0.125rem var(--ic-focus-glow);\n border-radius: 0.25rem;\n}\n\n.clear-button:focus * {\n fill: white;\n}\n\n.searchable-select-results-status {\n border: 0;\n clip: rect(0, 0, 0, 0, 0);\n height: var(--ic-space-1px);\n overflow: hidden;\n padding: 0;\n position: absolute;\n white-space: nowrap;\n width: var(--ic-space-1px);\n}\n","import {\n Component,\n Element,\n Event,\n EventEmitter,\n Host,\n Method,\n Prop,\n h,\n State,\n Watch,\n} from \"@stencil/core\";\n\nimport {\n getInputDescribedByText,\n getLabelFromValue,\n hasValidationStatus,\n inheritAttributes,\n onComponentRequiredPropUndefined,\n renderHiddenInput,\n isMobileOrTablet,\n getFilteredMenuOptions,\n addFormResetListener,\n removeFormResetListener,\n removeDisabledFalse,\n} from \"../../utils/helpers\";\nimport { IC_INHERITED_ARIA } from \"../../utils/constants\";\nimport {\n IcInformationStatus,\n IcInformationStatusOrEmpty,\n IcThemeForegroundEnum,\n IcMenuOption,\n IcSearchMatchPositions,\n IcValueEventDetail,\n} from \"../../utils/types\";\nimport Expand from \"./assets/Expand.svg\";\nimport Clear from \"./assets/Clear.svg\";\nimport { IcOptionSelectEventDetail } from \"../ic-menu/ic-menu.types\";\n\nlet inputIds = 0;\n\n@Component({\n tag: \"ic-select\",\n styleUrl: \"ic-select.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport class Select {\n private anchorEl: HTMLElement;\n private blurredBecauseButtonPressed: boolean;\n private characterKeyPressTimer: number;\n private clearButton: HTMLIcButtonElement;\n private customSelectElement: HTMLButtonElement;\n private debounceAria: number;\n private hasSetDefaultValue = false;\n private hasTimedOut: boolean;\n private inheritedAttributes: { [k: string]: unknown } = {};\n private initialOptionsEmpty = false;\n private inputId = `ic-select-input-${inputIds++}`;\n private menu: HTMLIcMenuElement;\n private menuId = `${this.inputId}-menu`;\n private nativeSelectElement: HTMLSelectElement;\n private retryButtonClick: boolean;\n private searchableMenuItemSelected: boolean = false;\n private searchableSelectElement: HTMLInputElement;\n private timeoutTimer: number;\n private ungroupedOptions: IcMenuOption[] = [];\n\n @Element() host!: HTMLIcSelectElement;\n\n @State() ariaActiveDescendant: string;\n @State() clearButtonFocused: boolean = false;\n @State() debounceIcChange: number;\n @State() hiddenInputValue: string;\n @State() noOptions: IcMenuOption[] = null;\n @State() open: boolean = false;\n @State() pressedCharacters: string = \"\";\n @State() searchableSelectInputValue: string = null;\n\n /**\n * @deprecated This prop should not be used anymore.\n */\n @Prop() charactersUntilSuggestions?: number = 0;\n\n /**\n * If `true`, the disabled state will be set.\n */\n @Prop({ reflect: true }) disabled?: boolean = false;\n\n /**\n * If `true`, the built in filtering will be disabled for a searchable variant. For example, if options will already be filtered from external source.\n */\n @Prop() disableFilter?: boolean = false;\n\n /**\n * The text displayed when there are no options in the option list.\n */\n @Prop() emptyOptionListText = \"No results found\";\n\n /**\n * If `true`, the select element will fill the width of the container.\n */\n @Prop() fullWidth: boolean = false;\n\n /**\n * The helper text that will be displayed for additional field guidance.\n */\n @Prop() helperText?: string = \"\";\n\n /**\n * If `true`, the label will be hidden and the required label value will be applied as an aria-label.\n */\n @Prop() hideLabel?: boolean = false;\n\n /**\n * If `true`, descriptions of options will be included when filtering options in a searchable select. Only applies to built in filtering.\n */\n @Prop() includeDescriptionsInSearch?: boolean = false;\n\n /**\n * If `true`, group titles of grouped options will be included when filtering options in a searchable select. Only applies to built in filtering.\n */\n @Prop() includeGroupTitlesInSearch?: boolean = false;\n\n /**\n * The label for the select.\n */\n @Prop() label!: string;\n\n /**\n * The message displayed when external loading times out.\n */\n @Prop() loadingErrorLabel?: string = \"Loading Error\";\n\n /**\n * The message displayed whilst the options are being loaded externally.\n */\n @Prop() loadingLabel?: string = \"Loading...\";\n\n /**\n * The name of the control, which is submitted with the form data.\n */\n @Prop() name?: string = this.inputId;\n\n /**\n * The placeholder value to be displayed.\n */\n @Prop() placeholder?: string = \"Select an option\";\n\n /**\n * If `true`, the readonly state will be set.\n */\n @Prop() readonly?: boolean = false;\n\n /**\n * If `true`, the select will require a value.\n */\n @Prop() required?: boolean = false;\n\n /**\n * If `true`, a searchable variant of the select will be displayed which can be typed in to filter options.\n */\n @Prop() searchable?: boolean = false;\n\n /**\n * Whether the search string of the searchable select should match the start of or anywhere in the options. Only applies to built in filtering.\n */\n @Prop() searchMatchPosition?: IcSearchMatchPositions = \"anywhere\";\n\n /**\n * If `true`, a button which clears the select input when clicked will be displayed. The button will always appear on the searchable select.\n */\n @Prop() showClearButton?: boolean = false;\n\n /**\n * If `true`, the small styling will be applied to the select.\n */\n @Prop() small?: boolean = false;\n\n /**\n * If using external filtering, set a timeout for when loading takes too long.\n */\n @Prop() timeout?: number;\n\n /**\n * The validation status - e.g. 'error' | 'warning' | 'success'.\n */\n @Prop() validationStatus?: IcInformationStatusOrEmpty = \"\";\n\n /**\n * The text to display as the validation message.\n */\n @Prop() validationText?: string = \"\";\n\n /**\n * If `true`, the loading state will be triggered when fetching options asyncronously.\n */\n @Prop({ mutable: true }) loading?: boolean = false;\n\n @Watch(\"loading\")\n loadingHandler(newValue: boolean): void {\n newValue && this.triggerLoading();\n }\n\n /**\n * The possible selection options.\n */\n @Prop() options?: IcMenuOption[] = [];\n @State() filteredOptions: IcMenuOption[] = this.options;\n\n @Watch(\"options\")\n watchOptionsHandler(): void {\n if (!this.hasTimedOut) {\n this.loading = false;\n clearTimeout(this.timeoutTimer);\n if (this.isExternalFiltering()) {\n if (this.options.length > 0) {\n this.setOptionsValuesFromLabels();\n this.noOptions = null;\n this.filteredOptions = this.options;\n } else {\n this.noOptions = [{ label: this.emptyOptionListText, value: \"\" }];\n this.filteredOptions = this.noOptions;\n }\n this.updateSearchableSelectResultAriaLive();\n this.setDefaultValue();\n } else {\n this.setOptionsValuesFromLabels();\n this.filteredOptions = this.options;\n\n if (this.initialOptionsEmpty) {\n this.setDefaultValue();\n this.initialOptionsEmpty = false;\n }\n }\n } else {\n if (!this.searchable) this.options = this.noOptions;\n }\n }\n\n /**\n * The amount of time, in milliseconds, to wait to trigger the `icChange` event after each keystroke.\n */\n @Prop() debounce?: number = 0;\n @State() currDebounce = this.debounce;\n\n @Watch(\"debounce\")\n debounceChangedHandler(newValue: number): void {\n this.updateOnChangeDebounce(newValue);\n }\n\n /**\n * The value of the select, reflected by the value of the currently selected option. For the searchable variant, the value is also reflected by the user input.\n */\n @Prop({ mutable: true }) value?: string;\n @State() initialValue = this.value;\n @State() inputValueToFilter = this.value;\n @State() currValue = this.value;\n\n @Watch(\"value\")\n valueChangedHandler(): void {\n if (this.value !== this.currValue) {\n this.currValue = this.value;\n }\n\n if (this.searchable) {\n this.searchableSelectInputValue =\n this.getLabelFromValue(this.currValue) || this.currValue;\n }\n }\n\n /**\n * Emitted when the select loses focus.\n */\n @Event() icBlur!: EventEmitter<void>;\n\n /**\n * Emitted when the value changes.\n */\n @Event() icChange!: EventEmitter<IcValueEventDetail>;\n\n /**\n * Emitted when the clear button is clicked.\n */\n @Event() icClear!: EventEmitter<void>;\n\n /**\n * Emitted when the select gains focus.\n */\n @Event() icFocus!: EventEmitter<void>;\n\n /**\n * Emitted when a keyboard input occurred.\n */\n @Event() icInput: EventEmitter<IcValueEventDetail>;\n\n /**\n * Emitted when an option is highlighted within the menu.\n * Highlighting a menu item will also trigger an `icChange/onIcChange` due to the value being updated.\n */\n @Event() icOptionSelect: EventEmitter<IcOptionSelectEventDetail>;\n\n /**\n * Emitted when the 'retry loading' button is clicked for a searchable variant.\n */\n @Event() icRetryLoad: EventEmitter<IcValueEventDetail>;\n\n disconnectedCallback(): void {\n removeFormResetListener(this.host, this.handleFormReset);\n }\n\n componentWillLoad(): void {\n this.inheritedAttributes = inheritAttributes(this.host, [\n ...IC_INHERITED_ARIA,\n \"tabindex\",\n \"title\",\n ]);\n\n removeDisabledFalse(this.disabled, this.host);\n\n this.setOptionsValuesFromLabels();\n\n addFormResetListener(this.host, this.handleFormReset);\n\n if (!this.options.length) {\n this.initialOptionsEmpty = true;\n } else {\n this.setDefaultValue();\n }\n }\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.label, propName: \"label\" }],\n \"Select\"\n );\n\n if (this.loading) this.triggerLoading();\n\n this.hiddenInputValue = this.searchable && this.currValue;\n }\n\n componentDidRender(): void {\n if (this.nativeSelectElement && !this.disabled) {\n this.setTextColor();\n }\n }\n\n /**\n * Sets focus on the input box.\n */\n @Method()\n async setFocus(): Promise<void> {\n if (this.nativeSelectElement) {\n this.nativeSelectElement.focus();\n } else if (this.customSelectElement) {\n this.customSelectElement.focus();\n } else if (this.searchableSelectElement) {\n this.searchableSelectElement.focus();\n }\n }\n\n private handleRetry = (ev: CustomEvent<IcValueEventDetail>) => {\n if (ev.detail.keyPressed) this.searchableSelectElement?.focus();\n this.blurredBecauseButtonPressed = true;\n this.retryButtonClick = true;\n this.hasSetDefaultValue = true;\n this.icRetryLoad.emit({ value: this.hiddenInputValue });\n };\n\n private updateOnChangeDebounce(newValue: number) {\n if (this.currDebounce !== newValue) {\n this.currDebounce = newValue;\n }\n }\n\n private emitIcChange = (value: string) => {\n if (!this.searchable) {\n this.value = value;\n }\n\n clearTimeout(this.debounceIcChange);\n this.debounceIcChange = window.setTimeout(() => {\n this.icChange.emit({ value: value });\n }, this.currDebounce);\n };\n\n private emitImmediateIcChange = (value: string) => {\n this.value = value;\n clearTimeout(this.debounceIcChange);\n this.icChange.emit({ value: value });\n };\n\n private setOptionsValuesFromLabels = (): void => {\n if (this.options.length > 0 && this.options.map) {\n this.options.map((option) => {\n if (!option.value) {\n option.value = option.label;\n }\n });\n }\n };\n\n private setUngroupedOptions = (event: CustomEvent): void => {\n this.ungroupedOptions = event.detail.options;\n };\n\n private setTextColor = (): void => {\n if (this.nativeSelectElement.selectedIndex === 0) {\n this.nativeSelectElement.className = \"placeholder\";\n } else {\n this.nativeSelectElement.className = \"select-option-selected\";\n }\n };\n\n private setMenuChange = (open: boolean) => {\n if (this.open !== open) {\n this.open = open;\n }\n };\n\n private getLabelFromValue = (value: string): string | undefined => {\n return getLabelFromValue(value, this.options);\n };\n\n private getFilteredChildMenuOptions = (option: IcMenuOption) => {\n let children = option.children;\n\n if (this.searchable) {\n children = getFilteredMenuOptions(\n option.children,\n this.includeDescriptionsInSearch,\n this.searchableSelectInputValue,\n this.searchMatchPosition\n );\n } else {\n children = getFilteredMenuOptions(\n option.children,\n false,\n this.pressedCharacters,\n \"start\"\n );\n }\n\n const newOption = { ...option };\n newOption.children = children;\n return newOption;\n };\n\n private handleNativeSelectChange = (): void => {\n this.icOptionSelect.emit({ value: this.nativeSelectElement.value });\n this.emitImmediateIcChange(this.nativeSelectElement.value);\n this.setTextColor();\n };\n\n private handleCustomSelectChange = (event: CustomEvent): void => {\n if (this.searchable && event.detail.label === this.emptyOptionListText) {\n this.searchableSelectElement.focus();\n return;\n }\n\n if (this.searchable) {\n this.value = event.detail.value;\n this.searchableMenuItemSelected = true;\n\n // After editing the input, if selecting the same option as before, set the input value to label again\n if (this.value === this.currValue) {\n this.searchableSelectInputValue = this.getLabelFromValue(this.value);\n }\n\n this.inputValueToFilter = null;\n this.hiddenInputValue = this.getValueFromLabel(\n this.searchableSelectInputValue\n );\n }\n\n this.ariaActiveDescendant = event.detail.optionId;\n this.icOptionSelect.emit({ value: event.detail.value });\n this.emitIcChange(event.detail.value);\n };\n\n private handleMenuChange = (event: CustomEvent): void => {\n this.open = event.detail.open;\n this.pressedCharacters = \"\";\n\n this.searchable && this.handleFocusIndicatorDisplay();\n };\n\n // clears the debounce delay when navigating the menu with arrow keys etc\n // to prevent delay in change event, which should only occur when typing in input\n private handleMenuKeyPress = (ev: CustomEvent): void => {\n ev.cancelBubble = true;\n this.handleCharacterKeyDown(ev.detail.key);\n };\n\n private handleMenuValueChange = (ev: CustomEvent): void => {\n this.value = ev.detail.value;\n };\n\n private handleFocusIndicatorDisplay = () => {\n const focusIndicator =\n this.host.shadowRoot.querySelector(\".focus-indicator\");\n\n if (this.open) {\n focusIndicator.classList.add(\"focus-indicator-enabled\");\n } else {\n focusIndicator.classList.remove(\"focus-indicator-enabled\");\n }\n };\n\n private handleMouseDown = (event: Event): void => {\n if (!this.open) {\n event.preventDefault();\n }\n };\n\n private isExternalFiltering = (): boolean =>\n this.searchable && this.disableFilter;\n\n private handleClick = (event: MouseEvent): void => {\n if (!this.open) {\n if (this.isExternalFiltering()) {\n this.menu.options = this.filteredOptions;\n } else if (\n !this.hasTimedOut &&\n !this.loading &&\n (!this.searchable || this.searchableMenuItemSelected)\n ) {\n this.noOptions = null;\n this.menu.options = this.options;\n }\n }\n\n if (event.detail !== 0) {\n this.menu.handleClickOpen();\n }\n };\n\n private handleExpandIconMouseDown = (event: MouseEvent) => {\n if (!this.disabled) {\n event.preventDefault();\n this.searchableSelectElement.focus();\n this.handleClick(event);\n }\n };\n\n private handleClear = (event: Event): void => {\n event.stopPropagation();\n this.hasTimedOut = false;\n clearTimeout(this.timeoutTimer);\n this.noOptions = null;\n this.emitImmediateIcChange(null);\n this.icClear.emit();\n\n if (this.searchable) {\n this.searchableSelectElement.value = null;\n this.searchableSelectInputValue = null;\n this.filteredOptions = this.options;\n this.hiddenInputValue = null;\n this.searchableSelectElement.focus();\n } else {\n this.customSelectElement.focus();\n }\n };\n\n private handleCharacterKeyDown = (key: string) => {\n // Only close menu when space is pressed if not being used alongside character keys to quickly select options\n if (\n this.open &&\n key === \" \" &&\n this.pressedCharacters.length === 0 &&\n !this.hasTimedOut &&\n !this.loading\n ) {\n this.setMenuChange(false);\n }\n\n if (key.length === 1 && !this.searchable) {\n window.clearTimeout(this.characterKeyPressTimer);\n this.characterKeyPressTimer = window.setTimeout(\n () => (this.pressedCharacters = \"\"),\n 1000\n );\n\n this.pressedCharacters += key;\n this.handleFilter();\n\n if (!this.noOptions) {\n this.emitImmediateIcChange(this.filteredOptions[0].value);\n }\n } else {\n this.pressedCharacters = \"\";\n }\n };\n\n private handleNativeSelectKeyDown = (event: KeyboardEvent) => {\n if ((event.key !== \"Escape\" && event.key !== \"Tab\") || this.open) {\n event.cancelBubble = true;\n }\n this.handleCharacterKeyDown(event.key);\n };\n\n private handleKeyDown = (event: KeyboardEvent): void => {\n if ((event.key !== \"Escape\" && event.key !== \"Tab\") || this.open) {\n event.cancelBubble = true;\n }\n const isArrowKey = event.key === \"ArrowDown\" || event.key === \"ArrowUp\";\n\n if (!this.open) {\n if (this.isExternalFiltering() && (event.key === \"Enter\" || isArrowKey)) {\n this.menu.options = this.filteredOptions;\n } else {\n if (!this.hasTimedOut) {\n this.noOptions = null;\n this.menu.options = this.options;\n }\n }\n }\n\n if (this.open && event.key === \"Enter\") {\n this.setMenuChange(false);\n } else {\n if (!(isArrowKey && this.noOptions !== null)) {\n if (!(event.key === \" \" && this.pressedCharacters.length > 0)) {\n // Keyboard events get passed onto ic-menu\n this.menu.handleKeyboardOpen(event);\n }\n this.handleCharacterKeyDown(event.key);\n }\n }\n };\n\n private handleClearButtonFocus = (): void => {\n this.clearButtonFocused = true;\n };\n\n private handleClearButtonBlur = (ev: FocusEvent): void => {\n const retryButton = this.menu?.querySelector(\"#retry-button\");\n if (\n !(\n this.searchableSelectElement &&\n ev.relatedTarget === this.searchableSelectElement\n ) &&\n !(retryButton && ev.relatedTarget === retryButton)\n ) {\n this.setMenuChange(false);\n this.handleFocusIndicatorDisplay();\n }\n this.clearButtonFocused = false;\n };\n\n private handleFilter = (): void => {\n const options = this.searchable ? [...this.options] : this.ungroupedOptions;\n\n let isGrouped = false;\n let newFilteredOptions: IcMenuOption[] = [];\n\n options.map((option) => {\n if (option.children) isGrouped = true;\n });\n\n let menuOptionsFiltered: IcMenuOption[];\n\n if (this.searchable) {\n menuOptionsFiltered = getFilteredMenuOptions(\n options,\n this.includeDescriptionsInSearch,\n this.inputValueToFilter,\n this.searchMatchPosition\n );\n this.searchableMenuItemSelected = false;\n } else {\n menuOptionsFiltered = getFilteredMenuOptions(\n options,\n false,\n this.pressedCharacters,\n \"start\"\n );\n }\n\n if (!isGrouped) {\n newFilteredOptions = menuOptionsFiltered;\n } else {\n options.map((option) => {\n if (this.includeGroupTitlesInSearch) {\n if (menuOptionsFiltered.indexOf(option) !== -1) {\n newFilteredOptions.push(option);\n } else {\n newFilteredOptions.push(this.getFilteredChildMenuOptions(option));\n }\n } else {\n newFilteredOptions.push(this.getFilteredChildMenuOptions(option));\n }\n });\n }\n\n let noChildOptionsWhenFiltered = false;\n\n if (isGrouped) {\n noChildOptionsWhenFiltered = true;\n newFilteredOptions.map((option) => {\n if (option.children.length > 0) {\n noChildOptionsWhenFiltered = false;\n }\n });\n }\n\n const noOptions = [{ label: this.emptyOptionListText, value: \"\" }];\n\n if (newFilteredOptions.length > 0 && !noChildOptionsWhenFiltered) {\n this.noOptions = null;\n this.filteredOptions = newFilteredOptions;\n } else {\n this.noOptions = noOptions;\n this.filteredOptions = this.noOptions;\n }\n };\n\n private triggerLoading = () => {\n this.hasTimedOut = false;\n this.noOptions = [{ label: this.loadingLabel, value: \"\", loading: true }];\n if (this.filteredOptions !== this.noOptions && this.searchable)\n this.filteredOptions = this.noOptions;\n else if (!this.searchable && this.options !== this.noOptions)\n this.options = this.noOptions;\n if (this.timeout) {\n this.timeoutTimer = window.setTimeout(() => {\n this.loading = false;\n this.hasTimedOut = true;\n this.noOptions = [\n { label: this.loadingErrorLabel, value: \"\", timedOut: true },\n ];\n this.filteredOptions = this.noOptions;\n if (!this.searchable) this.options = this.noOptions;\n }, this.timeout);\n }\n };\n\n private getValueFromLabel = (label: string): string | undefined => {\n return this.options.find((option) => option.label === label)?.value;\n };\n\n private handleSearchableSelectInput = (event: Event): void => {\n this.searchableSelectInputValue = (event.target as HTMLInputElement).value;\n this.icInput.emit({ value: this.searchableSelectInputValue });\n this.emitIcChange(this.searchableSelectInputValue);\n\n this.hiddenInputValue = this.searchableSelectInputValue;\n this.inputValueToFilter = this.searchableSelectInputValue;\n this.setMenuChange(true);\n\n if (!this.disableFilter) {\n this.handleFilter();\n this.debounceAriaLiveUpdate();\n }\n };\n\n private updateSearchableSelectResultAriaLive = (): void => {\n const searchableSelectResultsStatusEl = this.host.shadowRoot.querySelector(\n \".searchable-select-results-status\"\n ) as HTMLDivElement;\n\n if (searchableSelectResultsStatusEl) {\n if (this.noOptions !== null) {\n searchableSelectResultsStatusEl.innerText = this.emptyOptionListText;\n } else {\n searchableSelectResultsStatusEl.innerText = \"\";\n }\n }\n };\n\n private debounceAriaLiveUpdate() {\n clearTimeout(this.debounceAria);\n\n window.setTimeout(() => {\n this.updateSearchableSelectResultAriaLive();\n }, 800);\n }\n\n private getDefaultValue = (value: string): string | null =>\n this.getLabelFromValue(value) || value || null;\n\n private setDefaultValue() {\n if (!this.hasSetDefaultValue && this.currValue) {\n this.searchableSelectInputValue = this.getDefaultValue(this.currValue);\n this.initialValue = this.currValue;\n this.hasSetDefaultValue = true;\n }\n }\n\n private onFocus = (): void => {\n this.icFocus.emit();\n };\n\n private onBlur = (event: FocusEvent): void => {\n const target = event.relatedTarget as HTMLElement;\n if (\n target !== null &&\n target.tagName === \"UL\" &&\n target.className.includes(\"menu\")\n ) {\n return;\n }\n\n const retryButton = this.menu?.querySelector(\"#retry-button\");\n const isSearchableAndNoFocusedInternalElements =\n this.searchable &&\n event.relatedTarget !== this.menu &&\n !Array.from(this.menu.querySelectorAll(\"[role='option']\")).includes(\n event.relatedTarget as Element\n ) &&\n !(this.clearButton && event.relatedTarget === this.clearButton) &&\n !(retryButton && event.relatedTarget === retryButton);\n\n if (isSearchableAndNoFocusedInternalElements) {\n if (!this.retryButtonClick) {\n this.setMenuChange(false);\n }\n this.handleFocusIndicatorDisplay();\n }\n\n this.retryButtonClick = false;\n this.icBlur.emit();\n };\n\n private onTimeoutBlur = (ev: CustomEvent) => {\n if (\n (ev.detail.ev as FocusEvent).relatedTarget !==\n this.searchableSelectElement &&\n !this.blurredBecauseButtonPressed\n ) {\n this.setMenuChange(false);\n this.handleFocusIndicatorDisplay();\n this.icBlur.emit();\n }\n this.blurredBecauseButtonPressed = false;\n };\n\n private handleFormReset = (): void => {\n this.value = this.initialValue;\n if (this.searchable) {\n this.searchableSelectInputValue = this.getDefaultValue(this.value);\n this.hiddenInputValue = this.value;\n }\n };\n\n render() {\n const {\n small,\n disabled,\n fullWidth,\n helperText,\n hideLabel,\n label,\n menuId,\n name,\n options,\n placeholder,\n readonly,\n required,\n searchable,\n showClearButton,\n validationStatus,\n validationText,\n currValue,\n } = this;\n\n const noOptionSelect =\n searchable &&\n (this.loading ||\n this.hasTimedOut ||\n (this.noOptions !== null &&\n this.noOptions[0] &&\n this.noOptions[0].label === this.emptyOptionListText));\n const inputValue = this.searchable ? this.hiddenInputValue : currValue;\n\n renderHiddenInput(true, this.host, name, inputValue, disabled);\n\n const invalid =\n validationStatus === IcInformationStatus.Error ? \"true\" : \"false\";\n\n const describedBy = getInputDescribedByText(\n this.inputId,\n helperText !== \"\",\n hasValidationStatus(this.validationStatus, this.disabled)\n ).trim();\n\n return (\n <Host\n class={{\n disabled: disabled,\n searchable: searchable,\n small: small,\n \"full-width\": fullWidth,\n }}\n onBlur={this.onBlur}\n >\n <ic-input-container readonly={readonly}>\n {!hideLabel && (\n <ic-input-label\n for={this.inputId}\n label={label}\n helperText={helperText}\n required={required}\n disabled={disabled}\n readonly={readonly}\n ></ic-input-label>\n )}\n <ic-input-component-container\n ref={(el) => (this.anchorEl = el)}\n class={{ \"menu-open\": this.open }}\n small={small}\n fullWidth={fullWidth}\n disabled={disabled}\n readonly={readonly}\n validationStatus={validationStatus}\n >\n {readonly ? (\n <ic-typography>\n <p>{this.getLabelFromValue(currValue)}</p>\n </ic-typography>\n ) : isMobileOrTablet() ? (\n <select\n ref={(el) => (this.nativeSelectElement = el)}\n disabled={disabled}\n onChange={this.handleNativeSelectChange}\n required={required}\n id={this.inputId}\n aria-label={label}\n aria-describedby={describedBy}\n aria-invalid={invalid}\n onBlur={this.onBlur}\n onFocus={this.onFocus}\n onKeyDown={this.handleNativeSelectKeyDown}\n {...this.inheritedAttributes}\n >\n <option value=\"\" selected disabled={!showClearButton}>\n {placeholder}\n </option>\n {options.map((option) => {\n if (option.children) {\n return (\n <optgroup label={option.label}>\n {option.children.map((option) => (\n <option\n value={option.value}\n disabled={option.disabled}\n selected={option.value === currValue}\n >\n {option.label}\n </option>\n ))}\n </optgroup>\n );\n } else {\n return (\n <option\n value={option.value}\n disabled={option.disabled}\n selected={option.value === currValue}\n >\n {option.label}\n </option>\n );\n }\n })}\n </select>\n ) : searchable ? (\n <div class=\"searchable-select-container\">\n <input\n class=\"select-input\"\n role=\"combobox\"\n autocomplete=\"off\"\n aria-label={label}\n aria-describedby={describedBy}\n aria-activedescendant={this.ariaActiveDescendant}\n aria-autocomplete=\"list\"\n aria-expanded={this.open ? \"true\" : \"false\"}\n aria-invalid={invalid}\n aria-required={required ? \"true\" : \"false\"}\n aria-controls={menuId}\n ref={(el) => (this.searchableSelectElement = el)}\n id={this.inputId}\n value={this.searchableSelectInputValue}\n placeholder={placeholder}\n disabled={disabled}\n onInput={this.handleSearchableSelectInput}\n onClick={this.handleClick}\n onKeyDown={this.handleKeyDown}\n onFocus={this.onFocus}\n onBlur={this.onBlur}\n ></input>\n {this.searchableSelectInputValue &&\n (showClearButton || searchable) && (\n <div class=\"clear-button-container\">\n <ic-button\n id=\"clear-button\"\n ref={(el) => (this.clearButton = el)}\n aria-label={\n this.searchableSelectInputValue && currValue === null\n ? \"Clear input\"\n : \"Clear selection\"\n }\n class=\"clear-button\"\n innerHTML={Clear}\n onClick={this.handleClear}\n onFocus={this.handleClearButtonFocus}\n onBlur={this.handleClearButtonBlur}\n size={small ? \"small\" : \"default\"}\n variant=\"icon\"\n appearance={\n this.clearButtonFocused\n ? IcThemeForegroundEnum.Light\n : IcThemeForegroundEnum.Dark\n }\n ></ic-button>\n <div class=\"divider\"></div>\n </div>\n )}\n <span\n onMouseDown={this.handleExpandIconMouseDown}\n class={{\n \"expand-icon\": true,\n \"expand-icon-open\": this.open,\n \"expand-icon-filled\": !(\n currValue == null || currValue === \"\"\n ),\n }}\n innerHTML={Expand}\n aria-hidden=\"true\"\n />\n <div\n aria-live=\"polite\"\n role=\"status\"\n class=\"searchable-select-results-status\"\n ></div>\n </div>\n ) : (\n <div class=\"select-container\">\n <button\n class=\"select-input\"\n ref={(el) => (this.customSelectElement = el)}\n id={this.inputId}\n aria-label={`${label}, ${\n this.getLabelFromValue(currValue) || placeholder\n }${required ? \", required\" : \"\"}`}\n aria-describedby={describedBy}\n aria-invalid={invalid}\n aria-haspopup=\"listbox\"\n aria-expanded={this.open ? \"true\" : \"false\"}\n aria-owns={menuId}\n aria-controls={menuId}\n disabled={disabled}\n onBlur={this.onBlur}\n onFocus={this.onFocus}\n onClick={this.handleClick}\n onMouseDown={this.handleMouseDown}\n onKeyDown={this.handleKeyDown}\n >\n <ic-typography\n variant=\"body\"\n class={{\n \"value-text\": true,\n placeholder:\n this.getLabelFromValue(currValue) === undefined,\n }}\n >\n <p>{this.getLabelFromValue(currValue) || placeholder}</p>\n </ic-typography>\n <div class=\"select-input-end\">\n {currValue && showClearButton && (\n <div class=\"divider\"></div>\n )}\n <span\n class={{\n \"expand-icon\": true,\n \"expand-icon-open\": this.open,\n \"expand-icon-filled\": !(\n currValue == null || currValue === \"\"\n ),\n }}\n innerHTML={Expand}\n aria-hidden=\"true\"\n />\n </div>\n </button>\n {currValue && showClearButton && (\n <ic-button\n id=\"clear-button\"\n aria-label=\"Clear selection\"\n class=\"clear-button\"\n innerHTML={Clear}\n onClick={this.handleClear}\n onFocus={this.handleClearButtonFocus}\n onBlur={this.handleClearButtonBlur}\n size={small ? \"small\" : \"default\"}\n variant=\"icon\"\n appearance={\n this.clearButtonFocused\n ? IcThemeForegroundEnum.Light\n : IcThemeForegroundEnum.Dark\n }\n ></ic-button>\n )}\n </div>\n )}\n </ic-input-component-container>\n {!isMobileOrTablet() && (\n <ic-menu\n class={{\n \"no-results\": noOptionSelect,\n }}\n ref={(el) => (this.menu = el)}\n inputEl={\n searchable\n ? this.searchableSelectElement\n : this.customSelectElement\n }\n inputLabel={label}\n anchorEl={this.anchorEl}\n small={small}\n menuId={menuId}\n open={this.open}\n options={searchable ? this.filteredOptions : options}\n value={currValue}\n fullWidth={fullWidth}\n onMenuStateChange={this.handleMenuChange}\n onMenuOptionSelect={this.handleCustomSelectChange}\n onMenuKeyPress={this.handleMenuKeyPress}\n onMenuValueChange={this.handleMenuValueChange}\n onUngroupedOptionsSet={this.setUngroupedOptions}\n onRetryButtonClicked={this.handleRetry}\n parentEl={this.host}\n onTimeoutBlur={this.onTimeoutBlur}\n activationType={this.searchable ? \"manual\" : \"automatic\"}\n ></ic-menu>\n )}\n {hasValidationStatus(this.validationStatus, this.disabled) && (\n <ic-input-validation\n class={{ \"menu-open\": this.open }}\n ariaLiveMode=\"polite\"\n status={validationStatus}\n message={validationText}\n for={this.inputId}\n ></ic-input-validation>\n )}\n </ic-input-container>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["ToastRegion","constructor","hostRef","this","pendingVisibility","handleDismissedToast","length","setVisible","then","res","previouslyFocused","shift","setFocus","_a","focus","async","toast","visibleToasts","Array","from","document","querySelectorAll","filter","el","window","getComputedStyle","display","indexOf","push","render","h"],"sources":["./src/components/ic-toast-region/ic-toast-region.tsx"],"sourcesContent":["import { Component, Element, h, Listen, Method } from \"@stencil/core\";\nimport { IcFocusableComponents } from \"../../utils/types\";\n\n@Component({ tag: \"ic-toast-region\" })\nexport class ToastRegion {\n private pendingVisibility: HTMLIcToastElement[] = [];\n private previouslyFocused: HTMLElement;\n\n @Element() el: HTMLIcToastRegionElement;\n\n @Listen(\"icDismiss\", { capture: true })\n handleDismissedToast(): void {\n if (this.pendingVisibility.length > 0) {\n this.pendingVisibility[0]\n .setVisible()\n .then((res) => (this.previouslyFocused = res));\n this.pendingVisibility.shift();\n } else {\n if (this.previouslyFocused && \"setFocus\" in this.previouslyFocused) {\n (this.previouslyFocused as IcFocusableComponents).setFocus();\n } else this.previouslyFocused?.focus();\n }\n }\n\n /**\n * Handles setting the visibility of various toasts based on what is already visible\n * @param toast The toast element being requested to display\n */\n @Method()\n async setVisible(toast: HTMLIcToastElement): Promise<void> {\n const visibleToasts = Array.from(\n document.querySelectorAll(\"ic-toast\")\n ).filter((el) => window.getComputedStyle(el).display !== \"none\");\n if (visibleToasts.indexOf(toast) === -1 && visibleToasts.length <= 0) {\n toast.setVisible().then((res) => (this.previouslyFocused = res));\n }\n if (visibleToasts.length > 0) this.pendingVisibility.push(toast);\n }\n\n render() {\n return <slot></slot>;\n }\n}\n"],"mappings":"wDAIaA,EAAW,MADxBC,YAAAC,G,UAEUC,KAAAC,kBAA0C,E,CAMlDC,uB,MACE,GAAIF,KAAKC,kBAAkBE,OAAS,EAAG,CACrCH,KAAKC,kBAAkB,GACpBG,aACAC,MAAMC,GAASN,KAAKO,kBAAoBD,IAC3CN,KAAKC,kBAAkBO,O,KAClB,CACL,GAAIR,KAAKO,mBAAqB,aAAcP,KAAKO,kBAAmB,CACjEP,KAAKO,kBAA4CE,U,MAC7CC,EAAAV,KAAKO,qBAAiB,MAAAG,SAAA,SAAAA,EAAEC,O,EASnCC,iBAAiBC,GACf,MAAMC,EAAgBC,MAAMC,KAC1BC,SAASC,iBAAiB,aAC1BC,QAAQC,GAAOC,OAAOC,iBAAiBF,GAAIG,UAAY,SACzD,GAAIT,EAAcU,QAAQX,MAAY,GAAKC,EAAcX,QAAU,EAAG,CACpEU,EAAMT,aAAaC,MAAMC,GAASN,KAAKO,kBAAoBD,G,CAE7D,GAAIQ,EAAcX,OAAS,EAAGH,KAAKC,kBAAkBwB,KAAKZ,E,CAG5Da,SACE,OAAOC,EAAA,Y"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["IcInformationStatus","IcThemeForegroundEnum"],"sources":["./src/utils/types.ts"],"sourcesContent":["export type IcFocusableComponents =\n | HTMLIcBreadcrumbElement\n | HTMLIcButtonElement\n | HTMLIcCardElement\n | HTMLIcCheckboxElement\n | HTMLIcChipElement\n | HTMLIcLinkElement\n | HTMLIcNavigationButtonElement\n | HTMLIcNavigationGroupElement\n | HTMLIcNavigationItemElement\n | HTMLIcRadioOptionElement\n | HTMLIcSearchBarElement\n | HTMLIcSelectElement\n | HTMLIcSwitchElement\n | HTMLIcTabElement\n | HTMLIcTextFieldElement;\n\nexport type IcStatusVariants =\n | \"neutral\"\n | \"info\"\n | \"warning\"\n | \"error\"\n | \"success\";\n\nexport enum IcInformationStatus {\n Warning = \"warning\",\n Error = \"error\",\n Success = \"success\",\n}\n\nexport type IcInformationStatusOrEmpty = \"warning\" | \"error\" | \"success\" | \"\";\n\nexport type IcNavType = \"side\" | \"top\" | \"page-header\";\n\n// From: https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete\nexport type IcAutocompleteTypes =\n | \"on\"\n | \"off\"\n | \"name\"\n | \"honorific-prefix\"\n | \"given-name\"\n | \"additional-name\"\n | \"family-name\"\n | \"honorific-suffix\"\n | \"nickname\"\n | \"email\"\n | \"username\"\n | \"new-password\"\n | \"current-password\"\n | \"one-time-code\"\n | \"organization-title\"\n | \"organization\"\n | \"street-address\"\n | \"address-line1\"\n | \"address-line2\"\n | \"address-line3\"\n | \"address-level4\"\n | \"address-level3\"\n | \"address-level2\"\n | \"address-level1\"\n | \"country\"\n | \"country-name\"\n | \"postal-code\"\n | \"cc-name\"\n | \"cc-given-name\"\n | \"cc-additional-name\"\n | \"cc-family-name\"\n | \"cc-family-name\"\n | \"cc-number\"\n | \"cc-exp\"\n | \"cc-exp-month\"\n | \"cc-exp-year\"\n | \"cc-csc\"\n | \"cc-type\"\n | \"transaction-currency\"\n | \"transaction-amount\"\n | \"language\"\n | \"bday\"\n | \"bday-day\"\n | \"bday-month\"\n | \"bday-year\"\n | \"sex\"\n | \"tel\"\n | \"tel-country-code\"\n | \"tel-national\"\n | \"tel-area-code\"\n | \"tel-local\"\n | \"tel-extension\"\n | \"impp\"\n | \"url\"\n | \"photo\";\n\nexport type IcAlignment = \"left\" | \"center\" | \"full-width\";\n\nexport enum IcThemeForegroundEnum {\n Default = \"default\",\n Dark = \"dark\",\n Light = \"light\",\n}\n\nexport type IcThemeForeground = \"default\" | \"dark\" | \"light\";\n\nexport type IcThemeForegroundNoDefault = \"dark\" | \"light\";\n\nexport type IcTheme = {\n mode: IcThemeForeground;\n color: IcColorRGB;\n};\n\nexport type IcAdditionalFieldTypes = \"static\" | \"dynamic\";\n\nexport type IcColorRGB = {\n r: number;\n g: number;\n b: number;\n};\n\nexport type IcColorRGBA = IcColorRGB & {\n a: number;\n};\n\nexport type IcActivationTypes = \"automatic\" | \"manual\";\n\nexport type IcAutocorrectStates = \"on\" | \"off\";\n\nexport type IcNavParentDetails = {\n navType: IcNavType | \"\";\n parent: HTMLElement;\n};\n\nexport type IcTypographyVariants =\n | \"h1\"\n | \"h2\"\n | \"h3\"\n | \"h4\"\n | \"subtitle-large\"\n | \"subtitle-small\"\n | \"body\"\n | \"label\"\n | \"label-uppercase\"\n | \"caption\"\n | \"caption-uppercase\"\n | \"code-large\"\n | \"code-small\"\n | \"code-extra-small\";\n\nexport interface IcMenuOption {\n value?: string;\n label: string;\n description?: string;\n disabled?: boolean;\n recommended?: boolean;\n children?: IcMenuOption[];\n loading?: boolean;\n timedOut?: boolean;\n}\n\nexport type IcSearchMatchPositions = \"start\" | \"anywhere\";\n\nexport type IcCallbackFunctionNoReturn = (...args: unknown[]) => void;\n\nexport type IcRequiredPropsTypes =\n | string\n | boolean\n | number\n | HTMLElement\n | IcMenuOption[];\n\nexport type IcPropObject = { prop: IcRequiredPropsTypes; propName: string };\n\nexport type IcRelatedTarget = EventTarget | undefined;\n\nexport type IcOrientation = \"horizontal\" | \"vertical\";\n\nexport type IcSizes = \"default\" | \"large\" | \"small\";\n\nexport interface IcValueEventDetail {\n value: string;\n keyPressed?: string;\n}\nexport interface IcBlurEventDetail {\n relatedTarget: IcRelatedTarget;\n}\n"],"mappings":"IAwBYA,GAAZ,SAAYA,GACVA,EAAA,qBACAA,EAAA,iBACAA,EAAA,oBACD,EAJD,CAAYA,MAAmB,K,IAsEnBC,GAAZ,SAAYA,GACVA,EAAA,qBACAA,EAAA,eACAA,EAAA,gBACD,EAJD,CAAYA,MAAqB,Y"}
@@ -1,2 +0,0 @@
1
- import{r as t,c as i,h as s,H as e,g as a}from"./p-69920d86.js";import{I as h}from"./p-6f57b13c.js";import{w as n,x as o,y as r,r as l,a as c,j as u,f as d}from"./p-dd980be4.js";const f=`<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg">\n <path d="M15.8327 5.34199L14.6577 4.16699L9.99935 8.82533L5.34102 4.16699L4.16602 5.34199L8.82435 10.0003L4.16602 14.6587L5.34102 15.8337L9.99935 11.1753L14.6577 15.8337L15.8327 14.6587L11.1743 10.0003L15.8327 5.34199Z" fill="currentColor"/>\n</svg>\n`;const b=`<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg" aria-hidden="true">\n <path d="M13.1292 11.8792H12.4708L12.2375 11.6542C13.0542 10.7042 13.5458 9.47083 13.5458 8.12916C13.5458 5.13749 11.1208 2.71249 8.12916 2.71249C5.13749 2.71249 2.71249 5.13749 2.71249 8.12916C2.71249 11.1208 5.13749 13.5458 8.12916 13.5458C9.47083 13.5458 10.7042 13.0542 11.6542 12.2375L11.8792 12.4708V13.1292L16.0458 17.2875L17.2875 16.0458L13.1292 11.8792ZM8.12916 11.8792C6.05416 11.8792 4.37916 10.2042 4.37916 8.12916C4.37916 6.05416 6.05416 4.37916 8.12916 4.37916C10.2042 4.37916 11.8792 6.05416 11.8792 8.12916C11.8792 10.2042 10.2042 11.8792 8.12916 11.8792Z" fill="currentColor"/>\n</svg>`;const p='/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0;}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px;}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font-style:inherit;vertical-align:baseline}:host(.search){--divider-height:1.5rem}:host(.search.small){--divider-height:1rem}:host(.fullwidth){width:100%}:host(.search) .disabled:hover{border-color:var(--ic-architectural-200)}:host(.search.disabled) .disabled svg{color:var(--ic-architectural-200)}:host(.search) .disabled svg{color:var(--ic-architectural-400)}.clear-button-container{align-items:center;margin-right:var(--ic-space-1px);display:none;visibility:hidden}.clear-button{border-radius:var(--ic-border-radius);transition:box-shadow var(--ic-easing-transition),\n border-radius var(--ic-easing-transition)}.clear-button:focus,.clear-button:active{background-color:var(--ic-focus-blue);box-shadow:inset 0 0 0 0.125rem var(--ic-focus-glow);border-radius:0.25rem}.clear-button:focus,.clear-button:active *{fill:white}.clear-button-visible{visibility:visible;display:flex}.search-submit-button-container{display:flex;align-items:center}.search-submit-button-disabled .ic-tooltip-container{display:none !important}.search-submit-button:focus,.search-submit-button:active{background-color:var(--ic-focus-blue) !important;box-shadow:inset 0 0 0 0.125rem var(--ic-focus-glow) !important;border-radius:var(--ic-space-xxs)}.search-submit-button:focus,.search-submit-button:active *{fill:white}.divider{width:var(--ic-space-1px);background-color:var(--ic-action-dark-active);height:var(--divider-height)}:host(.dark) .divider{background-color:var(--ic-architectural-200)}.menu-container{width:var(--input-width, 20rem);position:relative;top:var(--ic-space-xxxs)}.menu-container.fullwidth{width:100%}.no-results{cursor:not-allowed}.search-results-status{border:0;clip:rect(0, 0, 0, 0, 0);height:var(--ic-space-1px);margin-bottom:calc(-1 * var(--ic-space-1px));margin-right:calc(-1 * var(--ic-space-1px));overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:var(--ic-space-1px)}';let m=0;const v=class{constructor(s){t(this,s);this.icChange=i(this,"icChange",7);this.icClear=i(this,"icClear",7);this.icInput=i(this,"icInput",7);this.icInputBlur=i(this,"icInputBlur",7);this.icInputFocus=i(this,"icInputFocus",7);this.icOptionSelect=i(this,"icOptionSelect",7);this.icMenuChange=i(this,"icMenuChange",7);this.icClearBlur=i(this,"icClearBlur",7);this.icRetryLoad=i(this,"icRetryLoad",7);this.icSubmitSearch=i(this,"icSubmitSearch",7);this.icSubmitSearchBlur=i(this,"icSubmitSearchBlur",7);this.icSearchBarBlur=i(this,"icSearchBarBlur",7);this.icSearchBarFocus=i(this,"icSearchBarFocus",7);this.assistiveHintEl=null;this.hasTimedOut=false;this.inputId=`ic-search-bar-input-${m++}`;this.menuCloseFromMenuChangeEvent=false;this.menuId=`${this.inputId}-menu`;this.preLoad=true;this.preventSubmit=false;this.prevNoOption=false;this.retryButtonClick=false;this.truncateValue=false;this.handleClear=t=>{const i=t;const s=t;if(s.type==="click"||i.code==="Enter"||i.code==="Space"){this.value="";this.inputEl.value="";this.loading=false;clearTimeout(this.timeoutTimer);this.filteredOptions=this.options;this.el.setFocus();this.icClear.emit();t.preventDefault();this.preventSubmit=true}};this.onInput=t=>{this.value=t.target.value;const i=[{label:this.emptyOptionListText,value:""}];if(this.options.length>0){this.setMenuChange(true);this.preLoad=false;if(this.disableFilter===false){const t=n(this.options,false,this.value,"anywhere");this.filteredOptions=t.length>0?t:i}}if(!this.showClearButton){this.handleShowClearButton(true)}this.debounceAriaLiveUpdate()};this.onInputBlur=t=>{const i=t.target.value;const s=t.relatedTarget;this.icInputBlur.emit({value:i,relatedTarget:s})};this.onInputFocus=t=>{const i=t.target.value;this.icInputFocus.emit({value:i});this.handleShowClearButton(true)};this.handleClearBlur=t=>{const i=t.relatedTarget;this.icClearBlur.emit({relatedTarget:i});this.clearButtonFocused=false};this.handleSubmitSearchBlur=t=>{const i=t.relatedTarget;this.icSubmitSearchBlur.emit({relatedTarget:i});this.searchSubmitFocused=false};this.handleMouseDown=t=>{t.preventDefault()};this.handleSubmitSearchFocus=()=>{this.searchSubmitFocused=true};this.handleSubmitSearch=()=>{this.highlightedValue&&(this.value=this.highlightedValue);this.highlightedValue=undefined;this.icSubmitSearch.emit({value:this.value});const t=this.el.closest("FORM");if(this.searchSubmitButton&&!!t&&!this.preventSubmit){o(t,this.searchSubmitButton)}};this.handleSubmitSearchKeyDown=t=>{if(t.key===" "){t.preventDefault();this.handleSubmitSearch()}};this.handleRetry=t=>{this.retryViaKeyPress=t.detail.keyPressed==="Enter";this.icRetryLoad.emit({value:t.detail.value});this.triggerLoading();this.retryButtonClick=true};this.triggerLoading=()=>{const t=[{label:this.loadingLabel,value:"",loading:true}];if(this.filteredOptions!==t)this.filteredOptions=t;if(this.timeout){this.timeoutTimer=window.setTimeout((()=>{this.filteredOptions=[{label:this.loadingErrorLabel,value:"",timedOut:true}]}),this.timeout)}};this.handleOptionSelect=t=>{if(t.detail.label===this.emptyOptionListText){this.el.setFocus();return}this.value=t.detail.value;this.icOptionSelect.emit({value:this.value})};this.handleMenuOptionHighlight=t=>{var i;const s=(i=t.detail.optionId)===null||i===void 0?void 0:i.replace(`${this.menuId}-`,"");s&&(this.highlightedValue=s);if(t.detail.optionId){this.ariaActiveDescendant=t.detail.optionId}else{this.ariaActiveDescendant=undefined}};this.handleMenuChange=t=>{this.setMenuChange(t.detail.open);if(!t.detail.open){this.handleMenuCloseFromMenuChange(true);if(t.detail.focusInput===undefined||t.detail.focusInput){this.el.setFocus()}}};this.setMenuChange=t=>{if(this.open!==t){this.open=t;this.icMenuChange.emit({open:t})}};this.handleHostFocus=()=>{if(this.options&&this.value&&!this.menuCloseFromMenuChangeEvent){this.setMenuChange(true)}this.handleTruncateValue(false);this.icSearchBarFocus.emit()};this.handleHostBlur=t=>{const i=t.relatedTarget;if(this.open&&this.options&&i!==this.menu&&!this.retryViaKeyPress&&!this.retryButtonClick){this.setMenuChange(false)}if(this.retryButtonClick||this.retryViaKeyPress){this.inputEl.setFocus()}this.handleShowClearButton(false);this.handleMenuCloseFromMenuChange(false);this.handleTruncateValue(true);this.icSearchBarBlur.emit({relatedTarget:i,value:this.value});this.retryViaKeyPress=false;this.retryButtonClick=false};this.handleShowClearButton=t=>{this.showClearButton=t};this.handleFocusClearButton=()=>{this.clearButtonFocused=true};this.handleMenuCloseFromMenuChange=t=>{this.menuCloseFromMenuChangeEvent=t};this.handleTruncateValue=t=>{this.truncateValue=t};this.renderAssistiveHintEl=()=>{var t,i;const s=(i=(t=this.el.shadowRoot.querySelector("ic-text-field"))===null||t===void 0?void 0:t.shadowRoot)===null||i===void 0?void 0:i.querySelector(`#${this.inputId}`);if(s&&Object.keys(s).length>0&&this.hasOptionsOrFilterDisabled()){this.assistiveHintEl=document.createElement("span");this.assistiveHintEl.innerText=this.hintText;this.assistiveHintEl.id=`${this.inputId}-assistive-hint`;this.assistiveHintEl.style.display="none";if(s.after!==undefined){s.after(this.assistiveHintEl)}}};this.updateSearchResultAriaLive=()=>{const t=this.el.shadowRoot.querySelector(".search-results-status");if(!this.open||this.value===""||this.value.length<this.charactersUntilSuggestion){t.innerText=""}else if(this.hasOptionsOrFilterDisabled()&&this.filteredOptions.length>0&&this.open&&t&&!this.filteredOptions[0].loading){if(this.hadNoOptions()){t.innerText=this.emptyOptionListText}else{t.innerText=`${this.filteredOptions.length} result${this.filteredOptions.length>1?"s":""} available`}}};this.hasOptionsOrFilterDisabled=()=>this.options.length>0||this.disableFilter;this.hadNoOptions=()=>this.filteredOptions.length===1&&this.filteredOptions[0].label===this.emptyOptionListText&&this.searchMode==="navigation";this.isSubmitDisabled=()=>{const t=this.value===undefined||this.value===null||this.value==="";const i=this.value.length<this.charactersUntilSuggestion;return t||i||this.disabled||this.hadNoOptions()||this.hasTimedOut||this.loading};this.highlightFirstOptionAfterNoResults=()=>{if(this.prevNoOption&&this.menu&&!this.hasTimedOut){this.menu.handleSetFirstOption();this.prevNoOption=false}const t=this.filteredOptions.find((t=>t.label===this.emptyOptionListText||t.label===this.loadingErrorLabel||t.label===this.loadingLabel));if(t){this.prevNoOption=true}};this.ariaActiveDescendant=undefined;this.clearButtonFocused=false;this.highlightedValue=undefined;this.open=false;this.searchSubmitFocused=false;this.showClearButton=false;this.autocapitalize="off";this.autocomplete="off";this.autocorrect="off";this.autofocus=false;this.charactersUntilSuggestion=2;this.disabled=false;this.disableFilter=false;this.debounce=0;this.emptyOptionListText="No results found";this.focusOnLoad=false;this.fullWidth=false;this.helperText="";this.hideLabel=false;this.hintText="When autocomplete results are available use the up and down arrows to choose and press enter to select";this.label=undefined;this.loading=false;this.loadingErrorLabel="Loading Error";this.loadingLabel="Loading...";this.name=this.inputId;this.placeholder="Search";this.readonly=false;this.required=false;this.searchMode="navigation";this.small=false;this.spellcheck=false;this.timeout=undefined;this.filteredOptions=[];this.options=[];this.value=""}loadingHandler(t){if(t&&!this.hasTimedOut){this.preLoad=false;this.triggerLoading()}}filteredOptionsHandler(t){this.hasTimedOut=t.some((t=>t.timedOut))}watchOptionsHandler(t){if(this.disableFilter&&!this.hasTimedOut){this.loading=false;clearTimeout(this.timeoutTimer);if(t.length>0){this.filteredOptions=t}else{if(this.hadNoOptions()){return}this.setMenuChange(true);!this.preLoad&&(this.filteredOptions=[{label:this.emptyOptionListText,value:""}]);this.preLoad=true}}this.debounceAriaLiveUpdate()}watchValueHandler(t){if(this.inputEl&&this.options&&!!r(t,this.options)){this.inputEl.value=r(t,this.options)}else if(this.inputEl&&this.inputEl.value!==t){this.inputEl.value=t}}disconnectedCallback(){if(this.assistiveHintEl){this.assistiveHintEl.remove()}}componentWillLoad(){this.watchValueHandler(this.value);l(this.disabled,this.el)}componentDidLoad(){if(this.focusOnLoad){this.el.setFocus()}if(this.hasOptionsOrFilterDisabled()){this.renderAssistiveHintEl();if(this.disableFilter){this.filteredOptions=this.options}}c([{prop:this.label,propName:"label"}],"Search Bar");if(this.inputEl!==undefined){this.anchorEl=this.inputEl.shadowRoot.querySelector("ic-input-component-container")}}componentWillRender(){this.highlightFirstOptionAfterNoResults()}handleKeyDown(t){const i=t.detail.event;if(this.menu&&this.open){this.menu.handleKeyboardOpen(i)}}handleKeyUp(t){if(t.key==="Enter"){if(this.preventSubmit||this.isSubmitDisabled()){return}this.handleSubmitSearch();this.setMenuChange(false)}if(t.key==="Escape"){this.setMenuChange(false)}if(this.preventSubmit){this.preventSubmit=false}}async setFocus(){this.retryViaKeyPress=false;this.retryButtonClick=false;if(this.inputEl){this.inputEl.setFocus()}}debounceAriaLiveUpdate(){clearTimeout(this.debounceAriaLive);this.debounceAriaLive=window.setTimeout((()=>{this.updateSearchResultAriaLive()}),500)}render(){const{inputId:t,name:i,label:a,required:n,small:o,placeholder:l,helperText:c,disabled:p,value:m,readonly:v,spellcheck:g,fullWidth:w,options:y,open:x,hideLabel:k,menuId:L,ariaActiveDescendant:z,truncateValue:C,autofocus:B,autocapitalize:M,autocomplete:S,filteredOptions:T}=this;const O=v||p?true:false;const H=u(t,c!=="",false).trim();let F;if(H!==""&&this.hasOptionsOrFilterDisabled()){F=`${H} ${this.inputId}-assistive-hint`}else if(this.hasOptionsOrFilterDisabled()){F=`${this.inputId}-assistive-hint`}else if(H!==""){F=H}else{F=undefined}const I=O&&!v;const $=m&&this.hasOptionsOrFilterDisabled();const E=$&&x&&T.length>0;const D=E&&m.length>=this.charactersUntilSuggestion;const j=this.filteredOptions.length===1&&(this.filteredOptions[0].label===this.loadingLabel||T[0].label===this.loadingErrorLabel);let W;if(y.length>0){if(E){W="true"}else{W="false"}}else{W=undefined}d(true,this.el,i,m,O);return s(e,{class:{["search"]:true,["fullwidth"]:w,["disabled"]:p,["small"]:o},onFocus:this.handleHostFocus,onBlur:this.handleHostBlur},s("ic-text-field",{ref:t=>this.inputEl=t,inputId:t,label:a,helperText:c,required:n,disabled:I,readonly:v,small:o,hideLabel:k,fullWidth:w,name:i,truncateValue:C,value:y&&!!r(m,y)?r(m,y):m,placeholder:l,onInput:this.onInput,onBlur:this.onInputBlur,onFocus:this.onInputFocus,"aria-label":k?a:"","aria-describedby":F,"aria-owns":D?L:undefined,"aria-haspopup":y.length>0?"listbox":undefined,ariaExpanded:W,ariaActiveDescendant:z,"aria-autocomplete":$?"list":undefined,role:$?"combobox":undefined,autocomplete:S,autocapitalize:M,autoFocus:B,spellcheck:g,inputmode:"search",debounce:this.debounce},s("div",{class:{"clear-button-container":true,"clear-button-visible":m&&!O&&this.showClearButton},slot:"clear-button"},s("ic-button",{id:"clear-button",class:"clear-button","aria-label":"Clear",innerHTML:f,onClick:this.handleClear,onMouseDown:this.handleMouseDown,size:o?"small":"default",onFocus:this.handleFocusClearButton,onBlur:this.handleClearBlur,onKeyDown:this.handleClear,type:"submit",variant:"icon",appearance:this.clearButtonFocused?h.Light:h.Dark}),s("div",{class:"divider"})),s("div",{class:{"search-submit-button-container":true,"search-submit-button-disabled":this.isSubmitDisabled()},slot:"search-submit-button"},s("ic-button",{id:"search-submit-button","aria-label":"Search",ref:t=>this.searchSubmitButton=t,class:{["search-submit-button"]:true,["search-submit-button-small"]:!!o},disabled:this.isSubmitDisabled(),innerHTML:b,size:o?"small":"default",onClick:this.handleSubmitSearch,onMouseDown:this.handleMouseDown,onBlur:this.handleSubmitSearchBlur,onFocus:this.handleSubmitSearchFocus,onKeyDown:this.handleSubmitSearchKeyDown,type:"submit",variant:"icon",appearance:this.searchSubmitFocused?h.Light:h.Default})),s("div",{class:{"menu-container":true,fullwidth:w},slot:"menu"},D&&s("ic-menu",{class:{"no-results":this.hadNoOptions()||j},activationType:"manual",anchorEl:this.anchorEl,autoFocusOnSelected:false,searchMode:this.searchMode,inputEl:this.inputEl,inputLabel:a,ref:t=>this.menu=t,small:o,fullWidth:w,menuId:L,open:true,options:T,onMenuOptionSelect:this.handleOptionSelect,onMenuStateChange:this.handleMenuChange,onMenuOptionId:this.handleMenuOptionHighlight,onRetryButtonClicked:this.handleRetry,parentEl:this.el,value:m}))),s("div",{"aria-live":"polite",role:"status",class:"search-results-status"}))}static get delegatesFocus(){return true}get el(){return a(this)}static get watchers(){return{loading:["loadingHandler"],filteredOptions:["filteredOptionsHandler"],options:["watchOptionsHandler"],value:["watchValueHandler"]}}};v.style=p;export{v as ic_search_bar};
2
- //# sourceMappingURL=p-736489c6.entry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["icSearchBarCss","inputIds","SearchBar","this","assistiveHintEl","hasTimedOut","inputId","menuCloseFromMenuChangeEvent","menuId","preLoad","preventSubmit","prevNoOption","retryButtonClick","truncateValue","handleClear","ev","keyboardEvent","mouseEvent","type","code","value","inputEl","loading","clearTimeout","timeoutTimer","filteredOptions","options","el","setFocus","icClear","emit","preventDefault","onInput","target","noOptions","label","emptyOptionListText","length","setMenuChange","disableFilter","rawFilteredOptions","getFilteredMenuOptions","showClearButton","handleShowClearButton","debounceAriaLiveUpdate","onInputBlur","nextFocus","relatedTarget","icInputBlur","onInputFocus","icInputFocus","handleClearBlur","icClearBlur","clearButtonFocused","handleSubmitSearchBlur","icSubmitSearchBlur","searchSubmitFocused","handleMouseDown","handleSubmitSearchFocus","handleSubmitSearch","highlightedValue","undefined","icSubmitSearch","form","closest","searchSubmitButton","handleHiddenFormButtonClick","handleSubmitSearchKeyDown","key","handleRetry","retryViaKeyPress","detail","keyPressed","icRetryLoad","triggerLoading","loadingOption","loadingLabel","timeout","window","setTimeout","loadingErrorLabel","timedOut","handleOptionSelect","icOptionSelect","handleMenuOptionHighlight","optionValue","_a","optionId","replace","ariaActiveDescendant","handleMenuChange","open","handleMenuCloseFromMenuChange","focusInput","icMenuChange","handleHostFocus","handleTruncateValue","icSearchBarFocus","handleHostBlur","menu","icSearchBarBlur","visible","handleFocusClearButton","fromEvent","truncate","renderAssistiveHintEl","input","_b","shadowRoot","querySelector","Object","keys","hasOptionsOrFilterDisabled","document","createElement","innerText","hintText","id","style","display","after","updateSearchResultAriaLive","searchResultsStatusEl","charactersUntilSuggestion","hadNoOptions","searchMode","isSubmitDisabled","valueNotSet","valueLengthLess","disabled","highlightFirstOptionAfterNoResults","handleSetFirstOption","prevNoOptionsList","find","filteredOption","loadingHandler","newValue","filteredOptionsHandler","newOptions","some","opt","watchOptionsHandler","watchValueHandler","getLabelFromValue","disconnectedCallback","remove","componentWillLoad","removeDisabledFalse","componentDidLoad","focusOnLoad","onComponentRequiredPropUndefined","prop","propName","anchorEl","componentWillRender","handleKeyDown","keyEv","event","handleKeyboardOpen","handleKeyUp","async","debounceAriaLive","render","name","required","small","placeholder","helperText","readonly","spellcheck","fullWidth","hideLabel","autofocus","autocapitalize","autocomplete","disabledMode","describedBy","getInputDescribedByText","trim","describedById","disabledText","hasSuggestedSearch","menuOpen","menuRendered","isOrHasLoaded","expanded","renderHiddenInput","h","Host","class","onFocus","onBlur","ref","ariaExpanded","role","autoFocus","inputmode","debounce","slot","innerHTML","clearIcon","onClick","onMouseDown","size","onKeyDown","variant","appearance","IcThemeForegroundEnum","Light","Dark","searchIcon","Default","fullwidth","activationType","autoFocusOnSelected","inputLabel","onMenuOptionSelect","onMenuStateChange","onMenuOptionId","onRetryButtonClicked","parentEl"],"sources":["./src/components/ic-search-bar/ic-search-bar.css?tag=ic-search-bar&encapsulation=shadow","./src/components/ic-search-bar/ic-search-bar.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n/**\n * @prop --ic-z-index-menu: z-index of search bar menu\n */\n\n:host(.search) {\n --divider-height: 1.5rem;\n}\n\n:host(.search.small) {\n --divider-height: 1rem;\n}\n\n:host(.fullwidth) {\n width: 100%;\n}\n\n:host(.search) .disabled:hover {\n border-color: var(--ic-architectural-200);\n}\n\n:host(.search.disabled) .disabled svg {\n color: var(--ic-architectural-200);\n}\n\n:host(.search) .disabled svg {\n color: var(--ic-architectural-400);\n}\n\n/* CLEAR */\n\n.clear-button-container {\n align-items: center;\n margin-right: var(--ic-space-1px);\n display: none;\n visibility: hidden;\n}\n\n.clear-button {\n border-radius: var(--ic-border-radius);\n transition: box-shadow var(--ic-easing-transition),\n border-radius var(--ic-easing-transition);\n}\n\n.clear-button:focus,\n.clear-button:active {\n background-color: var(--ic-focus-blue);\n box-shadow: inset 0 0 0 0.125rem var(--ic-focus-glow);\n border-radius: 0.25rem;\n}\n\n.clear-button:focus,\n.clear-button:active * {\n fill: white;\n}\n\n.clear-button-visible {\n visibility: visible;\n display: flex;\n}\n\n.search-submit-button-container {\n display: flex;\n align-items: center;\n}\n\n.search-submit-button-disabled .ic-tooltip-container {\n display: none !important;\n}\n\n.search-submit-button:focus,\n.search-submit-button:active {\n background-color: var(--ic-focus-blue) !important;\n box-shadow: inset 0 0 0 0.125rem var(--ic-focus-glow) !important;\n border-radius: var(--ic-space-xxs);\n}\n\n.search-submit-button:focus,\n.search-submit-button:active * {\n fill: white;\n}\n\n.divider {\n width: var(--ic-space-1px);\n background-color: var(--ic-action-dark-active);\n height: var(--divider-height);\n}\n\n:host(.dark) .divider {\n background-color: var(--ic-architectural-200);\n}\n\n.menu-container {\n width: var(--input-width, 20rem);\n position: relative;\n top: var(--ic-space-xxxs);\n}\n\n.menu-container.fullwidth {\n width: 100%;\n}\n\n.no-results {\n cursor: not-allowed;\n}\n\n.search-results-status {\n border: 0;\n clip: rect(0, 0, 0, 0, 0);\n height: var(--ic-space-1px);\n margin-bottom: calc(-1 * var(--ic-space-1px));\n margin-right: calc(-1 * var(--ic-space-1px));\n overflow: hidden;\n padding: 0;\n position: absolute;\n white-space: nowrap;\n width: var(--ic-space-1px);\n}\n","import {\n Component,\n Element,\n Event,\n EventEmitter,\n Host,\n Listen,\n Prop,\n State,\n Watch,\n Method,\n h,\n} from \"@stencil/core\";\n\nimport {\n IcAutocompleteTypes,\n IcAutocorrectStates,\n IcThemeForegroundEnum,\n IcMenuOption,\n} from \"../../utils/types\";\nimport {\n getInputDescribedByText,\n renderHiddenInput,\n handleHiddenFormButtonClick,\n getLabelFromValue,\n onComponentRequiredPropUndefined,\n getFilteredMenuOptions,\n removeDisabledFalse,\n} from \"../../utils/helpers\";\nimport {\n IcSearchBarBlurEventDetail,\n IcSearchBarSearchModes,\n} from \"./ic-search-bar.types\";\nimport { IcValueEventDetail, IcBlurEventDetail } from \"../../utils/types\";\nimport {\n IcMenuChangeEventDetail,\n IcOptionSelectEventDetail,\n} from \"../ic-menu/ic-menu.types\";\n\nimport clearIcon from \"../../assets/clear-icon.svg\";\nimport searchIcon from \"../../assets/search-icon.svg\";\n\nlet inputIds = 0;\n\n@Component({\n tag: \"ic-search-bar\",\n styleUrl: \"ic-search-bar.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport class SearchBar {\n private anchorEl: HTMLElement;\n private assistiveHintEl: HTMLSpanElement = null;\n private debounceAriaLive: number;\n private hasTimedOut = false;\n private inputEl: HTMLIcTextFieldElement;\n private inputId = `ic-search-bar-input-${inputIds++}`;\n private menu: HTMLIcMenuElement;\n private menuCloseFromMenuChangeEvent: boolean = false;\n private menuId = `${this.inputId}-menu`;\n private preLoad = true;\n private preventSubmit: boolean = false;\n private prevNoOption: boolean = false;\n private retryButtonClick: boolean = false;\n private retryViaKeyPress: boolean;\n private timeoutTimer: number;\n private truncateValue = false;\n private searchSubmitButton: HTMLIcButtonElement;\n\n @Element() el: HTMLIcSearchBarElement;\n\n @State() ariaActiveDescendant: string;\n @State() clearButtonFocused: boolean = false;\n @State() highlightedValue: string;\n @State() open: boolean = false;\n @State() searchSubmitFocused: boolean = false;\n @State() showClearButton: boolean = false;\n\n /**\n * The automatic capitalisation of the text value as it is entered/edited by the user.\n * Available options: \"off\", \"none\", \"on\", \"sentences\", \"words\", \"characters\".\n */\n @Prop() autocapitalize = \"off\";\n\n /**\n * The state of autocompletion the browser can apply on the text value.\n */\n @Prop() autocomplete?: IcAutocompleteTypes = \"off\";\n\n /**\n * The state of autocorrection the browser can apply when the user is entering/editing the text value.\n */\n @Prop() autocorrect?: IcAutocorrectStates = \"off\";\n\n /**\n * If `true`, the form control will have input focus when the page loads.\n */\n @Prop() autofocus = false;\n\n /**\n * The number of characters until suggestions appear. The submit button will be disabled until the inputted value is equal to or greater than this number.\n */\n @Prop() charactersUntilSuggestion: number = 2;\n\n /**\n * If `true`, the disabled state will be set.\n */\n @Prop() disabled?: boolean = false;\n\n /**\n * Specify whether to disable the built in filtering. For example, if options will already be filtered from external source.\n * If `true`, all options provided will be displayed.\n */\n @Prop() disableFilter?: boolean = false;\n\n /**\n * The amount of time, in milliseconds, to wait to trigger the `icChange` event after each keystroke.\n */\n @Prop() debounce?: number = 0;\n\n /**\n * The text displayed when there are no options in the option list.\n */\n @Prop() emptyOptionListText = \"No results found\";\n\n /**\n * If `true`, the search bar will be focused when component loaded.\n */\n @Prop() focusOnLoad?: boolean = false;\n\n /**\n * Specify whether the search bar fills the full width of the container.\n * If `true`, this overrides the --input-width CSS variable.\n */\n @Prop() fullWidth?: boolean = false;\n\n /**\n * The helper text that will be displayed for additional field guidance.\n */\n @Prop() helperText?: string = \"\";\n\n /**\n * If `true`, the label will be hidden and the required label value will be applied as an aria-label.\n */\n @Prop() hideLabel?: boolean = false;\n\n /**\n * The hint text for the hidden assistive description element.\n */\n @Prop() hintText?: string =\n \"When autocomplete results are available use the up and down arrows to choose and press enter to select\";\n\n /**\n * The label for the search bar.\n */\n @Prop() label!: string;\n\n /**\n * Trigger loading state when fetching options asyncronously\n */\n @Prop({ mutable: true }) loading?: boolean = false;\n\n /**\n * Change the message displayed when external loading times out.\n */\n @Prop() loadingErrorLabel?: string = \"Loading Error\";\n\n /**\n * Change the message displayed whilst the options are being loaded externally.\n */\n @Prop() loadingLabel?: string = \"Loading...\";\n\n /**\n * The name of the control, which is submitted with the form data.\n */\n @Prop() name: string = this.inputId;\n\n /**\n * The placeholder value to display.\n */\n @Prop() placeholder?: string = \"Search\";\n\n /**\n * If `true`, the readonly state will be set.\n */\n @Prop() readonly?: boolean = false;\n\n /**\n * If `true`, the search bar will require a value.\n */\n @Prop() required?: boolean = false;\n\n /**\n * Specify the mode search bar uses to search. `navigation` allows for quick lookups of a set of values, `query` allows for more general searches.\n */\n @Prop() searchMode?: IcSearchBarSearchModes = \"navigation\";\n\n /**\n * If `true`, the small styling will be applied to the search bar.\n */\n @Prop() small?: boolean = false;\n\n /**\n * If `true`, the value of the search will have its spelling and grammar checked.\n */\n @Prop() spellcheck: boolean = false;\n\n /**\n * If using external filtering, set a timeout for when loading takes too long.\n */\n @Prop() timeout?: number;\n\n @Watch(\"loading\")\n loadingHandler(newValue: boolean): void {\n if (newValue && !this.hasTimedOut) {\n this.preLoad = false;\n this.triggerLoading();\n }\n }\n\n @State() filteredOptions: IcMenuOption[] = [];\n\n @Watch(\"filteredOptions\")\n filteredOptionsHandler(newOptions: IcMenuOption[]): void {\n this.hasTimedOut = newOptions.some((opt) => opt.timedOut);\n }\n\n /**\n * The suggested search options.\n */\n @Prop() options?: IcMenuOption[] = [];\n\n @Watch(\"options\")\n watchOptionsHandler(newOptions: IcMenuOption[]): void {\n if (this.disableFilter && !this.hasTimedOut) {\n this.loading = false;\n clearTimeout(this.timeoutTimer);\n if (newOptions.length > 0) {\n this.filteredOptions = newOptions;\n } else {\n if (this.hadNoOptions()) {\n return;\n }\n this.setMenuChange(true);\n !this.preLoad &&\n (this.filteredOptions = [\n { label: this.emptyOptionListText, value: \"\" },\n ]);\n this.preLoad = true;\n }\n }\n this.debounceAriaLiveUpdate();\n }\n\n /**\n * The value of the search input.\n */\n @Prop({ reflect: true, mutable: true }) value: string = \"\";\n\n @Watch(\"value\")\n watchValueHandler(newValue: string): void {\n if (\n this.inputEl &&\n this.options &&\n !!getLabelFromValue(newValue, this.options)\n ) {\n this.inputEl.value = getLabelFromValue(newValue, this.options);\n } else if (this.inputEl && this.inputEl.value !== newValue) {\n this.inputEl.value = newValue;\n }\n }\n\n // The icChange event is defined here so that it appears as an event for search bar\n // The actual event is emitted from the child ic-text-field\n /**\n * Emitted when the value has changed.\n */\n @Event() icChange: EventEmitter<IcValueEventDetail>;\n\n /**\n * Emitted when value is cleared with clear button\n */\n @Event() icClear: EventEmitter<void>;\n private handleClear = (ev: Event) => {\n const keyboardEvent = ev as KeyboardEvent;\n const mouseEvent = ev as MouseEvent;\n\n if (\n mouseEvent.type === \"click\" ||\n keyboardEvent.code === \"Enter\" ||\n keyboardEvent.code === \"Space\"\n ) {\n this.value = \"\";\n this.inputEl.value = \"\";\n this.loading = false;\n clearTimeout(this.timeoutTimer);\n this.filteredOptions = this.options;\n this.el.setFocus();\n\n this.icClear.emit();\n ev.preventDefault();\n\n this.preventSubmit = true;\n }\n };\n\n // The icInput event is defined here so that it appears as an event for search bar\n // The actual event is emitted from the child ic-text-field\n /**\n * Emitted when a keyboard input occurred.\n */\n @Event() icInput: EventEmitter<IcValueEventDetail>;\n private onInput = (ev: Event) => {\n this.value = (ev.target as HTMLInputElement).value;\n\n const noOptions = [{ label: this.emptyOptionListText, value: \"\" }];\n\n if (this.options.length > 0) {\n this.setMenuChange(true);\n\n this.preLoad = false;\n\n if (this.disableFilter === false) {\n const rawFilteredOptions = getFilteredMenuOptions(\n this.options,\n false,\n this.value,\n \"anywhere\"\n );\n\n this.filteredOptions =\n rawFilteredOptions.length > 0 ? rawFilteredOptions : noOptions;\n }\n }\n\n if (!this.showClearButton) {\n this.handleShowClearButton(true);\n }\n\n this.debounceAriaLiveUpdate();\n };\n\n /**\n * @deprecated This event should not be used anymore. Use icSearchBarBlur instead.\n */\n @Event() icInputBlur: EventEmitter<IcSearchBarBlurEventDetail>;\n private onInputBlur = (ev: Event) => {\n const value = (ev.target as HTMLInputElement).value;\n const nextFocus = (ev as FocusEvent).relatedTarget;\n\n this.icInputBlur.emit({ value: value, relatedTarget: nextFocus });\n };\n\n /**\n * @deprecated This event should not be used anymore. Use icSearchBarFocus instead.\n */\n @Event() icInputFocus: EventEmitter<IcValueEventDetail>;\n private onInputFocus = (ev: Event) => {\n const value = (ev.target as HTMLInputElement).value;\n this.icInputFocus.emit({ value: value });\n\n this.handleShowClearButton(true);\n };\n\n /**\n * Emitted when option is highlighted within the menu\n */\n @Event() icOptionSelect: EventEmitter<IcOptionSelectEventDetail>;\n\n /**\n * Emitted when the state of the menu changes (i.e. open or close)\n */\n @Event() icMenuChange: EventEmitter<IcMenuChangeEventDetail>;\n /**\n * @internal - Emitted when blur is invoked from clear button\n */\n @Event() icClearBlur: EventEmitter<IcBlurEventDetail>;\n private handleClearBlur = (ev: Event) => {\n const nextFocus = (ev as FocusEvent).relatedTarget;\n\n this.icClearBlur.emit({ relatedTarget: nextFocus });\n\n this.clearButtonFocused = false;\n };\n\n /**\n * Emitted when the 'retry loading' button is clicked\n */\n @Event() icRetryLoad: EventEmitter<IcValueEventDetail>;\n\n /**\n * Emitted when the search value has been submitted\n */\n @Event() icSubmitSearch: EventEmitter<IcValueEventDetail>;\n\n /**\n * @internal - Emitted when blur is invoked from search submit button\n */\n @Event() icSubmitSearchBlur: EventEmitter<IcBlurEventDetail>;\n private handleSubmitSearchBlur = (ev: Event) => {\n const nextFocus = (ev as FocusEvent).relatedTarget;\n\n this.icSubmitSearchBlur.emit({ relatedTarget: nextFocus });\n\n this.searchSubmitFocused = false;\n };\n\n /**\n * Emitted when blur is invoked from ic-search-bar\n */\n @Event() icSearchBarBlur: EventEmitter<IcSearchBarBlurEventDetail>;\n\n /**\n * Emitted when focus is invoked from ic-search-bar\n */\n @Event() icSearchBarFocus: EventEmitter<void>;\n\n disconnectedCallback(): void {\n if (this.assistiveHintEl) {\n this.assistiveHintEl.remove();\n }\n }\n\n componentWillLoad(): void {\n this.watchValueHandler(this.value);\n\n removeDisabledFalse(this.disabled, this.el);\n }\n\n componentDidLoad(): void {\n if (this.focusOnLoad) {\n this.el.setFocus();\n }\n\n if (this.hasOptionsOrFilterDisabled()) {\n this.renderAssistiveHintEl();\n if (this.disableFilter) {\n this.filteredOptions = this.options;\n }\n }\n\n onComponentRequiredPropUndefined(\n [{ prop: this.label, propName: \"label\" }],\n \"Search Bar\"\n );\n\n if (this.inputEl !== undefined) {\n this.anchorEl = this.inputEl.shadowRoot.querySelector(\n \"ic-input-component-container\"\n );\n }\n }\n\n componentWillRender(): void {\n this.highlightFirstOptionAfterNoResults();\n }\n\n @Listen(\"icKeydown\", {})\n handleKeyDown(ev: CustomEvent): void {\n const keyEv: KeyboardEvent = ev.detail.event;\n if (this.menu && this.open) {\n this.menu.handleKeyboardOpen(keyEv);\n }\n }\n\n @Listen(\"keyup\", {})\n handleKeyUp(ev: KeyboardEvent): void {\n if (ev.key === \"Enter\") {\n if (this.preventSubmit || this.isSubmitDisabled()) {\n return;\n }\n\n this.handleSubmitSearch();\n this.setMenuChange(false);\n }\n\n if (ev.key === \"Escape\") {\n this.setMenuChange(false);\n }\n\n if (this.preventSubmit) {\n this.preventSubmit = false;\n }\n }\n\n /**\n * Sets focus on the native `input`.\n */\n @Method()\n async setFocus(): Promise<void> {\n this.retryViaKeyPress = false;\n this.retryButtonClick = false;\n if (this.inputEl) {\n this.inputEl.setFocus();\n }\n }\n\n private handleMouseDown = (ev: Event) => {\n ev.preventDefault();\n };\n\n private handleSubmitSearchFocus = () => {\n this.searchSubmitFocused = true;\n };\n\n private handleSubmitSearch = () => {\n this.highlightedValue && (this.value = this.highlightedValue);\n this.highlightedValue = undefined;\n this.icSubmitSearch.emit({ value: this.value });\n\n const form: HTMLFormElement = this.el.closest(\"FORM\");\n\n if (this.searchSubmitButton && !!form && !this.preventSubmit) {\n handleHiddenFormButtonClick(form, this.searchSubmitButton);\n }\n };\n\n private debounceAriaLiveUpdate() {\n clearTimeout(this.debounceAriaLive);\n\n this.debounceAriaLive = window.setTimeout(() => {\n this.updateSearchResultAriaLive();\n }, 500);\n }\n\n private handleSubmitSearchKeyDown = (ev: KeyboardEvent) => {\n if (ev.key === \" \") {\n ev.preventDefault();\n this.handleSubmitSearch();\n }\n };\n\n private handleRetry = (ev: CustomEvent<IcValueEventDetail>) => {\n this.retryViaKeyPress = ev.detail.keyPressed === \"Enter\";\n this.icRetryLoad.emit({ value: ev.detail.value });\n this.triggerLoading();\n this.retryButtonClick = true;\n };\n\n private triggerLoading = () => {\n const loadingOption: IcMenuOption[] = [\n { label: this.loadingLabel, value: \"\", loading: true },\n ];\n if (this.filteredOptions !== loadingOption)\n this.filteredOptions = loadingOption;\n if (this.timeout) {\n this.timeoutTimer = window.setTimeout(() => {\n this.filteredOptions = [\n { label: this.loadingErrorLabel, value: \"\", timedOut: true },\n ];\n }, this.timeout);\n }\n };\n\n private handleOptionSelect = (ev: CustomEvent) => {\n if (ev.detail.label === this.emptyOptionListText) {\n this.el.setFocus();\n return;\n }\n\n this.value = ev.detail.value;\n this.icOptionSelect.emit({ value: this.value });\n };\n\n private handleMenuOptionHighlight = (ev: CustomEvent) => {\n const optionValue = ev.detail.optionId?.replace(`${this.menuId}-`, \"\");\n optionValue && (this.highlightedValue = optionValue);\n if (ev.detail.optionId) {\n this.ariaActiveDescendant = ev.detail.optionId;\n } else {\n this.ariaActiveDescendant = undefined;\n }\n };\n\n private handleMenuChange = (ev: CustomEvent) => {\n this.setMenuChange(ev.detail.open);\n if (!ev.detail.open) {\n this.handleMenuCloseFromMenuChange(true);\n if (ev.detail.focusInput === undefined || ev.detail.focusInput) {\n this.el.setFocus();\n }\n }\n };\n\n private setMenuChange = (open: boolean) => {\n if (this.open !== open) {\n this.open = open;\n this.icMenuChange.emit({ open });\n }\n };\n\n private handleHostFocus = () => {\n if (this.options && this.value && !this.menuCloseFromMenuChangeEvent) {\n this.setMenuChange(true);\n }\n this.handleTruncateValue(false);\n\n this.icSearchBarFocus.emit();\n };\n\n private handleHostBlur = (ev: Event) => {\n const nextFocus = (ev as FocusEvent).relatedTarget;\n if (\n this.open &&\n this.options &&\n nextFocus !== this.menu &&\n !this.retryViaKeyPress &&\n !this.retryButtonClick\n ) {\n this.setMenuChange(false);\n }\n\n if (this.retryButtonClick || this.retryViaKeyPress) {\n this.inputEl.setFocus();\n }\n\n this.handleShowClearButton(false);\n this.handleMenuCloseFromMenuChange(false);\n this.handleTruncateValue(true);\n this.icSearchBarBlur.emit({ relatedTarget: nextFocus, value: this.value });\n this.retryViaKeyPress = false;\n this.retryButtonClick = false;\n };\n\n private handleShowClearButton = (visible: boolean): void => {\n this.showClearButton = visible;\n };\n\n private handleFocusClearButton = (): void => {\n this.clearButtonFocused = true;\n };\n\n private handleMenuCloseFromMenuChange = (fromEvent: boolean): void => {\n this.menuCloseFromMenuChangeEvent = fromEvent;\n };\n\n private handleTruncateValue = (truncate: boolean): void => {\n this.truncateValue = truncate;\n };\n\n private renderAssistiveHintEl = (): void => {\n const input = this.el.shadowRoot\n .querySelector(\"ic-text-field\")\n ?.shadowRoot?.querySelector(`#${this.inputId}`);\n\n if (\n input &&\n Object.keys(input).length > 0 &&\n this.hasOptionsOrFilterDisabled()\n ) {\n this.assistiveHintEl = document.createElement(\"span\");\n this.assistiveHintEl.innerText = this.hintText;\n this.assistiveHintEl.id = `${this.inputId}-assistive-hint`;\n this.assistiveHintEl.style.display = \"none\";\n if (input.after !== undefined) {\n input.after(this.assistiveHintEl);\n }\n }\n };\n\n private updateSearchResultAriaLive = (): void => {\n const searchResultsStatusEl = this.el.shadowRoot.querySelector(\n \".search-results-status\"\n ) as HTMLParagraphElement;\n\n if (\n !this.open ||\n this.value === \"\" ||\n this.value.length < this.charactersUntilSuggestion\n ) {\n searchResultsStatusEl.innerText = \"\";\n } else if (\n this.hasOptionsOrFilterDisabled() &&\n this.filteredOptions.length > 0 &&\n this.open &&\n searchResultsStatusEl &&\n !this.filteredOptions[0].loading\n ) {\n if (this.hadNoOptions()) {\n searchResultsStatusEl.innerText = this.emptyOptionListText;\n } else {\n searchResultsStatusEl.innerText = `${\n this.filteredOptions.length\n } result${this.filteredOptions.length > 1 ? \"s\" : \"\"} available`;\n }\n }\n };\n\n private hasOptionsOrFilterDisabled = (): boolean =>\n this.options.length > 0 || this.disableFilter;\n\n private hadNoOptions = (): boolean =>\n this.filteredOptions.length === 1 &&\n this.filteredOptions[0].label === this.emptyOptionListText &&\n this.searchMode === \"navigation\";\n\n private isSubmitDisabled = (): boolean => {\n const valueNotSet =\n this.value === undefined || this.value === null || this.value === \"\";\n const valueLengthLess = this.value.length < this.charactersUntilSuggestion;\n return (\n valueNotSet ||\n valueLengthLess ||\n this.disabled ||\n this.hadNoOptions() ||\n this.hasTimedOut ||\n this.loading\n );\n };\n\n private highlightFirstOptionAfterNoResults = () => {\n if (this.prevNoOption && this.menu && !this.hasTimedOut) {\n this.menu.handleSetFirstOption();\n this.prevNoOption = false;\n }\n const prevNoOptionsList = this.filteredOptions.find(\n (filteredOption) =>\n filteredOption.label === this.emptyOptionListText ||\n filteredOption.label === this.loadingErrorLabel ||\n filteredOption.label === this.loadingLabel\n );\n if (prevNoOptionsList) {\n this.prevNoOption = true;\n }\n };\n\n render() {\n const {\n inputId,\n name,\n label,\n required,\n small,\n placeholder,\n helperText,\n disabled,\n value,\n readonly,\n spellcheck,\n fullWidth,\n options,\n open,\n hideLabel,\n menuId,\n ariaActiveDescendant,\n truncateValue,\n autofocus,\n autocapitalize,\n autocomplete,\n filteredOptions,\n } = this;\n\n const disabledMode = readonly || disabled ? true : false;\n\n const describedBy = getInputDescribedByText(\n inputId,\n helperText !== \"\",\n false\n ).trim();\n\n let describedById;\n\n if (describedBy !== \"\" && this.hasOptionsOrFilterDisabled()) {\n describedById = `${describedBy} ${this.inputId}-assistive-hint`;\n } else if (this.hasOptionsOrFilterDisabled()) {\n describedById = `${this.inputId}-assistive-hint`;\n } else if (describedBy !== \"\") {\n describedById = describedBy;\n } else {\n describedById = undefined;\n }\n\n const disabledText = disabledMode && !readonly;\n const hasSuggestedSearch = value && this.hasOptionsOrFilterDisabled();\n const menuOpen = hasSuggestedSearch && open && filteredOptions.length > 0;\n const menuRendered =\n menuOpen && value.length >= this.charactersUntilSuggestion;\n const isOrHasLoaded =\n this.filteredOptions.length === 1 &&\n (this.filteredOptions[0].label === this.loadingLabel ||\n filteredOptions[0].label === this.loadingErrorLabel);\n\n let expanded;\n\n if (options.length > 0) {\n if (menuOpen) {\n expanded = \"true\";\n } else {\n expanded = \"false\";\n }\n } else {\n expanded = undefined;\n }\n\n renderHiddenInput(true, this.el, name, value, disabledMode);\n\n return (\n <Host\n class={{\n [\"search\"]: true,\n [\"fullwidth\"]: fullWidth,\n [\"disabled\"]: disabled,\n [\"small\"]: small,\n }}\n onFocus={this.handleHostFocus}\n onBlur={this.handleHostBlur}\n >\n <ic-text-field\n ref={(el) => (this.inputEl = el)}\n inputId={inputId}\n label={label}\n helperText={helperText}\n required={required}\n disabled={disabledText}\n readonly={readonly}\n small={small}\n hideLabel={hideLabel}\n fullWidth={fullWidth}\n name={name}\n truncateValue={truncateValue}\n value={\n options && !!getLabelFromValue(value, options)\n ? getLabelFromValue(value, options)\n : value\n }\n placeholder={placeholder}\n onInput={this.onInput}\n onBlur={this.onInputBlur}\n onFocus={this.onInputFocus}\n aria-label={hideLabel ? label : \"\"}\n aria-describedby={describedById}\n aria-owns={menuRendered ? menuId : undefined}\n aria-haspopup={options.length > 0 ? \"listbox\" : undefined}\n ariaExpanded={expanded}\n ariaActiveDescendant={ariaActiveDescendant}\n aria-autocomplete={hasSuggestedSearch ? \"list\" : undefined}\n role={hasSuggestedSearch ? \"combobox\" : undefined}\n autocomplete={autocomplete}\n autocapitalize={autocapitalize}\n autoFocus={autofocus}\n spellcheck={spellcheck}\n inputmode=\"search\"\n debounce={this.debounce}\n >\n <div\n class={{\n \"clear-button-container\": true,\n \"clear-button-visible\":\n value && !disabledMode && this.showClearButton,\n }}\n slot=\"clear-button\"\n >\n <ic-button\n id=\"clear-button\"\n class=\"clear-button\"\n aria-label=\"Clear\"\n innerHTML={clearIcon}\n onClick={this.handleClear}\n onMouseDown={this.handleMouseDown}\n size={small ? \"small\" : \"default\"}\n onFocus={this.handleFocusClearButton}\n onBlur={this.handleClearBlur}\n onKeyDown={this.handleClear}\n type=\"submit\"\n variant=\"icon\"\n appearance={\n this.clearButtonFocused\n ? IcThemeForegroundEnum.Light\n : IcThemeForegroundEnum.Dark\n }\n ></ic-button>\n <div class=\"divider\"></div>\n </div>\n <div\n class={{\n \"search-submit-button-container\": true,\n \"search-submit-button-disabled\": this.isSubmitDisabled(),\n }}\n slot=\"search-submit-button\"\n >\n <ic-button\n id=\"search-submit-button\"\n aria-label=\"Search\"\n ref={(el) => (this.searchSubmitButton = el)}\n class={{\n [\"search-submit-button\"]: true,\n [\"search-submit-button-small\"]: !!small,\n }}\n disabled={this.isSubmitDisabled()}\n innerHTML={searchIcon}\n size={small ? \"small\" : \"default\"}\n onClick={this.handleSubmitSearch}\n onMouseDown={this.handleMouseDown}\n onBlur={this.handleSubmitSearchBlur}\n onFocus={this.handleSubmitSearchFocus}\n onKeyDown={this.handleSubmitSearchKeyDown}\n type=\"submit\"\n variant=\"icon\"\n appearance={\n this.searchSubmitFocused\n ? IcThemeForegroundEnum.Light\n : IcThemeForegroundEnum.Default\n }\n ></ic-button>\n </div>\n <div\n class={{\n \"menu-container\": true,\n fullwidth: fullWidth,\n }}\n slot=\"menu\"\n >\n {menuRendered && (\n <ic-menu\n class={{\n \"no-results\": this.hadNoOptions() || isOrHasLoaded,\n }}\n activationType=\"manual\"\n anchorEl={this.anchorEl}\n autoFocusOnSelected={false}\n searchMode={this.searchMode}\n inputEl={this.inputEl}\n inputLabel={label}\n ref={(el) => (this.menu = el)}\n small={small}\n fullWidth={fullWidth}\n menuId={menuId}\n open={true}\n options={filteredOptions}\n onMenuOptionSelect={this.handleOptionSelect}\n onMenuStateChange={this.handleMenuChange}\n onMenuOptionId={this.handleMenuOptionHighlight}\n onRetryButtonClicked={this.handleRetry}\n parentEl={this.el}\n value={value}\n ></ic-menu>\n )}\n </div>\n </ic-text-field>\n <div\n aria-live=\"polite\"\n role=\"status\"\n class=\"search-results-status\"\n ></div>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["icBreadcrumbGroupCss","BreadcrumbGroup","this","ADD_CLASS_DELAY","IC_BREADCRUMB","resizeObserver","SHOW_BACK_ICON","setBackBreadcrumb","backBreadcrumbOnly","setBackBreadcrumbAttr","lastParentBreadcrumb","classList","add","setAttribute","getLastParentBreadcrumb","allBreadcrumbs","Array","from","el","querySelectorAll","length","breadcrumbs","filter","breadcrumb","getAttribute","setDefaultBreadcrumbs","forEach","setCollapsed","collapsed","collapsedBreadcrumbs","splice","contains","firstBreadcrumb","insertAdjacentElement","collapsedBreadcrumbWrapper","clickHandler","handleHiddenCollapsedBreadcrumbs","renderCollapsedBreadcrumb","document","createElement","collapsedBreadcrumbEl","ariaLabel","id","innerText","className","ariaDescribed","addEventListener","append","remove","setTimeout","removeVisuallyHiddenClass","expandedBreadcrumbs","transitionendHandler","event","propertyName","target","setLastParentCollapsedBackBreadcrumb","revertLastParentCollapsedBreadcrumb","resizeObserverCallback","currSize","deviceSize","DEVICE_SIZES","S","runResizeObserver","ResizeObserver","getCurrentDeviceSize","observe","XL","componentWillLoad","checkResizeObserver","disconnectedCallback","removeEventListener","render","h","Host","class","back"],"sources":["./src/components/ic-breadcrumb-group/ic-breadcrumb-group.css?tag=ic-breadcrumb-group&encapsulation=shadow","./src/components/ic-breadcrumb-group/ic-breadcrumb-group.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n:host ol {\n display: flex;\n list-style-type: none;\n align-items: center;\n flex-wrap: wrap;\n padding: 0;\n margin: 0;\n}\n\n:host(.back) ol ::slotted(ic-breadcrumb) {\n display: none;\n}\n\n:host(.back) ol ::slotted(ic-breadcrumb.show) {\n display: flex;\n}\n\n:host(.collapsed) ol ::slotted(ic-breadcrumb.hide) {\n display: none;\n opacity: 0;\n visibility: hidden;\n}\n\n:host(.collapsed) ol ::slotted(ic-breadcrumb.visuallyhidden) {\n display: block;\n opacity: 0;\n transition: all var(--ic-easing-transition-slow);\n}\n\n:host(.collapsed) ol ::slotted(ic-breadcrumb.fade) {\n opacity: 1;\n}\n","import { Component, Host, h, Element, Prop, State } from \"@stencil/core\";\nimport {\n checkResizeObserver,\n DEVICE_SIZES,\n getCurrentDeviceSize,\n} from \"../../utils/helpers\";\n\n@Component({\n tag: \"ic-breadcrumb-group\",\n styleUrl: \"ic-breadcrumb-group.css\",\n shadow: true,\n})\n\n// Added ResizeObserver to find out width of breadcrumbs and parents. Use side navigation long title for ref.\nexport class BreadcrumbGroup {\n private ADD_CLASS_DELAY = 50;\n private breadcrumb: HTMLIcBreadcrumbElement;\n private breadcrumbs: HTMLIcBreadcrumbElement[];\n private collapsedBreadcrumbEl: HTMLButtonElement;\n private collapsedBreadcrumbs: HTMLIcBreadcrumbElement[];\n private collapsedBreadcrumbWrapper: HTMLIcBreadcrumbElement;\n private IC_BREADCRUMB: string = \"ic-breadcrumb\";\n private resizeObserver: ResizeObserver = null;\n private SHOW_BACK_ICON: string = \"show-back-icon\";\n\n @Element() el: HTMLIcBreadcrumbGroupElement;\n\n @State() deviceSize: number = DEVICE_SIZES.XL;\n @State() expandedBreadcrumbs: boolean = false;\n\n /**\n * If `true`, display only a single breadcrumb for the parent page with a back icon.\n */\n @Prop() backBreadcrumbOnly: boolean = false;\n /**\n * If `true`, all breadcrumbs between the first and last breadcrumb will be collapsed.\n */\n @Prop() collapsed: boolean = false;\n\n componentWillLoad(): void {\n const allBreadcrumbs = Array.from(\n this.el.querySelectorAll(this.IC_BREADCRUMB)\n );\n\n if (this.backBreadcrumbOnly) {\n this.setBackBreadcrumb();\n } else {\n checkResizeObserver(this.runResizeObserver);\n }\n\n if (this.collapsed) {\n this.collapsedBreadcrumbWrapper = this.renderCollapsedBreadcrumb();\n\n if (allBreadcrumbs.length > 2) {\n if (getCurrentDeviceSize() === DEVICE_SIZES.S) {\n this.setLastParentCollapsedBackBreadcrumb();\n } else {\n this.setCollapsed();\n }\n }\n }\n }\n\n disconnectedCallback(): void {\n this.breadcrumb.removeEventListener(\n \"transitionend\",\n this.transitionendHandler\n );\n this.collapsedBreadcrumbEl.removeEventListener(\"click\", this.clickHandler);\n }\n\n private setBackBreadcrumb = () => {\n if (this.backBreadcrumbOnly) {\n this.setBackBreadcrumbAttr();\n }\n };\n\n private setBackBreadcrumbAttr = () => {\n if (this.lastParentBreadcrumb) {\n this.lastParentBreadcrumb.classList.add(\"show\");\n this.lastParentBreadcrumb.setAttribute(this.SHOW_BACK_ICON, \"true\");\n }\n };\n\n private getLastParentBreadcrumb = (): HTMLIcBreadcrumbElement | null => {\n const allBreadcrumbs: HTMLIcBreadcrumbElement[] = Array.from(\n this.el.querySelectorAll(this.IC_BREADCRUMB)\n );\n\n if (allBreadcrumbs.length === 1) {\n return null;\n }\n\n this.breadcrumbs = allBreadcrumbs.filter(\n (breadcrumb) => !breadcrumb.getAttribute(\"current\")\n );\n this.breadcrumb = this.breadcrumbs[this.breadcrumbs.length - 1];\n\n return this.breadcrumb;\n };\n\n private lastParentBreadcrumb = this.getLastParentBreadcrumb();\n\n private setDefaultBreadcrumbs = () => {\n const allBreadcrumbs = Array.from(\n this.el.querySelectorAll(this.IC_BREADCRUMB)\n );\n allBreadcrumbs.forEach((breadcrumb) => {\n breadcrumb.setAttribute(this.SHOW_BACK_ICON, \"false\");\n });\n };\n\n private setCollapsed = () => {\n if (this.collapsed) {\n const allBreadcrumbs: HTMLIcBreadcrumbElement[] = Array.from(\n this.el.querySelectorAll(this.IC_BREADCRUMB)\n );\n this.collapsedBreadcrumbs = allBreadcrumbs\n .splice(1, allBreadcrumbs.length - 2)\n .filter(\n (breadcrumb) =>\n !breadcrumb.classList.contains(\"collapsed-breadcrumb-wrapper\")\n );\n\n this.collapsedBreadcrumbs.forEach((breadcrumb) =>\n breadcrumb.classList.add(\"hide\")\n );\n\n const firstBreadcrumb = allBreadcrumbs[0];\n\n if (firstBreadcrumb) {\n firstBreadcrumb.insertAdjacentElement(\n \"afterend\",\n this.collapsedBreadcrumbWrapper\n );\n }\n }\n };\n\n private clickHandler = () => {\n this.handleHiddenCollapsedBreadcrumbs(this.collapsedBreadcrumbWrapper);\n };\n\n private renderCollapsedBreadcrumb = () => {\n this.collapsedBreadcrumbWrapper = document.createElement(\"ic-breadcrumb\");\n this.collapsedBreadcrumbWrapper.classList.add(\n \"collapsed-breadcrumb-wrapper\"\n );\n this.collapsedBreadcrumbEl = document.createElement(\"button\");\n\n const ariaLabel = document.createElement(\"span\");\n ariaLabel.id = \"collapsed-button-label\";\n ariaLabel.innerText = \"Collapsed breadcrumbs\";\n ariaLabel.className = \"hide\";\n this.collapsedBreadcrumbEl.setAttribute(\n \"aria-labelledby\",\n \"collapsed-button-label\"\n );\n\n const ariaDescribed = document.createElement(\"span\");\n ariaDescribed.id = \"collapsed-button-described\";\n ariaDescribed.innerText = \"Select to view collapsed breadcrumbs\";\n ariaDescribed.className = \"hide\";\n this.collapsedBreadcrumbEl.setAttribute(\n \"aria-describedby\",\n \"collapsed-button-described\"\n );\n\n this.collapsedBreadcrumbEl.id = \"collapsed-ellipsis\";\n this.collapsedBreadcrumbEl.innerText = \"...\";\n this.collapsedBreadcrumbEl.classList.add(\"collapsed-breadcrumb\");\n this.collapsedBreadcrumbEl.addEventListener(\"click\", this.clickHandler);\n\n this.collapsedBreadcrumbWrapper.append(ariaDescribed);\n this.collapsedBreadcrumbWrapper.append(ariaLabel);\n this.collapsedBreadcrumbWrapper.append(this.collapsedBreadcrumbEl);\n\n return this.collapsedBreadcrumbWrapper;\n };\n\n private handleHiddenCollapsedBreadcrumbs = (\n collapsedBreadcrumbWrapper: HTMLIcBreadcrumbElement\n ) => {\n collapsedBreadcrumbWrapper.remove();\n this.collapsedBreadcrumbs.forEach((breadcrumb) => {\n breadcrumb.classList.add(\"visuallyhidden\");\n breadcrumb.classList.remove(\"hide\");\n setTimeout(() => {\n breadcrumb.classList.add(\"fade\");\n }, this.ADD_CLASS_DELAY);\n\n this.removeVisuallyHiddenClass(breadcrumb);\n });\n this.expandedBreadcrumbs = true;\n };\n\n private transitionendHandler = (event: TransitionEvent) => {\n if (event.propertyName === \"opacity\") {\n (event.target as HTMLElement).classList.remove(\"visuallyhidden\");\n }\n };\n\n private removeVisuallyHiddenClass = (breadcrumb: HTMLIcBreadcrumbElement) => {\n breadcrumb.addEventListener(\"transitionend\", this.transitionendHandler);\n };\n\n private setLastParentCollapsedBackBreadcrumb = () => {\n this.setBackBreadcrumbAttr();\n this.lastParentBreadcrumb.classList.remove(\"hide\");\n };\n\n private revertLastParentCollapsedBreadcrumb = () => {\n this.lastParentBreadcrumb.setAttribute(this.SHOW_BACK_ICON, \"false\");\n };\n\n private resizeObserverCallback = (currSize: number) => {\n if (currSize !== this.deviceSize) {\n this.deviceSize = currSize;\n\n if (this.deviceSize <= DEVICE_SIZES.S) {\n this.el.setAttribute(\"back-breadcrumb-only\", \"true\");\n if (this.collapsed) {\n this.setLastParentCollapsedBackBreadcrumb();\n } else {\n this.setBackBreadcrumb();\n }\n } else {\n this.el.setAttribute(\"back-breadcrumb-only\", \"false\");\n if (this.collapsed && this.breadcrumbs && this.breadcrumbs.length > 2) {\n this.revertLastParentCollapsedBreadcrumb();\n if (this.expandedBreadcrumbs) {\n this.setDefaultBreadcrumbs();\n } else {\n this.setCollapsed();\n }\n } else {\n this.setDefaultBreadcrumbs();\n }\n }\n }\n };\n\n private runResizeObserver = () => {\n this.resizeObserver = new ResizeObserver(() => {\n const currSize = getCurrentDeviceSize();\n this.resizeObserverCallback(currSize);\n });\n\n this.resizeObserver.observe(this.el);\n };\n\n render() {\n return (\n <Host\n class={{\n back: this.backBreadcrumbOnly,\n collapsed: this.collapsed,\n }}\n >\n <nav aria-label=\"breadcrumbs\">\n <ol>\n <slot />\n </ol>\n </nav>\n </Host>\n );\n }\n}\n"],"mappings":"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"}