@ukic/web-components 2.8.0 → 2.9.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1070) hide show
  1. package/dist/cjs/core.cjs.js +3 -3
  2. package/dist/cjs/core.cjs.js.map +1 -1
  3. package/dist/cjs/{helpers-0d63359f.js → helpers-3f91f63a.js} +292 -292
  4. package/dist/cjs/helpers-3f91f63a.js.map +1 -0
  5. package/dist/cjs/ic-accordion-group.cjs.entry.js +71 -71
  6. package/dist/cjs/ic-accordion-group.cjs.entry.js.map +1 -1
  7. package/dist/cjs/ic-accordion.cjs.entry.js +99 -99
  8. package/dist/cjs/ic-accordion.cjs.entry.js.map +1 -1
  9. package/dist/cjs/ic-alert.cjs.entry.js +58 -58
  10. package/dist/cjs/ic-alert.cjs.entry.js.map +1 -1
  11. package/dist/cjs/ic-back-to-top.cjs.entry.js +120 -120
  12. package/dist/cjs/ic-back-to-top.cjs.entry.js.map +1 -1
  13. package/dist/cjs/ic-badge.cjs.entry.js +146 -146
  14. package/dist/cjs/ic-badge.cjs.entry.js.map +1 -1
  15. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +172 -166
  16. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js.map +1 -1
  17. package/dist/cjs/ic-breadcrumb.cjs.entry.js +55 -53
  18. package/dist/cjs/ic-breadcrumb.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ic-button_3.cjs.entry.js +615 -606
  20. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  21. package/dist/cjs/ic-card.cjs.entry.js +105 -105
  22. package/dist/cjs/ic-card.cjs.entry.js.map +1 -1
  23. package/dist/cjs/ic-checkbox-group.cjs.entry.js +60 -60
  24. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ic-checkbox.cjs.entry.js +95 -95
  26. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -1
  27. package/dist/cjs/ic-chip.cjs.entry.js +67 -65
  28. package/dist/cjs/ic-chip.cjs.entry.js.map +1 -1
  29. package/dist/cjs/ic-classification-banner.cjs.entry.js +23 -23
  30. package/dist/cjs/ic-classification-banner.cjs.entry.js.map +1 -1
  31. package/dist/cjs/ic-data-entity.cjs.entry.js +17 -17
  32. package/dist/cjs/ic-data-entity.cjs.entry.js.map +1 -1
  33. package/dist/cjs/ic-data-row.cjs.entry.js +74 -74
  34. package/dist/cjs/ic-data-row.cjs.entry.js.map +1 -1
  35. package/dist/cjs/ic-dialog.cjs.entry.js +339 -339
  36. package/dist/cjs/ic-dialog.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ic-divider.cjs.entry.js +16 -16
  38. package/dist/cjs/ic-divider.cjs.entry.js.map +1 -1
  39. package/dist/cjs/ic-empty-state.cjs.entry.js +24 -24
  40. package/dist/cjs/ic-empty-state.cjs.entry.js.map +1 -1
  41. package/dist/cjs/ic-footer-link-group.cjs.entry.js +55 -55
  42. package/dist/cjs/ic-footer-link-group.cjs.entry.js.map +1 -1
  43. package/dist/cjs/ic-footer-link.cjs.entry.js +50 -50
  44. package/dist/cjs/ic-footer-link.cjs.entry.js.map +1 -1
  45. package/dist/cjs/ic-footer.cjs.entry.js +78 -78
  46. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -1
  47. package/dist/cjs/ic-hero.cjs.entry.js +62 -62
  48. package/dist/cjs/ic-hero.cjs.entry.js.map +1 -1
  49. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +151 -151
  50. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js.map +1 -1
  51. package/dist/cjs/ic-input-component-container_3.cjs.entry.js +678 -678
  52. package/dist/cjs/ic-input-component-container_3.cjs.entry.js.map +1 -1
  53. package/dist/cjs/ic-input-label_2.cjs.entry.js +63 -63
  54. package/dist/cjs/ic-input-label_2.cjs.entry.js.map +1 -1
  55. package/dist/cjs/ic-link.cjs.entry.js +55 -55
  56. package/dist/cjs/ic-link.cjs.entry.js.map +1 -1
  57. package/dist/cjs/ic-menu-group.cjs.entry.js +12 -12
  58. package/dist/cjs/ic-menu-group.cjs.entry.js.map +1 -1
  59. package/dist/cjs/ic-menu-item.cjs.entry.js +100 -100
  60. package/dist/cjs/ic-menu-item.cjs.entry.js.map +1 -1
  61. package/dist/cjs/ic-navigation-button.cjs.entry.js +79 -76
  62. package/dist/cjs/ic-navigation-button.cjs.entry.js.map +1 -1
  63. package/dist/cjs/ic-navigation-group.cjs.entry.js +283 -283
  64. package/dist/cjs/ic-navigation-group.cjs.entry.js.map +1 -1
  65. package/dist/cjs/ic-navigation-item.cjs.entry.js +152 -152
  66. package/dist/cjs/ic-navigation-item.cjs.entry.js.map +1 -1
  67. package/dist/cjs/ic-navigation-menu.cjs.entry.js +105 -105
  68. package/dist/cjs/ic-navigation-menu.cjs.entry.js.map +1 -1
  69. package/dist/cjs/ic-page-header.cjs.entry.js +93 -93
  70. package/dist/cjs/ic-page-header.cjs.entry.js.map +1 -1
  71. package/dist/cjs/ic-pagination-item.cjs.entry.js +42 -42
  72. package/dist/cjs/ic-pagination-item.cjs.entry.js.map +1 -1
  73. package/dist/cjs/ic-pagination.cjs.entry.js +196 -195
  74. package/dist/cjs/ic-pagination.cjs.entry.js.map +1 -1
  75. package/dist/cjs/ic-popover-menu.cjs.entry.js +231 -231
  76. package/dist/cjs/ic-popover-menu.cjs.entry.js.map +1 -1
  77. package/dist/cjs/ic-radio-group.cjs.entry.js +156 -156
  78. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -1
  79. package/dist/cjs/ic-radio-option.cjs.entry.js +128 -128
  80. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  81. package/dist/cjs/ic-search-bar.cjs.entry.js +474 -474
  82. package/dist/cjs/ic-search-bar.cjs.entry.js.map +1 -1
  83. package/dist/cjs/ic-section-container.cjs.entry.js +15 -15
  84. package/dist/cjs/ic-section-container.cjs.entry.js.map +1 -1
  85. package/dist/cjs/ic-select.cjs.entry.js +639 -639
  86. package/dist/cjs/ic-select.cjs.entry.js.map +1 -1
  87. package/dist/cjs/ic-side-navigation.cjs.entry.js +424 -426
  88. package/dist/cjs/ic-side-navigation.cjs.entry.js.map +1 -1
  89. package/dist/cjs/ic-skeleton.cjs.entry.js +43 -43
  90. package/dist/cjs/ic-skeleton.cjs.entry.js.map +1 -1
  91. package/dist/cjs/ic-status-tag.cjs.entry.js +29 -29
  92. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -1
  93. package/dist/cjs/ic-step.cjs.entry.js +121 -121
  94. package/dist/cjs/ic-step.cjs.entry.js.map +1 -1
  95. package/dist/cjs/ic-stepper.cjs.entry.js +200 -200
  96. package/dist/cjs/ic-stepper.cjs.entry.js.map +1 -1
  97. package/dist/cjs/ic-switch.cjs.entry.js +77 -77
  98. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  99. package/dist/cjs/ic-tab-context.cjs.entry.js +252 -252
  100. package/dist/cjs/ic-tab-context.cjs.entry.js.map +1 -1
  101. package/dist/cjs/ic-tab-group.cjs.entry.js +23 -23
  102. package/dist/cjs/ic-tab-group.cjs.entry.js.map +1 -1
  103. package/dist/cjs/ic-tab-panel.cjs.entry.js +31 -31
  104. package/dist/cjs/ic-tab-panel.cjs.entry.js.map +1 -1
  105. package/dist/cjs/ic-tab.cjs.entry.js +86 -86
  106. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -1
  107. package/dist/cjs/ic-text-field.cjs.entry.js +210 -210
  108. package/dist/cjs/ic-text-field.cjs.entry.js.map +1 -1
  109. package/dist/cjs/ic-theme.cjs.entry.js +51 -51
  110. package/dist/cjs/ic-theme.cjs.entry.js.map +1 -1
  111. package/dist/cjs/ic-toast-region.cjs.entry.js +47 -46
  112. package/dist/cjs/ic-toast-region.cjs.entry.js.map +1 -1
  113. package/dist/cjs/ic-toast.cjs.entry.js +145 -145
  114. package/dist/cjs/ic-toast.cjs.entry.js.map +1 -1
  115. package/dist/cjs/ic-top-navigation.cjs.entry.js +198 -199
  116. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -1
  117. package/dist/cjs/ic-typography.cjs.entry.js +118 -118
  118. package/dist/cjs/ic-typography.cjs.entry.js.map +1 -1
  119. package/dist/{esm/index-813020f1.js → cjs/index-152d1fe5.js} +634 -376
  120. package/dist/cjs/index-152d1fe5.js.map +1 -0
  121. package/dist/cjs/loader.cjs.js +2 -2
  122. package/dist/cjs/types-dc22e301.js +16 -0
  123. package/dist/cjs/{types-7d67439f.js.map → types-dc22e301.js.map} +1 -1
  124. package/dist/collection/collection-manifest.json +2 -2
  125. package/dist/collection/components/ic-accordion/ic-accordion.js +276 -276
  126. package/dist/collection/components/ic-accordion/ic-accordion.js.map +1 -1
  127. package/dist/collection/components/ic-accordion/test/basic/ic-accordion.e2e.js +39 -39
  128. package/dist/collection/components/ic-accordion/test/basic/ic-accordion.e2e.js.map +1 -1
  129. package/dist/collection/components/ic-accordion/test/basic/ic-accordion.spec.js +215 -215
  130. package/dist/collection/components/ic-accordion/test/basic/ic-accordion.spec.js.map +1 -1
  131. package/dist/collection/components/ic-accordion-group/ic-accordion-group.js +200 -200
  132. package/dist/collection/components/ic-accordion-group/ic-accordion-group.js.map +1 -1
  133. package/dist/collection/components/ic-accordion-group/test/a11y/ic-accordion-group.test.a11y.js +5 -5
  134. package/dist/collection/components/ic-accordion-group/test/a11y/ic-accordion-group.test.a11y.js.map +1 -1
  135. package/dist/collection/components/ic-accordion-group/test/basic/ic-accordion-group.e2e.js +68 -68
  136. package/dist/collection/components/ic-accordion-group/test/basic/ic-accordion-group.e2e.js.map +1 -1
  137. package/dist/collection/components/ic-accordion-group/test/basic/ic-accordion-group.spec.js +71 -71
  138. package/dist/collection/components/ic-accordion-group/test/basic/ic-accordion-group.spec.js.map +1 -1
  139. package/dist/collection/components/ic-alert/ic-alert.js +231 -231
  140. package/dist/collection/components/ic-alert/ic-alert.js.map +1 -1
  141. package/dist/collection/components/ic-alert/test/a11y/ic-alert.test.a11y.js +5 -5
  142. package/dist/collection/components/ic-alert/test/a11y/ic-alert.test.a11y.js.map +1 -1
  143. package/dist/collection/components/ic-alert/test/basic/ic-alert.e2e.js +12 -12
  144. package/dist/collection/components/ic-alert/test/basic/ic-alert.e2e.js.map +1 -1
  145. package/dist/collection/components/ic-alert/test/basic/ic-alert.spec.js +44 -44
  146. package/dist/collection/components/ic-alert/test/basic/ic-alert.spec.js.map +1 -1
  147. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js +159 -159
  148. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js.map +1 -1
  149. package/dist/collection/components/ic-back-to-top/test/a11y/ic-back-to-top.test.a11y.js +14 -14
  150. package/dist/collection/components/ic-back-to-top/test/a11y/ic-back-to-top.test.a11y.js.map +1 -1
  151. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.e2e.js +43 -43
  152. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.e2e.js.map +1 -1
  153. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.spec.js +102 -102
  154. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.spec.js.map +1 -1
  155. package/dist/collection/components/ic-badge/ic-badge.js +385 -385
  156. package/dist/collection/components/ic-badge/ic-badge.js.map +1 -1
  157. package/dist/collection/components/ic-badge/test/a11y/ic-badge.test.a11y.js +10 -10
  158. package/dist/collection/components/ic-badge/test/a11y/ic-badge.test.a11y.js.map +1 -1
  159. package/dist/collection/components/ic-badge/test/basic/ic-badge.spec.js +172 -172
  160. package/dist/collection/components/ic-badge/test/basic/ic-badge.spec.js.map +1 -1
  161. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.css +9 -1
  162. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js +186 -157
  163. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js.map +1 -1
  164. package/dist/collection/components/ic-breadcrumb/test/basic/ic-breadcrumb.spec.js +43 -43
  165. package/dist/collection/components/ic-breadcrumb/test/basic/ic-breadcrumb.spec.js.map +1 -1
  166. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js +250 -220
  167. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js.map +1 -1
  168. package/dist/collection/components/ic-breadcrumb-group/test/a11y/ic-breadcrumb-group.test.a11y.js +10 -10
  169. package/dist/collection/components/ic-breadcrumb-group/test/a11y/ic-breadcrumb-group.test.a11y.js.map +1 -1
  170. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.e2e.js +34 -34
  171. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.e2e.js.map +1 -1
  172. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.spec.js +156 -118
  173. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.spec.js.map +1 -1
  174. package/dist/collection/components/ic-button/ic-button.css +14 -0
  175. package/dist/collection/components/ic-button/ic-button.js +798 -773
  176. package/dist/collection/components/ic-button/ic-button.js.map +1 -1
  177. package/dist/collection/components/ic-button/test/a11y/ic-button.test.a11y.js +5 -5
  178. package/dist/collection/components/ic-button/test/a11y/ic-button.test.a11y.js.map +1 -1
  179. package/dist/collection/components/ic-button/test/basic/ic-button.e2e.js +114 -114
  180. package/dist/collection/components/ic-button/test/basic/ic-button.e2e.js.map +1 -1
  181. package/dist/collection/components/ic-button/test/basic/ic-button.spec.js +249 -236
  182. package/dist/collection/components/ic-button/test/basic/ic-button.spec.js.map +1 -1
  183. package/dist/collection/components/ic-card/ic-card.js +375 -375
  184. package/dist/collection/components/ic-card/ic-card.js.map +1 -1
  185. package/dist/collection/components/ic-card/test/a11y/ic-card.test.a11y.js +15 -15
  186. package/dist/collection/components/ic-card/test/a11y/ic-card.test.a11y.js.map +1 -1
  187. package/dist/collection/components/ic-card/test/basic/ic-card.e2e.js +19 -19
  188. package/dist/collection/components/ic-card/test/basic/ic-card.e2e.js.map +1 -1
  189. package/dist/collection/components/ic-card/test/basic/ic-card.spec.js +147 -147
  190. package/dist/collection/components/ic-card/test/basic/ic-card.spec.js.map +1 -1
  191. package/dist/collection/components/ic-checkbox/ic-checkbox.css +6 -6
  192. package/dist/collection/components/ic-checkbox/ic-checkbox.js +474 -474
  193. package/dist/collection/components/ic-checkbox/ic-checkbox.js.map +1 -1
  194. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js +302 -302
  195. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js.map +1 -1
  196. package/dist/collection/components/ic-checkbox-group/test/a11y/ic-checkbox-group.test.a11y.js +5 -5
  197. package/dist/collection/components/ic-checkbox-group/test/a11y/ic-checkbox-group.test.a11y.js.map +1 -1
  198. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.e2e.js +124 -124
  199. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.e2e.js.map +1 -1
  200. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.spec.js +148 -148
  201. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.spec.js.map +1 -1
  202. package/dist/collection/components/ic-chip/ic-chip.css +8 -0
  203. package/dist/collection/components/ic-chip/ic-chip.js +291 -271
  204. package/dist/collection/components/ic-chip/ic-chip.js.map +1 -1
  205. package/dist/collection/components/ic-chip/test/a11y/ic-chip.test.a11y.js +5 -5
  206. package/dist/collection/components/ic-chip/test/a11y/ic-chip.test.a11y.js.map +1 -1
  207. package/dist/collection/components/ic-chip/test/basic/ic-chip.spec.js +81 -81
  208. package/dist/collection/components/ic-chip/test/basic/ic-chip.spec.js.map +1 -1
  209. package/dist/collection/components/ic-classification-banner/ic-classification-banner.js +132 -132
  210. package/dist/collection/components/ic-classification-banner/ic-classification-banner.js.map +1 -1
  211. package/dist/collection/components/ic-classification-banner/test/a11y/ic-classification-banner.test.a11y.js +5 -5
  212. package/dist/collection/components/ic-classification-banner/test/a11y/ic-classification-banner.test.a11y.js.map +1 -1
  213. package/dist/collection/components/ic-classification-banner/test/basic/ic-classification-banner.spec.js +55 -55
  214. package/dist/collection/components/ic-classification-banner/test/basic/ic-classification-banner.spec.js.map +1 -1
  215. package/dist/collection/components/ic-data-entity/ic-data-entity.js +92 -92
  216. package/dist/collection/components/ic-data-entity/ic-data-entity.js.map +1 -1
  217. package/dist/collection/components/ic-data-entity/test/a11y/ic-data-entity.test.a11y.js +5 -5
  218. package/dist/collection/components/ic-data-entity/test/a11y/ic-data-entity.test.a11y.js.map +1 -1
  219. package/dist/collection/components/ic-data-entity/test/basic/ic-data-entity.spec.js +28 -28
  220. package/dist/collection/components/ic-data-entity/test/basic/ic-data-entity.spec.js.map +1 -1
  221. package/dist/collection/components/ic-data-row/ic-data-row.js +170 -170
  222. package/dist/collection/components/ic-data-row/ic-data-row.js.map +1 -1
  223. package/dist/collection/components/ic-data-row/test/a11y/ic-data-row.test.a11y.js +14 -14
  224. package/dist/collection/components/ic-data-row/test/a11y/ic-data-row.test.a11y.js.map +1 -1
  225. package/dist/collection/components/ic-data-row/test/basic/ic-data-row.spec.js +61 -61
  226. package/dist/collection/components/ic-data-row/test/basic/ic-data-row.spec.js.map +1 -1
  227. package/dist/collection/components/ic-dialog/ic-dialog.js +765 -765
  228. package/dist/collection/components/ic-dialog/ic-dialog.js.map +1 -1
  229. package/dist/collection/components/ic-dialog/test/a11y/ic-dialog.test.a11y.js +5 -5
  230. package/dist/collection/components/ic-dialog/test/a11y/ic-dialog.test.a11y.js.map +1 -1
  231. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.e2e.js +155 -155
  232. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.e2e.js.map +1 -1
  233. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.spec.js +573 -573
  234. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.spec.js.map +1 -1
  235. package/dist/collection/components/ic-divider/ic-divider.js +38 -38
  236. package/dist/collection/components/ic-divider/ic-divider.js.map +1 -1
  237. package/dist/collection/components/ic-divider/test/basic/ic-divider.spec.js +17 -17
  238. package/dist/collection/components/ic-divider/test/basic/ic-divider.spec.js.map +1 -1
  239. package/dist/collection/components/ic-empty-state/ic-empty-state.js +151 -151
  240. package/dist/collection/components/ic-empty-state/ic-empty-state.js.map +1 -1
  241. package/dist/collection/components/ic-empty-state/test/a11y/ic-empty-state.test.a11y.js +5 -5
  242. package/dist/collection/components/ic-empty-state/test/a11y/ic-empty-state.test.a11y.js.map +1 -1
  243. package/dist/collection/components/ic-empty-state/test/basic/ic-empty-state.spec.js +52 -52
  244. package/dist/collection/components/ic-empty-state/test/basic/ic-empty-state.spec.js.map +1 -1
  245. package/dist/collection/components/ic-footer/ic-footer.js +242 -242
  246. package/dist/collection/components/ic-footer/ic-footer.js.map +1 -1
  247. package/dist/collection/components/ic-footer/test/a11y/ic-footer.test.a11y.js +15 -15
  248. package/dist/collection/components/ic-footer/test/a11y/ic-footer.test.a11y.js.map +1 -1
  249. package/dist/collection/components/ic-footer/test/basic/ic-footer.e2e.js +25 -25
  250. package/dist/collection/components/ic-footer/test/basic/ic-footer.e2e.js.map +1 -1
  251. package/dist/collection/components/ic-footer/test/basic/ic-footer.spec.js +108 -108
  252. package/dist/collection/components/ic-footer/test/basic/ic-footer.spec.js.map +1 -1
  253. package/dist/collection/components/ic-footer-link/ic-footer-link.js +190 -190
  254. package/dist/collection/components/ic-footer-link/ic-footer-link.js.map +1 -1
  255. package/dist/collection/components/ic-footer-link/test/a11y/ic-footer-link.test.a11y.js +13 -13
  256. package/dist/collection/components/ic-footer-link/test/a11y/ic-footer-link.test.a11y.js.map +1 -1
  257. package/dist/collection/components/ic-footer-link/test/basic/ic-footer-link.spec.js +36 -36
  258. package/dist/collection/components/ic-footer-link/test/basic/ic-footer-link.spec.js.map +1 -1
  259. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js +107 -107
  260. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js.map +1 -1
  261. package/dist/collection/components/ic-footer-link-group/test/a11y/ic-footer-link-group.test.a11y.js +13 -13
  262. package/dist/collection/components/ic-footer-link-group/test/a11y/ic-footer-link-group.test.a11y.js.map +1 -1
  263. package/dist/collection/components/ic-footer-link-group/test/basic/ic-footer-link-group.spec.js +52 -52
  264. package/dist/collection/components/ic-footer-link-group/test/basic/ic-footer-link-group.spec.js.map +1 -1
  265. package/dist/collection/components/ic-hero/ic-hero.js +292 -292
  266. package/dist/collection/components/ic-hero/ic-hero.js.map +1 -1
  267. package/dist/collection/components/ic-hero/test/a11y/ic-hero.test.a11y.js +5 -5
  268. package/dist/collection/components/ic-hero/test/a11y/ic-hero.test.a11y.js.map +1 -1
  269. package/dist/collection/components/ic-hero/test/basic/ic-hero.spec.js +62 -62
  270. package/dist/collection/components/ic-hero/test/basic/ic-hero.spec.js.map +1 -1
  271. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js +241 -240
  272. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js.map +1 -1
  273. package/dist/collection/components/ic-horizontal-scroll/test/a11y/ic-horizontal-scroll.test.a11y.js +17 -17
  274. package/dist/collection/components/ic-horizontal-scroll/test/a11y/ic-horizontal-scroll.test.a11y.js.map +1 -1
  275. package/dist/collection/components/ic-horizontal-scroll/test/basic/ic-horizontal-scroll.spec.js +145 -145
  276. package/dist/collection/components/ic-horizontal-scroll/test/basic/ic-horizontal-scroll.spec.js.map +1 -1
  277. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js +248 -248
  278. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js.map +1 -1
  279. package/dist/collection/components/ic-input-component-container/test/basic/ic-input-component-container.spec.js +49 -49
  280. package/dist/collection/components/ic-input-component-container/test/basic/ic-input-component-container.spec.js.map +1 -1
  281. package/dist/collection/components/ic-input-container/ic-input-container.js +62 -62
  282. package/dist/collection/components/ic-input-container/ic-input-container.js.map +1 -1
  283. package/dist/collection/components/ic-input-container/test/basic/ic-input-container.spec.js +19 -19
  284. package/dist/collection/components/ic-input-container/test/basic/ic-input-container.spec.js.map +1 -1
  285. package/dist/collection/components/ic-input-label/ic-input-label.js +211 -211
  286. package/dist/collection/components/ic-input-label/ic-input-label.js.map +1 -1
  287. package/dist/collection/components/ic-input-label/test/basic/ic-input-label.spec.js +37 -37
  288. package/dist/collection/components/ic-input-label/test/basic/ic-input-label.spec.js.map +1 -1
  289. package/dist/collection/components/ic-input-validation/ic-input-validation.js +139 -139
  290. package/dist/collection/components/ic-input-validation/ic-input-validation.js.map +1 -1
  291. package/dist/collection/components/ic-input-validation/test/basic/ic-input-validation.spec.js +31 -31
  292. package/dist/collection/components/ic-input-validation/test/basic/ic-input-validation.spec.js.map +1 -1
  293. package/dist/collection/components/ic-link/ic-link.js +248 -248
  294. package/dist/collection/components/ic-link/ic-link.js.map +1 -1
  295. package/dist/collection/components/ic-link/test/a11y/ic-link.test.a11y.js +5 -5
  296. package/dist/collection/components/ic-link/test/a11y/ic-link.test.a11y.js.map +1 -1
  297. package/dist/collection/components/ic-link/test/basic/ic-link.spec.js +92 -92
  298. package/dist/collection/components/ic-link/test/basic/ic-link.spec.js.map +1 -1
  299. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js +416 -415
  300. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js.map +1 -1
  301. package/dist/collection/components/ic-loading-indicator/test/a11y/ic-loading-indicator.test.a11y.js +5 -5
  302. package/dist/collection/components/ic-loading-indicator/test/a11y/ic-loading-indicator.test.a11y.js.map +1 -1
  303. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.e2e.js +25 -25
  304. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.e2e.js.map +1 -1
  305. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.spec.js +114 -114
  306. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.spec.js.map +1 -1
  307. package/dist/collection/components/ic-menu/ic-menu.js +1268 -1269
  308. package/dist/collection/components/ic-menu/ic-menu.js.map +1 -1
  309. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js +684 -684
  310. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js.map +1 -1
  311. package/dist/collection/components/ic-menu-group/ic-menu-group.js +41 -41
  312. package/dist/collection/components/ic-menu-group/ic-menu-group.js.map +1 -1
  313. package/dist/collection/components/ic-menu-group/test/basic/ic-menu-group.spec.js +16 -16
  314. package/dist/collection/components/ic-menu-group/test/basic/ic-menu-group.spec.js.map +1 -1
  315. package/dist/collection/components/ic-menu-item/ic-menu-item.js +378 -378
  316. package/dist/collection/components/ic-menu-item/ic-menu-item.js.map +1 -1
  317. package/dist/collection/components/ic-menu-item/test/basic/ic-menu-item.spec.js +67 -67
  318. package/dist/collection/components/ic-menu-item/test/basic/ic-menu-item.spec.js.map +1 -1
  319. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js +262 -259
  320. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js.map +1 -1
  321. package/dist/collection/components/ic-navigation-button/test/basic/ic-navigation-button.spec.js +41 -41
  322. package/dist/collection/components/ic-navigation-button/test/basic/ic-navigation-button.spec.js.map +1 -1
  323. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js +380 -380
  324. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js.map +1 -1
  325. package/dist/collection/components/ic-navigation-group/test/a11y/ic-navigation-group.test.a11y.js +14 -14
  326. package/dist/collection/components/ic-navigation-group/test/a11y/ic-navigation-group.test.a11y.js.map +1 -1
  327. package/dist/collection/components/ic-navigation-group/test/basic/ic-navigation-group.spec.js +242 -242
  328. package/dist/collection/components/ic-navigation-group/test/basic/ic-navigation-group.spec.js.map +1 -1
  329. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js +446 -446
  330. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js.map +1 -1
  331. package/dist/collection/components/ic-navigation-item/test/a11y/ic-navigation-item.test.a11y.js +14 -14
  332. package/dist/collection/components/ic-navigation-item/test/a11y/ic-navigation-item.test.a11y.js.map +1 -1
  333. package/dist/collection/components/ic-navigation-item/test/basic/ic-navigation-item.spec.js +78 -78
  334. package/dist/collection/components/ic-navigation-item/test/basic/ic-navigation-item.spec.js.map +1 -1
  335. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js +187 -187
  336. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js.map +1 -1
  337. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.e2e.js +25 -25
  338. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.e2e.js.map +1 -1
  339. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.spec.js +104 -104
  340. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.spec.js.map +1 -1
  341. package/dist/collection/components/ic-page-header/ic-page-header.js +286 -286
  342. package/dist/collection/components/ic-page-header/ic-page-header.js.map +1 -1
  343. package/dist/collection/components/ic-page-header/test/a11y/ic-page-header.test.a11y.js +5 -5
  344. package/dist/collection/components/ic-page-header/test/a11y/ic-page-header.test.a11y.js.map +1 -1
  345. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.e2e.js +66 -66
  346. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.e2e.js.map +1 -1
  347. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.spec.js +82 -82
  348. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.spec.js.map +1 -1
  349. package/dist/collection/components/ic-pagination/ic-pagination.js +487 -482
  350. package/dist/collection/components/ic-pagination/ic-pagination.js.map +1 -1
  351. package/dist/collection/components/ic-pagination/test/a11y/ic-pagination.test.a11y.js +5 -5
  352. package/dist/collection/components/ic-pagination/test/a11y/ic-pagination.test.a11y.js.map +1 -1
  353. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.e2e.js +103 -103
  354. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.e2e.js.map +1 -1
  355. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.spec.js +303 -303
  356. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.spec.js.map +1 -1
  357. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js +225 -225
  358. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js.map +1 -1
  359. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js +437 -437
  360. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js.map +1 -1
  361. package/dist/collection/components/ic-popover-menu/test/a11y/ic-popover-menu.test.a11y.js +5 -5
  362. package/dist/collection/components/ic-popover-menu/test/a11y/ic-popover-menu.test.a11y.js.map +1 -1
  363. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.e2e.js +27 -27
  364. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.e2e.js.map +1 -1
  365. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.spec.js +283 -283
  366. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.spec.js.map +1 -1
  367. package/dist/collection/components/ic-radio-group/ic-radio-group.js +429 -429
  368. package/dist/collection/components/ic-radio-group/ic-radio-group.js.map +1 -1
  369. package/dist/collection/components/ic-radio-group/test/a11y/ic-radio-group.test.a11y.js +5 -5
  370. package/dist/collection/components/ic-radio-group/test/a11y/ic-radio-group.test.a11y.js.map +1 -1
  371. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.e2e.js +218 -218
  372. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.e2e.js.map +1 -1
  373. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.spec.js +238 -238
  374. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.spec.js.map +1 -1
  375. package/dist/collection/components/ic-radio-option/ic-radio-option.css +5 -5
  376. package/dist/collection/components/ic-radio-option/ic-radio-option.js +479 -479
  377. package/dist/collection/components/ic-radio-option/ic-radio-option.js.map +1 -1
  378. package/dist/collection/components/ic-search-bar/ic-search-bar.js +1381 -1381
  379. package/dist/collection/components/ic-search-bar/ic-search-bar.js.map +1 -1
  380. package/dist/collection/components/ic-search-bar/test/a11y/ic-search-bar.test.a11y.js +5 -5
  381. package/dist/collection/components/ic-search-bar/test/a11y/ic-search-bar.test.a11y.js.map +1 -1
  382. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.e2e.js +992 -992
  383. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.e2e.js.map +1 -1
  384. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.spec.js +568 -568
  385. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.spec.js.map +1 -1
  386. package/dist/collection/components/ic-section-container/ic-section-container.js +70 -70
  387. package/dist/collection/components/ic-section-container/ic-section-container.js.map +1 -1
  388. package/dist/collection/components/ic-section-container/test/basic/ic-section-container.spec.js +28 -28
  389. package/dist/collection/components/ic-section-container/test/basic/ic-section-container.spec.js.map +1 -1
  390. package/dist/collection/components/ic-select/ic-select.js +1466 -1466
  391. package/dist/collection/components/ic-select/ic-select.js.map +1 -1
  392. package/dist/collection/components/ic-select/test/a11y/ic-select.test.a11y.js +5 -5
  393. package/dist/collection/components/ic-select/test/a11y/ic-select.test.a11y.js.map +1 -1
  394. package/dist/collection/components/ic-select/test/basic/ic-select.e2e.js +1563 -1563
  395. package/dist/collection/components/ic-select/test/basic/ic-select.e2e.js.map +1 -1
  396. package/dist/collection/components/ic-select/test/basic/ic-select.spec.js +1299 -1299
  397. package/dist/collection/components/ic-select/test/basic/ic-select.spec.js.map +1 -1
  398. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js +675 -654
  399. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js.map +1 -1
  400. package/dist/collection/components/ic-side-navigation/ic-side-navigation.types.js.map +1 -1
  401. package/dist/collection/components/ic-side-navigation/test/a11y/ic-side-navigation.test.a11y.js +5 -5
  402. package/dist/collection/components/ic-side-navigation/test/a11y/ic-side-navigation.test.a11y.js.map +1 -1
  403. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.e2e.js +463 -463
  404. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.e2e.js.map +1 -1
  405. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.spec.js +143 -143
  406. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.spec.js.map +1 -1
  407. package/dist/collection/components/ic-skeleton/ic-skeleton.js +127 -127
  408. package/dist/collection/components/ic-skeleton/ic-skeleton.js.map +1 -1
  409. package/dist/collection/components/ic-skeleton/test/a11y/ic-skeleton.test.a11y.js +5 -5
  410. package/dist/collection/components/ic-skeleton/test/a11y/ic-skeleton.test.a11y.js.map +1 -1
  411. package/dist/collection/components/ic-skeleton/test/basic/ic-skeleton.spec.js +38 -38
  412. package/dist/collection/components/ic-skeleton/test/basic/ic-skeleton.spec.js.map +1 -1
  413. package/dist/collection/components/ic-status-tag/ic-status-tag.js +194 -194
  414. package/dist/collection/components/ic-status-tag/ic-status-tag.js.map +1 -1
  415. package/dist/collection/components/ic-status-tag/test/a11y/ic-status-tag.test.a11y.js +5 -5
  416. package/dist/collection/components/ic-status-tag/test/a11y/ic-status-tag.test.a11y.js.map +1 -1
  417. package/dist/collection/components/ic-status-tag/test/basic/ic-status-tag.spec.js +14 -14
  418. package/dist/collection/components/ic-status-tag/test/basic/ic-status-tag.spec.js.map +1 -1
  419. package/dist/collection/components/ic-step/ic-step.css +6 -0
  420. package/dist/collection/components/ic-step/ic-step.js +385 -385
  421. package/dist/collection/components/ic-step/ic-step.js.map +1 -1
  422. package/dist/collection/components/ic-step/test/basic/ic-step.spec.js +87 -87
  423. package/dist/collection/components/ic-step/test/basic/ic-step.spec.js.map +1 -1
  424. package/dist/collection/components/ic-stepper/ic-stepper.js +306 -306
  425. package/dist/collection/components/ic-stepper/ic-stepper.js.map +1 -1
  426. package/dist/collection/components/ic-stepper/test/a11y/ic-stepper.test.a11y.js +10 -10
  427. package/dist/collection/components/ic-stepper/test/a11y/ic-stepper.test.a11y.js.map +1 -1
  428. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.e2e.js +36 -36
  429. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.e2e.js.map +1 -1
  430. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.spec.js +350 -350
  431. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.spec.js.map +1 -1
  432. package/dist/collection/components/ic-switch/ic-switch.js +355 -355
  433. package/dist/collection/components/ic-switch/ic-switch.js.map +1 -1
  434. package/dist/collection/components/ic-switch/test/a11y/ic-switch.test.a11y.js +5 -5
  435. package/dist/collection/components/ic-switch/test/a11y/ic-switch.test.a11y.js.map +1 -1
  436. package/dist/collection/components/ic-switch/test/basic/ic-switch.spec.js +88 -88
  437. package/dist/collection/components/ic-switch/test/basic/ic-switch.spec.js.map +1 -1
  438. package/dist/collection/components/ic-tab/ic-tab.js +350 -350
  439. package/dist/collection/components/ic-tab/ic-tab.js.map +1 -1
  440. package/dist/collection/components/ic-tab/test/basic/ic-tab.e2e.js +26 -26
  441. package/dist/collection/components/ic-tab/test/basic/ic-tab.e2e.js.map +1 -1
  442. package/dist/collection/components/ic-tab/test/basic/ic-tab.spec.js +93 -93
  443. package/dist/collection/components/ic-tab/test/basic/ic-tab.spec.js.map +1 -1
  444. package/dist/collection/components/ic-tab-context/ic-tab-context.js +442 -441
  445. package/dist/collection/components/ic-tab-context/ic-tab-context.js.map +1 -1
  446. package/dist/collection/components/ic-tab-context/test/a11y/ic-tab-context.test.a11y.js +5 -5
  447. package/dist/collection/components/ic-tab-context/test/a11y/ic-tab-context.test.a11y.js.map +1 -1
  448. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.e2e.js +213 -213
  449. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.e2e.js.map +1 -1
  450. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.spec.js +250 -250
  451. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.spec.js.map +1 -1
  452. package/dist/collection/components/ic-tab-group/ic-tab-group.js +117 -117
  453. package/dist/collection/components/ic-tab-group/ic-tab-group.js.map +1 -1
  454. package/dist/collection/components/ic-tab-panel/ic-tab-panel.css +444 -1
  455. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js +191 -191
  456. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js.map +1 -1
  457. package/dist/collection/components/ic-tab-panel/test/basic/ic-tab-panel.spec.js +29 -29
  458. package/dist/collection/components/ic-tab-panel/test/basic/ic-tab-panel.spec.js.map +1 -1
  459. package/dist/collection/components/ic-text-field/ic-text-field.js +1115 -1115
  460. package/dist/collection/components/ic-text-field/ic-text-field.js.map +1 -1
  461. package/dist/collection/components/ic-text-field/test/a11y/ic-text-field.test.a11y.js +5 -5
  462. package/dist/collection/components/ic-text-field/test/a11y/ic-text-field.test.a11y.js.map +1 -1
  463. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.e2e.js +94 -94
  464. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.e2e.js.map +1 -1
  465. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.input.spec.js +194 -194
  466. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.input.spec.js.map +1 -1
  467. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.textarea.spec.js +92 -92
  468. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.textarea.spec.js.map +1 -1
  469. package/dist/collection/components/ic-theme/ic-theme.js +99 -99
  470. package/dist/collection/components/ic-theme/ic-theme.js.map +1 -1
  471. package/dist/collection/components/ic-theme/test/basic/ic-theme.e2e.js +65 -65
  472. package/dist/collection/components/ic-theme/test/basic/ic-theme.e2e.js.map +1 -1
  473. package/dist/collection/components/ic-theme/test/basic/ic-theme.spec.js +53 -53
  474. package/dist/collection/components/ic-theme/test/basic/ic-theme.spec.js.map +1 -1
  475. package/dist/collection/components/ic-toast/ic-toast.js +368 -368
  476. package/dist/collection/components/ic-toast/ic-toast.js.map +1 -1
  477. package/dist/collection/components/ic-toast/test/a11y/ic-toast.test.a11y.js +10 -10
  478. package/dist/collection/components/ic-toast/test/a11y/ic-toast.test.a11y.js.map +1 -1
  479. package/dist/collection/components/ic-toast/test/basic/ic-toast.e2e.js +66 -66
  480. package/dist/collection/components/ic-toast/test/basic/ic-toast.e2e.js.map +1 -1
  481. package/dist/collection/components/ic-toast/test/basic/ic-toast.spec.js +180 -180
  482. package/dist/collection/components/ic-toast/test/basic/ic-toast.spec.js.map +1 -1
  483. package/dist/collection/components/ic-toast-region/ic-toast-region.js +115 -110
  484. package/dist/collection/components/ic-toast-region/ic-toast-region.js.map +1 -1
  485. package/dist/collection/components/ic-toast-region/test/basic/ic-toast-region.spec.js +58 -58
  486. package/dist/collection/components/ic-toast-region/test/basic/ic-toast-region.spec.js.map +1 -1
  487. package/dist/collection/components/ic-tooltip/ic-tooltip.js +347 -329
  488. package/dist/collection/components/ic-tooltip/ic-tooltip.js.map +1 -1
  489. package/dist/collection/components/ic-tooltip/test/a11y/ic-tooltip.test.a11y.js +5 -5
  490. package/dist/collection/components/ic-tooltip/test/a11y/ic-tooltip.test.a11y.js.map +1 -1
  491. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.e2e.js +105 -105
  492. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.e2e.js.map +1 -1
  493. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.spec.js +276 -276
  494. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.spec.js.map +1 -1
  495. package/dist/collection/components/ic-top-navigation/ic-top-navigation.css +0 -4
  496. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js +431 -418
  497. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js.map +1 -1
  498. package/dist/collection/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.js +20 -20
  499. package/dist/collection/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.js.map +1 -1
  500. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.e2e.js +43 -43
  501. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.e2e.js.map +1 -1
  502. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.mobile.e2e.js +191 -191
  503. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.mobile.e2e.js.map +1 -1
  504. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.spec.js +180 -180
  505. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.spec.js.map +1 -1
  506. package/dist/collection/components/ic-typography/ic-typography.js +270 -270
  507. package/dist/collection/components/ic-typography/ic-typography.js.map +1 -1
  508. package/dist/collection/components/ic-typography/test/a11y/ic-typography.test.a11y.js +5 -5
  509. package/dist/collection/components/ic-typography/test/a11y/ic-typography.test.a11y.js.map +1 -1
  510. package/dist/collection/components/ic-typography/test/basic/ic-typography.e2e.js +25 -25
  511. package/dist/collection/components/ic-typography/test/basic/ic-typography.e2e.js.map +1 -1
  512. package/dist/collection/components/ic-typography/test/basic/ic-typography.spec.js +276 -276
  513. package/dist/collection/components/ic-typography/test/basic/ic-typography.spec.js.map +1 -1
  514. package/dist/collection/testspec.setup.js +32 -32
  515. package/dist/collection/testspec.setup.js.map +1 -1
  516. package/dist/collection/utils/constants.js +55 -55
  517. package/dist/collection/utils/constants.js.map +1 -1
  518. package/dist/collection/utils/helpers.js +235 -235
  519. package/dist/collection/utils/helpers.js.map +1 -1
  520. package/dist/collection/utils/testa11y.helpers.js +2 -2
  521. package/dist/collection/utils/testa11y.helpers.js.map +1 -1
  522. package/dist/collection/utils/types.js +6 -6
  523. package/dist/collection/utils/types.js.map +1 -1
  524. package/dist/components/helpers.js +290 -290
  525. package/dist/components/helpers.js.map +1 -1
  526. package/dist/components/ic-accordion-group.d.ts +2 -2
  527. package/dist/components/ic-accordion-group.js +112 -112
  528. package/dist/components/ic-accordion-group.js.map +1 -1
  529. package/dist/components/ic-accordion.d.ts +2 -2
  530. package/dist/components/ic-accordion.js +125 -125
  531. package/dist/components/ic-accordion.js.map +1 -1
  532. package/dist/components/ic-alert.d.ts +2 -2
  533. package/dist/components/ic-alert2.js +98 -98
  534. package/dist/components/ic-alert2.js.map +1 -1
  535. package/dist/components/ic-back-to-top.d.ts +2 -2
  536. package/dist/components/ic-back-to-top.js +143 -143
  537. package/dist/components/ic-back-to-top.js.map +1 -1
  538. package/dist/components/ic-badge.d.ts +2 -2
  539. package/dist/components/ic-badge.js +174 -174
  540. package/dist/components/ic-badge.js.map +1 -1
  541. package/dist/components/ic-breadcrumb-group.d.ts +2 -2
  542. package/dist/components/ic-breadcrumb-group.js +199 -192
  543. package/dist/components/ic-breadcrumb-group.js.map +1 -1
  544. package/dist/components/ic-breadcrumb.d.ts +2 -2
  545. package/dist/components/ic-breadcrumb2.js +78 -75
  546. package/dist/components/ic-breadcrumb2.js.map +1 -1
  547. package/dist/components/ic-button.d.ts +2 -2
  548. package/dist/components/ic-button2.js +312 -304
  549. package/dist/components/ic-button2.js.map +1 -1
  550. package/dist/components/ic-card.d.ts +2 -2
  551. package/dist/components/ic-card.js +155 -155
  552. package/dist/components/ic-card.js.map +1 -1
  553. package/dist/components/ic-checkbox-group.d.ts +2 -2
  554. package/dist/components/ic-checkbox-group.js +97 -97
  555. package/dist/components/ic-checkbox-group.js.map +1 -1
  556. package/dist/components/ic-checkbox.d.ts +2 -2
  557. package/dist/components/ic-checkbox.js +131 -131
  558. package/dist/components/ic-checkbox.js.map +1 -1
  559. package/dist/components/ic-chip.d.ts +2 -2
  560. package/dist/components/ic-chip.js +99 -96
  561. package/dist/components/ic-chip.js.map +1 -1
  562. package/dist/components/ic-classification-banner.d.ts +2 -2
  563. package/dist/components/ic-classification-banner.js +47 -47
  564. package/dist/components/ic-classification-banner.js.map +1 -1
  565. package/dist/components/ic-data-entity.d.ts +2 -2
  566. package/dist/components/ic-data-entity.js +39 -39
  567. package/dist/components/ic-data-entity.js.map +1 -1
  568. package/dist/components/ic-data-row.d.ts +2 -2
  569. package/dist/components/ic-data-row.js +97 -97
  570. package/dist/components/ic-data-row.js.map +1 -1
  571. package/dist/components/ic-dialog.d.ts +2 -2
  572. package/dist/components/ic-dialog.js +399 -399
  573. package/dist/components/ic-dialog.js.map +1 -1
  574. package/dist/components/ic-divider.d.ts +2 -2
  575. package/dist/components/ic-divider2.js +28 -28
  576. package/dist/components/ic-divider2.js.map +1 -1
  577. package/dist/components/ic-empty-state.d.ts +2 -2
  578. package/dist/components/ic-empty-state.js +47 -47
  579. package/dist/components/ic-empty-state.js.map +1 -1
  580. package/dist/components/ic-footer-link-group.d.ts +2 -2
  581. package/dist/components/ic-footer-link-group.js +82 -82
  582. package/dist/components/ic-footer-link-group.js.map +1 -1
  583. package/dist/components/ic-footer-link.d.ts +2 -2
  584. package/dist/components/ic-footer-link.js +71 -71
  585. package/dist/components/ic-footer-link.js.map +1 -1
  586. package/dist/components/ic-footer.d.ts +2 -2
  587. package/dist/components/ic-footer.js +108 -108
  588. package/dist/components/ic-footer.js.map +1 -1
  589. package/dist/components/ic-hero.d.ts +2 -2
  590. package/dist/components/ic-hero.js +98 -98
  591. package/dist/components/ic-hero.js.map +1 -1
  592. package/dist/components/ic-horizontal-scroll.d.ts +2 -2
  593. package/dist/components/ic-horizontal-scroll2.js +189 -189
  594. package/dist/components/ic-horizontal-scroll2.js.map +1 -1
  595. package/dist/components/ic-input-component-container.d.ts +2 -2
  596. package/dist/components/ic-input-component-container2.js +61 -61
  597. package/dist/components/ic-input-component-container2.js.map +1 -1
  598. package/dist/components/ic-input-container.d.ts +2 -2
  599. package/dist/components/ic-input-container2.js +28 -28
  600. package/dist/components/ic-input-container2.js.map +1 -1
  601. package/dist/components/ic-input-label.d.ts +2 -2
  602. package/dist/components/ic-input-label2.js +62 -62
  603. package/dist/components/ic-input-label2.js.map +1 -1
  604. package/dist/components/ic-input-validation.d.ts +2 -2
  605. package/dist/components/ic-input-validation2.js +50 -50
  606. package/dist/components/ic-input-validation2.js.map +1 -1
  607. package/dist/components/ic-link.d.ts +2 -2
  608. package/dist/components/ic-link2.js +76 -76
  609. package/dist/components/ic-link2.js.map +1 -1
  610. package/dist/components/ic-loading-indicator.d.ts +2 -2
  611. package/dist/components/ic-loading-indicator2.js +211 -210
  612. package/dist/components/ic-loading-indicator2.js.map +1 -1
  613. package/dist/components/ic-menu-group.d.ts +2 -2
  614. package/dist/components/ic-menu-group.js +30 -30
  615. package/dist/components/ic-menu-group.js.map +1 -1
  616. package/dist/components/ic-menu-item.d.ts +2 -2
  617. package/dist/components/ic-menu-item2.js +144 -144
  618. package/dist/components/ic-menu-item2.js.map +1 -1
  619. package/dist/components/ic-menu.d.ts +2 -2
  620. package/dist/components/ic-menu2.js +691 -691
  621. package/dist/components/ic-menu2.js.map +1 -1
  622. package/dist/components/ic-navigation-button.d.ts +2 -2
  623. package/dist/components/ic-navigation-button.js +121 -118
  624. package/dist/components/ic-navigation-button.js.map +1 -1
  625. package/dist/components/ic-navigation-group.d.ts +2 -2
  626. package/dist/components/ic-navigation-group.js +310 -310
  627. package/dist/components/ic-navigation-group.js.map +1 -1
  628. package/dist/components/ic-navigation-item.d.ts +2 -2
  629. package/dist/components/ic-navigation-item.js +194 -194
  630. package/dist/components/ic-navigation-item.js.map +1 -1
  631. package/dist/components/ic-navigation-menu.d.ts +2 -2
  632. package/dist/components/ic-navigation-menu2.js +139 -139
  633. package/dist/components/ic-navigation-menu2.js.map +1 -1
  634. package/dist/components/ic-page-header.d.ts +2 -2
  635. package/dist/components/ic-page-header.js +147 -147
  636. package/dist/components/ic-page-header.js.map +1 -1
  637. package/dist/components/ic-pagination-item.d.ts +2 -2
  638. package/dist/components/ic-pagination-item2.js +67 -67
  639. package/dist/components/ic-pagination-item2.js.map +1 -1
  640. package/dist/components/ic-pagination.d.ts +2 -2
  641. package/dist/components/ic-pagination.js +253 -252
  642. package/dist/components/ic-pagination.js.map +1 -1
  643. package/dist/components/ic-popover-menu.d.ts +2 -2
  644. package/dist/components/ic-popover-menu.js +280 -280
  645. package/dist/components/ic-popover-menu.js.map +1 -1
  646. package/dist/components/ic-radio-group.d.ts +2 -2
  647. package/dist/components/ic-radio-group.js +200 -200
  648. package/dist/components/ic-radio-group.js.map +1 -1
  649. package/dist/components/ic-radio-option.d.ts +2 -2
  650. package/dist/components/ic-radio-option.js +163 -163
  651. package/dist/components/ic-radio-option.js.map +1 -1
  652. package/dist/components/ic-search-bar.d.ts +2 -2
  653. package/dist/components/ic-search-bar.js +580 -580
  654. package/dist/components/ic-search-bar.js.map +1 -1
  655. package/dist/components/ic-section-container.d.ts +2 -2
  656. package/dist/components/ic-section-container2.js +31 -31
  657. package/dist/components/ic-section-container2.js.map +1 -1
  658. package/dist/components/ic-select.d.ts +2 -2
  659. package/dist/components/ic-select.js +751 -751
  660. package/dist/components/ic-select.js.map +1 -1
  661. package/dist/components/ic-side-navigation.d.ts +2 -2
  662. package/dist/components/ic-side-navigation.js +479 -481
  663. package/dist/components/ic-side-navigation.js.map +1 -1
  664. package/dist/components/ic-skeleton.d.ts +2 -2
  665. package/dist/components/ic-skeleton.js +64 -64
  666. package/dist/components/ic-skeleton.js.map +1 -1
  667. package/dist/components/ic-status-tag.d.ts +2 -2
  668. package/dist/components/ic-status-tag.js +53 -53
  669. package/dist/components/ic-status-tag.js.map +1 -1
  670. package/dist/components/ic-step.d.ts +2 -2
  671. package/dist/components/ic-step.js +157 -157
  672. package/dist/components/ic-step.js.map +1 -1
  673. package/dist/components/ic-stepper.d.ts +2 -2
  674. package/dist/components/ic-stepper.js +223 -223
  675. package/dist/components/ic-stepper.js.map +1 -1
  676. package/dist/components/ic-switch.d.ts +2 -2
  677. package/dist/components/ic-switch.js +114 -114
  678. package/dist/components/ic-switch.js.map +1 -1
  679. package/dist/components/ic-tab-context.d.ts +2 -2
  680. package/dist/components/ic-tab-context.js +271 -271
  681. package/dist/components/ic-tab-context.js.map +1 -1
  682. package/dist/components/ic-tab-group.d.ts +2 -2
  683. package/dist/components/ic-tab-group.js +64 -64
  684. package/dist/components/ic-tab-group.js.map +1 -1
  685. package/dist/components/ic-tab-panel.d.ts +2 -2
  686. package/dist/components/ic-tab-panel.js +48 -48
  687. package/dist/components/ic-tab-panel.js.map +1 -1
  688. package/dist/components/ic-tab.d.ts +2 -2
  689. package/dist/components/ic-tab.js +112 -112
  690. package/dist/components/ic-tab.js.map +1 -1
  691. package/dist/components/ic-text-field.d.ts +2 -2
  692. package/dist/components/ic-text-field2.js +293 -293
  693. package/dist/components/ic-text-field2.js.map +1 -1
  694. package/dist/components/ic-theme.d.ts +2 -2
  695. package/dist/components/ic-theme.js +65 -65
  696. package/dist/components/ic-theme.js.map +1 -1
  697. package/dist/components/ic-toast-region.d.ts +2 -2
  698. package/dist/components/ic-toast-region.js +63 -62
  699. package/dist/components/ic-toast-region.js.map +1 -1
  700. package/dist/components/ic-toast.d.ts +2 -2
  701. package/dist/components/ic-toast.js +187 -187
  702. package/dist/components/ic-toast.js.map +1 -1
  703. package/dist/components/ic-tooltip.d.ts +2 -2
  704. package/dist/components/ic-tooltip2.js +213 -211
  705. package/dist/components/ic-tooltip2.js.map +1 -1
  706. package/dist/components/ic-top-navigation.d.ts +2 -2
  707. package/dist/components/ic-top-navigation.js +263 -264
  708. package/dist/components/ic-top-navigation.js.map +1 -1
  709. package/dist/components/ic-typography.d.ts +2 -2
  710. package/dist/components/ic-typography2.js +142 -142
  711. package/dist/components/ic-typography2.js.map +1 -1
  712. package/dist/components/types.js +6 -6
  713. package/dist/components/types.js.map +1 -1
  714. package/dist/core/core.css +1 -1
  715. package/dist/core/core.esm.js +1 -1
  716. package/dist/core/core.esm.js.map +1 -1
  717. package/dist/core/p-02159742.entry.js +2 -0
  718. package/dist/core/p-02159742.entry.js.map +1 -0
  719. package/dist/core/{p-7ce86152.entry.js → p-056f8a67.entry.js} +2 -2
  720. package/dist/core/{p-08b59078.entry.js → p-11736fbe.entry.js} +2 -2
  721. package/dist/core/{p-ba495175.entry.js → p-15466b42.entry.js} +2 -2
  722. package/dist/core/{p-ba495175.entry.js.map → p-15466b42.entry.js.map} +1 -1
  723. package/dist/core/{p-5ccbb042.entry.js → p-15624e08.entry.js} +2 -2
  724. package/dist/core/{p-5fcd202e.entry.js → p-15ef0674.entry.js} +2 -2
  725. package/dist/core/{p-88ea1e49.entry.js → p-180e36b1.entry.js} +2 -2
  726. package/dist/core/{p-43af3cf6.entry.js → p-22c024ee.entry.js} +2 -2
  727. package/dist/core/{p-613aa265.js → p-26b7b18f.js} +1 -1
  728. package/dist/core/{p-932fb4b7.entry.js → p-287ab47c.entry.js} +2 -2
  729. package/dist/core/{p-69948c3e.entry.js → p-2b24b4bf.entry.js} +2 -2
  730. package/dist/core/{p-9f6ffced.entry.js → p-31969be6.entry.js} +2 -2
  731. package/dist/core/{p-475b7bd2.entry.js → p-335fc5e4.entry.js} +2 -2
  732. package/dist/core/{p-c9ef9f5c.entry.js → p-366bcb17.entry.js} +2 -2
  733. package/dist/core/{p-ed256f1d.entry.js → p-3a0ef91e.entry.js} +2 -2
  734. package/dist/core/{p-ca6073be.entry.js → p-498eb7ad.entry.js} +2 -2
  735. package/dist/core/p-498eb7ad.entry.js.map +1 -0
  736. package/dist/core/{p-cb5f19ea.entry.js → p-51f9f329.entry.js} +2 -2
  737. package/dist/core/{p-f019219c.entry.js → p-529d8955.entry.js} +2 -2
  738. package/dist/core/p-52e063d3.js +3 -0
  739. package/dist/core/p-52e063d3.js.map +1 -0
  740. package/dist/core/{p-b879fa3e.entry.js → p-5c7e339f.entry.js} +2 -2
  741. package/dist/core/p-5f9d69ef.entry.js +2 -0
  742. package/dist/core/p-5f9d69ef.entry.js.map +1 -0
  743. package/dist/core/{p-2c30b583.entry.js → p-60c4604f.entry.js} +2 -2
  744. package/dist/core/{p-99fad66b.entry.js → p-6bc431b2.entry.js} +2 -2
  745. package/dist/core/{p-ccac1730.entry.js → p-6d3f9501.entry.js} +2 -2
  746. package/dist/core/{p-536b3c97.entry.js → p-6eb0421d.entry.js} +2 -2
  747. package/dist/core/{p-48525498.entry.js → p-765bdd98.entry.js} +2 -2
  748. package/dist/core/{p-3a814fc4.entry.js → p-7f887c1e.entry.js} +2 -2
  749. package/dist/core/{p-752f0f9a.entry.js → p-8a83f391.entry.js} +2 -2
  750. package/dist/core/p-8a83f391.entry.js.map +1 -0
  751. package/dist/core/{p-e3bffcae.entry.js → p-94e88827.entry.js} +2 -2
  752. package/dist/core/{p-8fb4f0c0.js → p-95a864bf.js} +2 -2
  753. package/dist/core/{p-c0c62df4.entry.js → p-9639e33f.entry.js} +2 -2
  754. package/dist/core/p-9639e33f.entry.js.map +1 -0
  755. package/dist/core/{p-eb4641a9.entry.js → p-96da1e85.entry.js} +2 -2
  756. package/dist/core/{p-69d15528.entry.js → p-988991d3.entry.js} +2 -2
  757. package/dist/core/{p-0c82048e.entry.js → p-9c30720d.entry.js} +2 -2
  758. package/dist/core/{p-a76912b0.entry.js → p-aa0a9870.entry.js} +2 -2
  759. package/dist/core/{p-76563540.entry.js → p-ad36a704.entry.js} +2 -2
  760. package/dist/core/{p-d80f99e0.entry.js → p-b0088956.entry.js} +2 -2
  761. package/dist/core/p-b39ecae2.entry.js +2 -0
  762. package/dist/core/p-b39ecae2.entry.js.map +1 -0
  763. package/dist/core/{p-2265e418.entry.js → p-b6a575c3.entry.js} +2 -2
  764. package/dist/core/{p-fbc8a739.entry.js → p-b9736cf4.entry.js} +2 -2
  765. package/dist/core/{p-025f9d2a.entry.js → p-b99f9e89.entry.js} +2 -2
  766. package/dist/core/{p-b0ce60a0.entry.js → p-c2452388.entry.js} +2 -2
  767. package/dist/core/{p-345fe84a.entry.js → p-c770e7a2.entry.js} +2 -2
  768. package/dist/core/p-ca178add.entry.js +2 -0
  769. package/dist/core/p-ca178add.entry.js.map +1 -0
  770. package/dist/core/{p-748159fe.entry.js → p-ca48e97a.entry.js} +2 -2
  771. package/dist/core/{p-5a3ca50a.entry.js → p-cd8de4c5.entry.js} +2 -2
  772. package/dist/core/{p-a4397df4.entry.js → p-cfc930f6.entry.js} +2 -2
  773. package/dist/core/{p-3a15202f.entry.js → p-d18450f9.entry.js} +2 -2
  774. package/dist/core/p-d18450f9.entry.js.map +1 -0
  775. package/dist/core/p-daebb58a.entry.js +2 -0
  776. package/dist/core/p-daebb58a.entry.js.map +1 -0
  777. package/dist/core/p-dbb5b008.entry.js +2 -0
  778. package/dist/core/p-dbb5b008.entry.js.map +1 -0
  779. package/dist/core/{p-4bc35224.entry.js → p-e278242f.entry.js} +2 -2
  780. package/dist/core/p-e278242f.entry.js.map +1 -0
  781. package/dist/core/{p-9ff57f09.entry.js → p-e5abfadd.entry.js} +2 -2
  782. package/dist/core/{p-41c6eaa1.entry.js → p-e9738c74.entry.js} +2 -2
  783. package/dist/core/p-ea17e371.entry.js +2 -0
  784. package/dist/core/p-ea17e371.entry.js.map +1 -0
  785. package/dist/core/{p-e2fd542e.entry.js → p-edd29edc.entry.js} +2 -2
  786. package/dist/core/p-edec0936.entry.js +2 -0
  787. package/dist/core/p-edec0936.entry.js.map +1 -0
  788. package/dist/core/{p-657513b5.entry.js → p-ee97e2a5.entry.js} +2 -2
  789. package/dist/core/{p-8b18346a.entry.js → p-f0809037.entry.js} +2 -2
  790. package/dist/core/{p-5bb6c79b.entry.js → p-f2e6b9ef.entry.js} +2 -2
  791. package/dist/core/{p-cf4bacee.entry.js → p-fdb4b48f.entry.js} +2 -2
  792. package/dist/esm/core.js +4 -4
  793. package/dist/esm/core.js.map +1 -1
  794. package/dist/esm/{helpers-24f6e762.js → helpers-c597f246.js} +292 -292
  795. package/dist/esm/helpers-c597f246.js.map +1 -0
  796. package/dist/esm/ic-accordion-group.entry.js +71 -71
  797. package/dist/esm/ic-accordion-group.entry.js.map +1 -1
  798. package/dist/esm/ic-accordion.entry.js +99 -99
  799. package/dist/esm/ic-accordion.entry.js.map +1 -1
  800. package/dist/esm/ic-alert.entry.js +58 -58
  801. package/dist/esm/ic-alert.entry.js.map +1 -1
  802. package/dist/esm/ic-back-to-top.entry.js +120 -120
  803. package/dist/esm/ic-back-to-top.entry.js.map +1 -1
  804. package/dist/esm/ic-badge.entry.js +146 -146
  805. package/dist/esm/ic-badge.entry.js.map +1 -1
  806. package/dist/esm/ic-breadcrumb-group.entry.js +172 -166
  807. package/dist/esm/ic-breadcrumb-group.entry.js.map +1 -1
  808. package/dist/esm/ic-breadcrumb.entry.js +55 -53
  809. package/dist/esm/ic-breadcrumb.entry.js.map +1 -1
  810. package/dist/esm/ic-button_3.entry.js +615 -606
  811. package/dist/esm/ic-button_3.entry.js.map +1 -1
  812. package/dist/esm/ic-card.entry.js +105 -105
  813. package/dist/esm/ic-card.entry.js.map +1 -1
  814. package/dist/esm/ic-checkbox-group.entry.js +60 -60
  815. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  816. package/dist/esm/ic-checkbox.entry.js +95 -95
  817. package/dist/esm/ic-checkbox.entry.js.map +1 -1
  818. package/dist/esm/ic-chip.entry.js +67 -65
  819. package/dist/esm/ic-chip.entry.js.map +1 -1
  820. package/dist/esm/ic-classification-banner.entry.js +23 -23
  821. package/dist/esm/ic-classification-banner.entry.js.map +1 -1
  822. package/dist/esm/ic-data-entity.entry.js +17 -17
  823. package/dist/esm/ic-data-entity.entry.js.map +1 -1
  824. package/dist/esm/ic-data-row.entry.js +74 -74
  825. package/dist/esm/ic-data-row.entry.js.map +1 -1
  826. package/dist/esm/ic-dialog.entry.js +339 -339
  827. package/dist/esm/ic-dialog.entry.js.map +1 -1
  828. package/dist/esm/ic-divider.entry.js +16 -16
  829. package/dist/esm/ic-divider.entry.js.map +1 -1
  830. package/dist/esm/ic-empty-state.entry.js +24 -24
  831. package/dist/esm/ic-empty-state.entry.js.map +1 -1
  832. package/dist/esm/ic-footer-link-group.entry.js +55 -55
  833. package/dist/esm/ic-footer-link-group.entry.js.map +1 -1
  834. package/dist/esm/ic-footer-link.entry.js +50 -50
  835. package/dist/esm/ic-footer-link.entry.js.map +1 -1
  836. package/dist/esm/ic-footer.entry.js +78 -78
  837. package/dist/esm/ic-footer.entry.js.map +1 -1
  838. package/dist/esm/ic-hero.entry.js +62 -62
  839. package/dist/esm/ic-hero.entry.js.map +1 -1
  840. package/dist/esm/ic-horizontal-scroll.entry.js +151 -151
  841. package/dist/esm/ic-horizontal-scroll.entry.js.map +1 -1
  842. package/dist/esm/ic-input-component-container_3.entry.js +678 -678
  843. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -1
  844. package/dist/esm/ic-input-label_2.entry.js +63 -63
  845. package/dist/esm/ic-input-label_2.entry.js.map +1 -1
  846. package/dist/esm/ic-link.entry.js +55 -55
  847. package/dist/esm/ic-link.entry.js.map +1 -1
  848. package/dist/esm/ic-menu-group.entry.js +12 -12
  849. package/dist/esm/ic-menu-group.entry.js.map +1 -1
  850. package/dist/esm/ic-menu-item.entry.js +100 -100
  851. package/dist/esm/ic-menu-item.entry.js.map +1 -1
  852. package/dist/esm/ic-navigation-button.entry.js +79 -76
  853. package/dist/esm/ic-navigation-button.entry.js.map +1 -1
  854. package/dist/esm/ic-navigation-group.entry.js +283 -283
  855. package/dist/esm/ic-navigation-group.entry.js.map +1 -1
  856. package/dist/esm/ic-navigation-item.entry.js +152 -152
  857. package/dist/esm/ic-navigation-item.entry.js.map +1 -1
  858. package/dist/esm/ic-navigation-menu.entry.js +105 -105
  859. package/dist/esm/ic-navigation-menu.entry.js.map +1 -1
  860. package/dist/esm/ic-page-header.entry.js +93 -93
  861. package/dist/esm/ic-page-header.entry.js.map +1 -1
  862. package/dist/esm/ic-pagination-item.entry.js +42 -42
  863. package/dist/esm/ic-pagination-item.entry.js.map +1 -1
  864. package/dist/esm/ic-pagination.entry.js +196 -195
  865. package/dist/esm/ic-pagination.entry.js.map +1 -1
  866. package/dist/esm/ic-popover-menu.entry.js +231 -231
  867. package/dist/esm/ic-popover-menu.entry.js.map +1 -1
  868. package/dist/esm/ic-radio-group.entry.js +156 -156
  869. package/dist/esm/ic-radio-group.entry.js.map +1 -1
  870. package/dist/esm/ic-radio-option.entry.js +128 -128
  871. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  872. package/dist/esm/ic-search-bar.entry.js +474 -474
  873. package/dist/esm/ic-search-bar.entry.js.map +1 -1
  874. package/dist/esm/ic-section-container.entry.js +15 -15
  875. package/dist/esm/ic-section-container.entry.js.map +1 -1
  876. package/dist/esm/ic-select.entry.js +639 -639
  877. package/dist/esm/ic-select.entry.js.map +1 -1
  878. package/dist/esm/ic-side-navigation.entry.js +424 -426
  879. package/dist/esm/ic-side-navigation.entry.js.map +1 -1
  880. package/dist/esm/ic-skeleton.entry.js +43 -43
  881. package/dist/esm/ic-skeleton.entry.js.map +1 -1
  882. package/dist/esm/ic-status-tag.entry.js +29 -29
  883. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  884. package/dist/esm/ic-step.entry.js +121 -121
  885. package/dist/esm/ic-step.entry.js.map +1 -1
  886. package/dist/esm/ic-stepper.entry.js +200 -200
  887. package/dist/esm/ic-stepper.entry.js.map +1 -1
  888. package/dist/esm/ic-switch.entry.js +77 -77
  889. package/dist/esm/ic-switch.entry.js.map +1 -1
  890. package/dist/esm/ic-tab-context.entry.js +252 -252
  891. package/dist/esm/ic-tab-context.entry.js.map +1 -1
  892. package/dist/esm/ic-tab-group.entry.js +23 -23
  893. package/dist/esm/ic-tab-group.entry.js.map +1 -1
  894. package/dist/esm/ic-tab-panel.entry.js +31 -31
  895. package/dist/esm/ic-tab-panel.entry.js.map +1 -1
  896. package/dist/esm/ic-tab.entry.js +86 -86
  897. package/dist/esm/ic-tab.entry.js.map +1 -1
  898. package/dist/esm/ic-text-field.entry.js +210 -210
  899. package/dist/esm/ic-text-field.entry.js.map +1 -1
  900. package/dist/esm/ic-theme.entry.js +51 -51
  901. package/dist/esm/ic-theme.entry.js.map +1 -1
  902. package/dist/esm/ic-toast-region.entry.js +47 -46
  903. package/dist/esm/ic-toast-region.entry.js.map +1 -1
  904. package/dist/esm/ic-toast.entry.js +145 -145
  905. package/dist/esm/ic-toast.entry.js.map +1 -1
  906. package/dist/esm/ic-top-navigation.entry.js +198 -199
  907. package/dist/esm/ic-top-navigation.entry.js.map +1 -1
  908. package/dist/esm/ic-typography.entry.js +118 -118
  909. package/dist/esm/ic-typography.entry.js.map +1 -1
  910. package/dist/{cjs/index-4f8c900f.js → esm/index-05003e1c.js} +603 -407
  911. package/dist/esm/index-05003e1c.js.map +1 -0
  912. package/dist/esm/loader.js +3 -3
  913. package/dist/esm/types-6f6b41a5.js +16 -0
  914. package/dist/esm/{types-b2398b37.js.map → types-6f6b41a5.js.map} +1 -1
  915. package/dist/node.d.ts +12 -0
  916. package/dist/types/components/ic-accordion/ic-accordion.d.ts +48 -48
  917. package/dist/types/components/ic-accordion-group/ic-accordion-group.d.ts +30 -30
  918. package/dist/types/components/ic-alert/ic-alert.d.ts +40 -40
  919. package/dist/types/components/ic-back-to-top/ic-back-to-top.d.ts +23 -23
  920. package/dist/types/components/ic-badge/ic-badge.d.ts +57 -57
  921. package/dist/types/components/ic-breadcrumb/ic-breadcrumb.d.ts +30 -25
  922. package/dist/types/components/ic-breadcrumb-group/ic-breadcrumb-group.d.ts +43 -38
  923. package/dist/types/components/ic-button/ic-button.d.ts +142 -137
  924. package/dist/types/components/ic-card/ic-card.d.ts +68 -68
  925. package/dist/types/components/ic-checkbox/ic-checkbox.d.ts +91 -91
  926. package/dist/types/components/ic-checkbox-group/ic-checkbox-group.d.ts +50 -50
  927. package/dist/types/components/ic-checkbox-group/ic-checkbox-group.types.d.ts +6 -6
  928. package/dist/types/components/ic-chip/ic-chip.d.ts +50 -46
  929. package/dist/types/components/ic-classification-banner/ic-classification-banner.d.ts +21 -21
  930. package/dist/types/components/ic-data-entity/ic-data-entity.d.ts +14 -14
  931. package/dist/types/components/ic-data-row/ic-data-row.d.ts +34 -34
  932. package/dist/types/components/ic-dialog/ic-dialog.d.ts +139 -139
  933. package/dist/types/components/ic-divider/ic-divider.d.ts +3 -3
  934. package/dist/types/components/ic-empty-state/ic-empty-state.d.ts +27 -27
  935. package/dist/types/components/ic-footer/ic-footer.d.ts +41 -41
  936. package/dist/types/components/ic-footer-link/ic-footer-link.d.ts +35 -35
  937. package/dist/types/components/ic-footer-link-group/ic-footer-link-group.d.ts +17 -17
  938. package/dist/types/components/ic-hero/ic-hero.d.ts +51 -51
  939. package/dist/types/components/ic-horizontal-scroll/ic-horizontal-scroll.d.ts +41 -41
  940. package/dist/types/components/ic-input-component-container/ic-input-component-container.d.ts +42 -42
  941. package/dist/types/components/ic-input-container/ic-input-container.d.ts +9 -9
  942. package/dist/types/components/ic-input-label/ic-input-label.d.ts +38 -38
  943. package/dist/types/components/ic-input-validation/ic-input-validation.d.ts +23 -23
  944. package/dist/types/components/ic-link/ic-link.d.ts +44 -44
  945. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.d.ts +76 -76
  946. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.types.d.ts +3 -3
  947. package/dist/types/components/ic-menu/ic-menu.d.ts +183 -183
  948. package/dist/types/components/ic-menu/ic-menu.types.d.ts +6 -6
  949. package/dist/types/components/ic-menu-group/ic-menu-group.d.ts +6 -6
  950. package/dist/types/components/ic-menu-item/ic-menu-item.d.ts +66 -66
  951. package/dist/types/components/ic-navigation-button/ic-navigation-button.d.ts +47 -47
  952. package/dist/types/components/ic-navigation-group/ic-navigation-group.d.ts +62 -62
  953. package/dist/types/components/ic-navigation-item/ic-navigation-item.d.ts +80 -80
  954. package/dist/types/components/ic-navigation-menu/ic-navigation-menu.d.ts +29 -29
  955. package/dist/types/components/ic-page-header/ic-page-header.d.ts +48 -48
  956. package/dist/types/components/ic-pagination/ic-pagination.d.ts +78 -77
  957. package/dist/types/components/ic-pagination/ic-pagination.types.d.ts +1 -1
  958. package/dist/types/components/ic-pagination-item/ic-pagination-item.d.ts +42 -42
  959. package/dist/types/components/ic-popover-menu/ic-popover-menu.d.ts +60 -60
  960. package/dist/types/components/ic-radio-group/ic-radio-group.d.ts +67 -67
  961. package/dist/types/components/ic-radio-group/ic-radio-group.types.d.ts +5 -5
  962. package/dist/types/components/ic-radio-option/ic-radio-option.d.ts +89 -89
  963. package/dist/types/components/ic-search-bar/ic-search-bar.d.ts +248 -248
  964. package/dist/types/components/ic-search-bar/ic-search-bar.types.d.ts +1 -1
  965. package/dist/types/components/ic-section-container/ic-section-container.d.ts +9 -9
  966. package/dist/types/components/ic-select/ic-select.d.ts +269 -269
  967. package/dist/types/components/ic-side-navigation/ic-side-navigation.d.ts +103 -97
  968. package/dist/types/components/ic-side-navigation/ic-side-navigation.types.d.ts +10 -6
  969. package/dist/types/components/ic-skeleton/ic-skeleton.d.ts +19 -19
  970. package/dist/types/components/ic-status-tag/ic-status-tag.d.ts +31 -31
  971. package/dist/types/components/ic-step/ic-step.d.ts +51 -51
  972. package/dist/types/components/ic-stepper/ic-stepper.d.ts +40 -40
  973. package/dist/types/components/ic-switch/ic-switch.d.ts +73 -73
  974. package/dist/types/components/ic-switch/ic-switch.types.d.ts +2 -2
  975. package/dist/types/components/ic-tab/ic-tab.d.ts +51 -51
  976. package/dist/types/components/ic-tab/ic-tab.types.d.ts +4 -4
  977. package/dist/types/components/ic-tab-context/ic-tab-context.d.ts +59 -59
  978. package/dist/types/components/ic-tab-group/ic-tab-group.d.ts +19 -19
  979. package/dist/types/components/ic-tab-panel/ic-tab-panel.d.ts +33 -33
  980. package/dist/types/components/ic-text-field/ic-text-field.d.ts +214 -214
  981. package/dist/types/components/ic-theme/ic-theme.d.ts +14 -14
  982. package/dist/types/components/ic-toast/ic-toast.d.ts +58 -58
  983. package/dist/types/components/ic-toast-region/ic-toast-region.d.ts +16 -15
  984. package/dist/types/components/ic-tooltip/ic-tooltip.d.ts +54 -50
  985. package/dist/types/components/ic-top-navigation/ic-top-navigation.d.ts +77 -72
  986. package/dist/types/components/ic-typography/ic-typography.d.ts +54 -54
  987. package/dist/types/components.d.ts +397 -3
  988. package/dist/types/stencil-public-runtime.d.ts +29 -0
  989. package/dist/types/testspec.setup.d.ts +7 -7
  990. package/dist/types/utils/constants.d.ts +26 -26
  991. package/dist/types/utils/helpers.d.ts +7 -7
  992. package/dist/types/utils/types.d.ts +31 -31
  993. package/hydrate/index.d.ts +2 -2
  994. package/hydrate/index.js +15870 -14095
  995. package/package.json +5 -4
  996. package/vscode-data.json +3939 -0
  997. package/dist/cjs/helpers-0d63359f.js.map +0 -1
  998. package/dist/cjs/index-4f8c900f.js.map +0 -1
  999. package/dist/cjs/types-7d67439f.js +0 -16
  1000. package/dist/core/p-03329fd0.entry.js +0 -2
  1001. package/dist/core/p-03329fd0.entry.js.map +0 -1
  1002. package/dist/core/p-24da56e7.entry.js +0 -2
  1003. package/dist/core/p-24da56e7.entry.js.map +0 -1
  1004. package/dist/core/p-39c8111d.entry.js +0 -2
  1005. package/dist/core/p-39c8111d.entry.js.map +0 -1
  1006. package/dist/core/p-3a15202f.entry.js.map +0 -1
  1007. package/dist/core/p-4bc35224.entry.js.map +0 -1
  1008. package/dist/core/p-59bdafff.entry.js +0 -2
  1009. package/dist/core/p-59bdafff.entry.js.map +0 -1
  1010. package/dist/core/p-6c376756.entry.js +0 -2
  1011. package/dist/core/p-6c376756.entry.js.map +0 -1
  1012. package/dist/core/p-717907de.entry.js +0 -2
  1013. package/dist/core/p-717907de.entry.js.map +0 -1
  1014. package/dist/core/p-752f0f9a.entry.js.map +0 -1
  1015. package/dist/core/p-9d124fc7.js +0 -3
  1016. package/dist/core/p-9d124fc7.js.map +0 -1
  1017. package/dist/core/p-c0719bf4.entry.js +0 -2
  1018. package/dist/core/p-c0719bf4.entry.js.map +0 -1
  1019. package/dist/core/p-c0c62df4.entry.js.map +0 -1
  1020. package/dist/core/p-ca6073be.entry.js.map +0 -1
  1021. package/dist/core/p-e9ddb8cd.entry.js +0 -2
  1022. package/dist/core/p-e9ddb8cd.entry.js.map +0 -1
  1023. package/dist/esm/helpers-24f6e762.js.map +0 -1
  1024. package/dist/esm/index-813020f1.js.map +0 -1
  1025. package/dist/esm/types-b2398b37.js +0 -16
  1026. /package/dist/core/{p-7ce86152.entry.js.map → p-056f8a67.entry.js.map} +0 -0
  1027. /package/dist/core/{p-08b59078.entry.js.map → p-11736fbe.entry.js.map} +0 -0
  1028. /package/dist/core/{p-5ccbb042.entry.js.map → p-15624e08.entry.js.map} +0 -0
  1029. /package/dist/core/{p-5fcd202e.entry.js.map → p-15ef0674.entry.js.map} +0 -0
  1030. /package/dist/core/{p-88ea1e49.entry.js.map → p-180e36b1.entry.js.map} +0 -0
  1031. /package/dist/core/{p-43af3cf6.entry.js.map → p-22c024ee.entry.js.map} +0 -0
  1032. /package/dist/core/{p-613aa265.js.map → p-26b7b18f.js.map} +0 -0
  1033. /package/dist/core/{p-932fb4b7.entry.js.map → p-287ab47c.entry.js.map} +0 -0
  1034. /package/dist/core/{p-69948c3e.entry.js.map → p-2b24b4bf.entry.js.map} +0 -0
  1035. /package/dist/core/{p-9f6ffced.entry.js.map → p-31969be6.entry.js.map} +0 -0
  1036. /package/dist/core/{p-475b7bd2.entry.js.map → p-335fc5e4.entry.js.map} +0 -0
  1037. /package/dist/core/{p-c9ef9f5c.entry.js.map → p-366bcb17.entry.js.map} +0 -0
  1038. /package/dist/core/{p-ed256f1d.entry.js.map → p-3a0ef91e.entry.js.map} +0 -0
  1039. /package/dist/core/{p-cb5f19ea.entry.js.map → p-51f9f329.entry.js.map} +0 -0
  1040. /package/dist/core/{p-f019219c.entry.js.map → p-529d8955.entry.js.map} +0 -0
  1041. /package/dist/core/{p-b879fa3e.entry.js.map → p-5c7e339f.entry.js.map} +0 -0
  1042. /package/dist/core/{p-2c30b583.entry.js.map → p-60c4604f.entry.js.map} +0 -0
  1043. /package/dist/core/{p-99fad66b.entry.js.map → p-6bc431b2.entry.js.map} +0 -0
  1044. /package/dist/core/{p-ccac1730.entry.js.map → p-6d3f9501.entry.js.map} +0 -0
  1045. /package/dist/core/{p-536b3c97.entry.js.map → p-6eb0421d.entry.js.map} +0 -0
  1046. /package/dist/core/{p-48525498.entry.js.map → p-765bdd98.entry.js.map} +0 -0
  1047. /package/dist/core/{p-3a814fc4.entry.js.map → p-7f887c1e.entry.js.map} +0 -0
  1048. /package/dist/core/{p-e3bffcae.entry.js.map → p-94e88827.entry.js.map} +0 -0
  1049. /package/dist/core/{p-8fb4f0c0.js.map → p-95a864bf.js.map} +0 -0
  1050. /package/dist/core/{p-eb4641a9.entry.js.map → p-96da1e85.entry.js.map} +0 -0
  1051. /package/dist/core/{p-69d15528.entry.js.map → p-988991d3.entry.js.map} +0 -0
  1052. /package/dist/core/{p-0c82048e.entry.js.map → p-9c30720d.entry.js.map} +0 -0
  1053. /package/dist/core/{p-a76912b0.entry.js.map → p-aa0a9870.entry.js.map} +0 -0
  1054. /package/dist/core/{p-76563540.entry.js.map → p-ad36a704.entry.js.map} +0 -0
  1055. /package/dist/core/{p-d80f99e0.entry.js.map → p-b0088956.entry.js.map} +0 -0
  1056. /package/dist/core/{p-2265e418.entry.js.map → p-b6a575c3.entry.js.map} +0 -0
  1057. /package/dist/core/{p-fbc8a739.entry.js.map → p-b9736cf4.entry.js.map} +0 -0
  1058. /package/dist/core/{p-025f9d2a.entry.js.map → p-b99f9e89.entry.js.map} +0 -0
  1059. /package/dist/core/{p-b0ce60a0.entry.js.map → p-c2452388.entry.js.map} +0 -0
  1060. /package/dist/core/{p-345fe84a.entry.js.map → p-c770e7a2.entry.js.map} +0 -0
  1061. /package/dist/core/{p-748159fe.entry.js.map → p-ca48e97a.entry.js.map} +0 -0
  1062. /package/dist/core/{p-5a3ca50a.entry.js.map → p-cd8de4c5.entry.js.map} +0 -0
  1063. /package/dist/core/{p-a4397df4.entry.js.map → p-cfc930f6.entry.js.map} +0 -0
  1064. /package/dist/core/{p-9ff57f09.entry.js.map → p-e5abfadd.entry.js.map} +0 -0
  1065. /package/dist/core/{p-41c6eaa1.entry.js.map → p-e9738c74.entry.js.map} +0 -0
  1066. /package/dist/core/{p-e2fd542e.entry.js.map → p-edd29edc.entry.js.map} +0 -0
  1067. /package/dist/core/{p-657513b5.entry.js.map → p-ee97e2a5.entry.js.map} +0 -0
  1068. /package/dist/core/{p-8b18346a.entry.js.map → p-f0809037.entry.js.map} +0 -0
  1069. /package/dist/core/{p-5bb6c79b.entry.js.map → p-f2e6b9ef.entry.js.map} +0 -0
  1070. /package/dist/core/{p-cf4bacee.entry.js.map → p-fdb4b48f.entry.js.map} +0 -0
@@ -1,71 +1,71 @@
1
1
  import { newE2EPage } from "@stencil/core/testing";
2
2
  beforeAll(() => {
3
- jest.spyOn(console, "warn").mockImplementation(jest.fn());
3
+ jest.spyOn(console, "warn").mockImplementation(jest.fn());
4
4
  });
5
5
  describe("ic-search-bar", () => {
6
- const options = [
7
- { label: "foo", value: "foo" },
8
- { label: "bar", value: "bar" },
9
- { label: "baz", value: "qux" },
10
- ];
11
- const longOptions = [
12
- { label: "item 1", value: "item-1" },
13
- { label: "item 2", value: "item-2" },
14
- { label: "item 3", value: "item-3" },
15
- { label: "item 4", value: "item-4" },
16
- { label: "item 5", value: "item-5" },
17
- ];
18
- const focusAndTypeIntoInput = async (value, page) => {
19
- await page.$eval("ic-search-bar", (el) => {
20
- const textfield = el.shadowRoot.querySelector("ic-text-field");
21
- const input = textfield.shadowRoot.querySelector("#ic-search-bar-input-0");
22
- input.focus();
6
+ const options = [
7
+ { label: "foo", value: "foo" },
8
+ { label: "bar", value: "bar" },
9
+ { label: "baz", value: "qux" },
10
+ ];
11
+ const longOptions = [
12
+ { label: "item 1", value: "item-1" },
13
+ { label: "item 2", value: "item-2" },
14
+ { label: "item 3", value: "item-3" },
15
+ { label: "item 4", value: "item-4" },
16
+ { label: "item 5", value: "item-5" },
17
+ ];
18
+ const focusAndTypeIntoInput = async (value, page) => {
19
+ await page.$eval("ic-search-bar", (el) => {
20
+ const textfield = el.shadowRoot.querySelector("ic-text-field");
21
+ const input = textfield.shadowRoot.querySelector("#ic-search-bar-input-0");
22
+ input.focus();
23
+ });
24
+ value.split("").forEach(async (char) => {
25
+ await page.keyboard.press(char);
26
+ });
27
+ };
28
+ it("renders clear button when value present", async () => {
29
+ const page = await newE2EPage();
30
+ await page.setContent('<ic-search-bar label="Test Label"></ic-search-bar>');
31
+ await page.waitForChanges();
32
+ let clearButton = await page.find("ic-search-bar >>> ic-text-field .clear-button");
33
+ expect(await clearButton.isVisible()).toBeFalsy();
34
+ await focusAndTypeIntoInput("foo", page);
35
+ await page.waitForChanges();
36
+ clearButton = await page.find("ic-search-bar >>> ic-text-field .clear-button");
37
+ expect(await clearButton.isVisible()).toBeTruthy();
23
38
  });
24
- value.split("").forEach(async (char) => {
25
- await page.keyboard.press(char);
39
+ it("should clear value when clear button pressed", async () => {
40
+ const page = await newE2EPage();
41
+ await page.setContent('<ic-search-bar label="Test Label"></ic-search-bar>');
42
+ const searchBar = await page.find("ic-search-bar");
43
+ const icClear = await page.spyOnEvent("icClear");
44
+ await focusAndTypeIntoInput("foo", page);
45
+ await page.waitForChanges();
46
+ const clearButton = await page.find("ic-search-bar >>> ic-text-field .clear-button");
47
+ await clearButton.click();
48
+ await page.waitForChanges();
49
+ const activeElId = await page.$eval("ic-search-bar", (el) => el.shadowRoot.querySelector("ic-text-field").shadowRoot.activeElement.id);
50
+ expect(await searchBar.getProperty("value")).toBe("");
51
+ expect(activeElId).toBe("ic-search-bar-input-0");
52
+ expect(icClear).toHaveReceivedEvent;
26
53
  });
27
- };
28
- it("renders clear button when value present", async () => {
29
- const page = await newE2EPage();
30
- await page.setContent('<ic-search-bar label="Test Label"></ic-search-bar>');
31
- await page.waitForChanges();
32
- let clearButton = await page.find("ic-search-bar >>> ic-text-field .clear-button");
33
- expect(await clearButton.isVisible()).toBeFalsy();
34
- await focusAndTypeIntoInput("foo", page);
35
- await page.waitForChanges();
36
- clearButton = await page.find("ic-search-bar >>> ic-text-field .clear-button");
37
- expect(await clearButton.isVisible()).toBeTruthy();
38
- });
39
- it("should clear value when clear button pressed", async () => {
40
- const page = await newE2EPage();
41
- await page.setContent('<ic-search-bar label="Test Label"></ic-search-bar>');
42
- const searchBar = await page.find("ic-search-bar");
43
- const icClear = await page.spyOnEvent("icClear");
44
- await focusAndTypeIntoInput("foo", page);
45
- await page.waitForChanges();
46
- const clearButton = await page.find("ic-search-bar >>> ic-text-field .clear-button");
47
- await clearButton.click();
48
- await page.waitForChanges();
49
- const activeElId = await page.$eval("ic-search-bar", (el) => el.shadowRoot.querySelector("ic-text-field").shadowRoot.activeElement.id);
50
- expect(await searchBar.getProperty("value")).toBe("");
51
- expect(activeElId).toBe("ic-search-bar-input-0");
52
- expect(icClear).toHaveReceivedEvent;
53
- });
54
- it("should emit icSubmitSearch when submit is clicked", async () => {
55
- const page = await newE2EPage();
56
- await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
57
- await page.waitForChanges();
58
- await focusAndTypeIntoInput("foo", page);
59
- const searchSubmitButton = await page.find("ic-search-bar >>> ic-text-field ic-button.search-submit-button");
60
- const icSubmitSearch = await page.spyOnEvent("icSubmitSearch");
61
- await searchSubmitButton.click();
62
- expect(icSubmitSearch).toHaveReceivedEventDetail({
63
- value: "foo",
54
+ it("should emit icSubmitSearch when submit is clicked", async () => {
55
+ const page = await newE2EPage();
56
+ await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
57
+ await page.waitForChanges();
58
+ await focusAndTypeIntoInput("foo", page);
59
+ const searchSubmitButton = await page.find("ic-search-bar >>> ic-text-field ic-button.search-submit-button");
60
+ const icSubmitSearch = await page.spyOnEvent("icSubmitSearch");
61
+ await searchSubmitButton.click();
62
+ expect(icSubmitSearch).toHaveReceivedEventDetail({
63
+ value: "foo",
64
+ });
64
65
  });
65
- });
66
- it("should invoke submit event when search textfield is in a form", async () => {
67
- const page = await newE2EPage();
68
- await page.setContent(`
66
+ it("should invoke submit event when search textfield is in a form", async () => {
67
+ const page = await newE2EPage();
68
+ await page.setContent(`
69
69
  <form>
70
70
  <ic-search-bar label="Test Label" name="search01"></ic-search-bar>
71
71
  </form>
@@ -77,388 +77,388 @@ describe("ic-search-bar", () => {
77
77
  })
78
78
  </script>
79
79
  `);
80
- const icSubmitSearch = await page.spyOnEvent("icSubmitSearch");
81
- await focusAndTypeIntoInput("foo", page);
82
- await page.waitForChanges();
83
- const searchSubmitButton = await page.find("ic-search-bar >>> ic-text-field ic-button.search-submit-button");
84
- await searchSubmitButton.click();
85
- await page.waitForChanges();
86
- expect(icSubmitSearch).toHaveReceivedEventDetail({
87
- value: "foo",
80
+ const icSubmitSearch = await page.spyOnEvent("icSubmitSearch");
81
+ await focusAndTypeIntoInput("foo", page);
82
+ await page.waitForChanges();
83
+ const searchSubmitButton = await page.find("ic-search-bar >>> ic-text-field ic-button.search-submit-button");
84
+ await searchSubmitButton.click();
85
+ await page.waitForChanges();
86
+ expect(icSubmitSearch).toHaveReceivedEventDetail({
87
+ value: "foo",
88
+ });
89
+ const p = await page.find("#text");
90
+ expect(p.innerText).toBe("submitted");
88
91
  });
89
- const p = await page.find("#text");
90
- expect(p.innerText).toBe("submitted");
91
- });
92
- it("should render options", async () => {
93
- const page = await newE2EPage();
94
- await page.setContent(`
92
+ it("should render options", async () => {
93
+ const page = await newE2EPage();
94
+ await page.setContent(`
95
95
  <ic-search-bar label="Test Label"></ic-search-bar>
96
96
  `);
97
- const searchBar = await page.find("ic-search-bar");
98
- searchBar.setProperty("options", options);
99
- await page.waitForChanges();
100
- let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
101
- expect(menu).toBeNull();
102
- await focusAndTypeIntoInput("ba", page);
103
- await page.waitForChanges();
104
- menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
105
- await page.waitForChanges();
106
- await page.waitForTimeout(500);
107
- const menuItems = menu.findAll("li");
108
- expect((await menuItems).length).toBe(2);
109
- expect(await menu.isVisible()).toBeTruthy();
110
- });
111
- it("should begin with no aria-owns attribute and then add one when the menu appears", async () => {
112
- const page = await newE2EPage();
113
- await page.setContent(`
97
+ const searchBar = await page.find("ic-search-bar");
98
+ searchBar.setProperty("options", options);
99
+ await page.waitForChanges();
100
+ let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
101
+ expect(menu).toBeNull();
102
+ await focusAndTypeIntoInput("ba", page);
103
+ await page.waitForChanges();
104
+ menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
105
+ await page.waitForChanges();
106
+ await page.waitForTimeout(500);
107
+ const menuItems = menu.findAll("li");
108
+ expect((await menuItems).length).toBe(2);
109
+ expect(await menu.isVisible()).toBeTruthy();
110
+ });
111
+ it("should begin with no aria-owns attribute and then add one when the menu appears", async () => {
112
+ const page = await newE2EPage();
113
+ await page.setContent(`
114
114
  <ic-search-bar label="Test Label"></ic-search-bar>
115
115
  `);
116
- const searchBar = await page.find("ic-search-bar");
117
- searchBar.setProperty("options", options);
118
- await page.waitForChanges();
119
- let textField = await page.find("ic-search-bar >>> ic-text-field");
120
- let menu = await textField.find("ic-menu");
121
- expect(textField).not.toHaveAttribute("aria-owns");
122
- expect(menu).toBeNull();
123
- await focusAndTypeIntoInput("ba", page);
124
- await page.waitForChanges();
125
- textField = await page.find("ic-search-bar >>> ic-text-field");
126
- menu = await textField.find("ic-menu");
127
- expect(textField).toHaveAttribute("aria-owns");
128
- expect(menu).not.toBeNull();
129
- });
130
- it("should focus on input when menu is initially displayed", async () => {
131
- const page = await newE2EPage();
132
- await page.setContent(`
116
+ const searchBar = await page.find("ic-search-bar");
117
+ searchBar.setProperty("options", options);
118
+ await page.waitForChanges();
119
+ let textField = await page.find("ic-search-bar >>> ic-text-field");
120
+ let menu = await textField.find("ic-menu");
121
+ expect(textField).not.toHaveAttribute("aria-owns");
122
+ expect(menu).toBeNull();
123
+ await focusAndTypeIntoInput("ba", page);
124
+ await page.waitForChanges();
125
+ textField = await page.find("ic-search-bar >>> ic-text-field");
126
+ menu = await textField.find("ic-menu");
127
+ expect(textField).toHaveAttribute("aria-owns");
128
+ expect(menu).not.toBeNull();
129
+ });
130
+ it("should focus on input when menu is initially displayed", async () => {
131
+ const page = await newE2EPage();
132
+ await page.setContent(`
133
133
  <ic-search-bar label="Test Label"></ic-search-bar>
134
134
  `);
135
- await page.waitForChanges();
136
- const searchBar = await page.find("ic-search-bar");
137
- searchBar.setProperty("options", options);
138
- await page.waitForChanges();
139
- await focusAndTypeIntoInput("ba", page);
140
- await page.waitForChanges();
141
- await page.waitForTimeout(500);
142
- const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
143
- const activeElId = await page.$eval("ic-search-bar", (el) => {
144
- const textfield = el.shadowRoot.querySelector("ic-text-field");
145
- return textfield.shadowRoot.activeElement.id;
135
+ await page.waitForChanges();
136
+ const searchBar = await page.find("ic-search-bar");
137
+ searchBar.setProperty("options", options);
138
+ await page.waitForChanges();
139
+ await focusAndTypeIntoInput("ba", page);
140
+ await page.waitForChanges();
141
+ await page.waitForTimeout(500);
142
+ const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
143
+ const activeElId = await page.$eval("ic-search-bar", (el) => {
144
+ const textfield = el.shadowRoot.querySelector("ic-text-field");
145
+ return textfield.shadowRoot.activeElement.id;
146
+ });
147
+ expect(await menu.isVisible()).toBeTruthy();
148
+ expect(activeElId).toBe("ic-search-bar-input-0");
146
149
  });
147
- expect(await menu.isVisible()).toBeTruthy();
148
- expect(activeElId).toBe("ic-search-bar-input-0");
149
- });
150
- it("should remove menu when input value is cleared", async () => {
151
- const page = await newE2EPage();
152
- await page.setContent(`
150
+ it("should remove menu when input value is cleared", async () => {
151
+ const page = await newE2EPage();
152
+ await page.setContent(`
153
153
  <ic-search-bar label="Test Label"></ic-search-bar>
154
154
  `);
155
- const searchBar = await page.find("ic-search-bar");
156
- searchBar.setProperty("options", options);
157
- await page.waitForChanges();
158
- await focusAndTypeIntoInput("ba", page);
159
- await page.waitForTimeout(500);
160
- let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
161
- expect(await menu.isVisible()).toBeTruthy();
162
- const clearButton = await page.find("ic-search-bar >>> ic-text-field .clear-button");
163
- await clearButton.click();
164
- menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
165
- expect(menu).toBeNull();
166
- });
167
- it("should not update value when options are highlighted", async () => {
168
- const page = await newE2EPage();
169
- await page.setContent(`
155
+ const searchBar = await page.find("ic-search-bar");
156
+ searchBar.setProperty("options", options);
157
+ await page.waitForChanges();
158
+ await focusAndTypeIntoInput("ba", page);
159
+ await page.waitForTimeout(500);
160
+ let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
161
+ expect(await menu.isVisible()).toBeTruthy();
162
+ const clearButton = await page.find("ic-search-bar >>> ic-text-field .clear-button");
163
+ await clearButton.click();
164
+ menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
165
+ expect(menu).toBeNull();
166
+ });
167
+ it("should not update value when options are highlighted", async () => {
168
+ const page = await newE2EPage();
169
+ await page.setContent(`
170
170
  <ic-search-bar label="Test Label"></ic-search-bar>
171
171
  `);
172
- const searchBar = await page.find("ic-search-bar");
173
- searchBar.setProperty("options", options);
174
- await page.waitForChanges();
175
- await focusAndTypeIntoInput("ba", page);
176
- await page.waitForChanges();
177
- await searchBar.press("ArrowDown");
178
- await page.waitForChanges();
179
- expect(await searchBar.getProperty("value")).toBe("ba");
180
- });
181
- it("should focus on menu on ArrowDown from input", async () => {
182
- const page = await newE2EPage();
183
- await page.setContent(`
172
+ const searchBar = await page.find("ic-search-bar");
173
+ searchBar.setProperty("options", options);
174
+ await page.waitForChanges();
175
+ await focusAndTypeIntoInput("ba", page);
176
+ await page.waitForChanges();
177
+ await searchBar.press("ArrowDown");
178
+ await page.waitForChanges();
179
+ expect(await searchBar.getProperty("value")).toBe("ba");
180
+ });
181
+ it("should focus on menu on ArrowDown from input", async () => {
182
+ const page = await newE2EPage();
183
+ await page.setContent(`
184
184
  <ic-search-bar label="Test Label"></ic-search-bar>
185
185
  `);
186
- const searchBar = await page.find("ic-search-bar");
187
- searchBar.setProperty("options", options);
188
- await page.waitForChanges();
189
- await focusAndTypeIntoInput("ba", page);
190
- await page.waitForChanges();
191
- await searchBar.press("ArrowDown");
192
- await page.waitForChanges();
193
- const activeElId = await page.$eval("ic-search-bar", (el) => {
194
- return el.shadowRoot.activeElement.id;
186
+ const searchBar = await page.find("ic-search-bar");
187
+ searchBar.setProperty("options", options);
188
+ await page.waitForChanges();
189
+ await focusAndTypeIntoInput("ba", page);
190
+ await page.waitForChanges();
191
+ await searchBar.press("ArrowDown");
192
+ await page.waitForChanges();
193
+ const activeElId = await page.$eval("ic-search-bar", (el) => {
194
+ return el.shadowRoot.activeElement.id;
195
+ });
196
+ expect(activeElId).toBe("ic-search-bar-input-0-menu-qux");
195
197
  });
196
- expect(activeElId).toBe("ic-search-bar-input-0-menu-qux");
197
- });
198
- it("should focus on menu on ArrowUp from input", async () => {
199
- const page = await newE2EPage();
200
- await page.setContent(`
198
+ it("should focus on menu on ArrowUp from input", async () => {
199
+ const page = await newE2EPage();
200
+ await page.setContent(`
201
201
  <ic-search-bar label="Test Label"></ic-search-bar>
202
202
  `);
203
- const searchBar = await page.find("ic-search-bar");
204
- searchBar.setProperty("options", options);
205
- await page.waitForChanges();
206
- await focusAndTypeIntoInput("ba", page);
207
- await page.waitForChanges();
208
- await searchBar.press("ArrowUp");
209
- await page.waitForChanges();
210
- const activeElId = await page.$eval("ic-search-bar", (el) => {
211
- return el.shadowRoot.activeElement.id;
203
+ const searchBar = await page.find("ic-search-bar");
204
+ searchBar.setProperty("options", options);
205
+ await page.waitForChanges();
206
+ await focusAndTypeIntoInput("ba", page);
207
+ await page.waitForChanges();
208
+ await searchBar.press("ArrowUp");
209
+ await page.waitForChanges();
210
+ const activeElId = await page.$eval("ic-search-bar", (el) => {
211
+ return el.shadowRoot.activeElement.id;
212
+ });
213
+ expect(activeElId).toBe("ic-search-bar-input-0-menu-qux");
212
214
  });
213
- expect(activeElId).toBe("ic-search-bar-input-0-menu-qux");
214
- });
215
- it("should highlight first and last options using Home and End and move focus to menu", async () => {
216
- const page = await newE2EPage();
217
- await page.setContent(`
215
+ it("should highlight first and last options using Home and End and move focus to menu", async () => {
216
+ const page = await newE2EPage();
217
+ await page.setContent(`
218
218
  <ic-search-bar label="Test Label"></ic-search-bar>
219
219
  `);
220
- const searchBar = await page.find("ic-search-bar");
221
- searchBar.setProperty("options", options);
222
- await page.waitForChanges();
223
- await focusAndTypeIntoInput("ba", page);
224
- await page.waitForChanges();
225
- await page.keyboard.press("End");
226
- await page.waitForChanges();
227
- let menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
228
- expect(menuOptions[0]).not.toHaveClass("focused-option");
229
- expect(menuOptions[1]).toHaveClass("focused-option");
230
- let activeElId = await page.$eval("ic-search-bar", (el) => {
231
- return el.shadowRoot.activeElement.id;
232
- });
233
- expect(activeElId).toBe("ic-search-bar-input-0-menu-qux");
234
- await page.keyboard.press("Home");
235
- await page.waitForChanges();
236
- menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
237
- expect(menuOptions[0]).toHaveClass("focused-option");
238
- expect(menuOptions[1]).not.toHaveClass("focused-option");
239
- activeElId = await page.$eval("ic-search-bar", (el) => {
240
- return el.shadowRoot.activeElement.id;
220
+ const searchBar = await page.find("ic-search-bar");
221
+ searchBar.setProperty("options", options);
222
+ await page.waitForChanges();
223
+ await focusAndTypeIntoInput("ba", page);
224
+ await page.waitForChanges();
225
+ await page.keyboard.press("End");
226
+ await page.waitForChanges();
227
+ let menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
228
+ expect(menuOptions[0]).not.toHaveClass("focused-option");
229
+ expect(menuOptions[1]).toHaveClass("focused-option");
230
+ let activeElId = await page.$eval("ic-search-bar", (el) => {
231
+ return el.shadowRoot.activeElement.id;
232
+ });
233
+ expect(activeElId).toBe("ic-search-bar-input-0-menu-qux");
234
+ await page.keyboard.press("Home");
235
+ await page.waitForChanges();
236
+ menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
237
+ expect(menuOptions[0]).toHaveClass("focused-option");
238
+ expect(menuOptions[1]).not.toHaveClass("focused-option");
239
+ activeElId = await page.$eval("ic-search-bar", (el) => {
240
+ return el.shadowRoot.activeElement.id;
241
+ });
242
+ expect(activeElId).toBe("ic-search-bar-input-0-menu-bar");
241
243
  });
242
- expect(activeElId).toBe("ic-search-bar-input-0-menu-bar");
243
- });
244
- it("should select first option and update value as label on Enter", async () => {
245
- const page = await newE2EPage();
246
- await page.setContent(`
244
+ it("should select first option and update value as label on Enter", async () => {
245
+ const page = await newE2EPage();
246
+ await page.setContent(`
247
247
  <ic-search-bar label="Test Label"></ic-search-bar>
248
248
  `);
249
- await page.waitForChanges();
250
- const searchBar = await page.find("ic-search-bar");
251
- searchBar.setProperty("options", options);
252
- await page.waitForChanges();
253
- await focusAndTypeIntoInput("ba", page);
254
- await page.waitForChanges();
255
- const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
256
- await menu.press("Enter");
257
- expect(await searchBar.getProperty("value")).toBe("bar");
258
- });
259
- it("should keep the input value on Enter when searchMode is set to `query`", async () => {
260
- const page = await newE2EPage();
261
- await page.setContent(`
249
+ await page.waitForChanges();
250
+ const searchBar = await page.find("ic-search-bar");
251
+ searchBar.setProperty("options", options);
252
+ await page.waitForChanges();
253
+ await focusAndTypeIntoInput("ba", page);
254
+ await page.waitForChanges();
255
+ const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
256
+ await menu.press("Enter");
257
+ expect(await searchBar.getProperty("value")).toBe("bar");
258
+ });
259
+ it("should keep the input value on Enter when searchMode is set to `query`", async () => {
260
+ const page = await newE2EPage();
261
+ await page.setContent(`
262
262
  <ic-search-bar label="Test Label" search-mode="query"></ic-search-bar>
263
263
  `);
264
- await page.waitForChanges();
265
- const searchBar = await page.find("ic-search-bar");
266
- searchBar.setProperty("options", options);
267
- await page.waitForChanges();
268
- await focusAndTypeIntoInput("ba", page);
269
- await page.waitForChanges();
270
- const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
271
- await menu.press("Enter");
272
- expect(await searchBar.getProperty("value")).toBe("ba");
273
- });
274
- it("should not highlight options when typing and searchMode is `query`", async () => {
275
- const page = await newE2EPage();
276
- await page.setContent(`
264
+ await page.waitForChanges();
265
+ const searchBar = await page.find("ic-search-bar");
266
+ searchBar.setProperty("options", options);
267
+ await page.waitForChanges();
268
+ await focusAndTypeIntoInput("ba", page);
269
+ await page.waitForChanges();
270
+ const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
271
+ await menu.press("Enter");
272
+ expect(await searchBar.getProperty("value")).toBe("ba");
273
+ });
274
+ it("should not highlight options when typing and searchMode is `query`", async () => {
275
+ const page = await newE2EPage();
276
+ await page.setContent(`
277
277
  <ic-search-bar label="Test Label" search-mode="query"></ic-search-bar>
278
278
  `);
279
- await page.waitForChanges();
280
- const searchBar = await page.find("ic-search-bar");
281
- searchBar.setProperty("options", options);
282
- await page.waitForChanges();
283
- await focusAndTypeIntoInput("bar", page);
284
- await page.waitForChanges();
285
- const menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
286
- expect(menuOptions[0]).not.toHaveClass("focused-option");
287
- });
288
- it("should move focus to first option after one ArrowDown press when searchMode is set to `query`", async () => {
289
- const page = await newE2EPage();
290
- await page.setContent(`
279
+ await page.waitForChanges();
280
+ const searchBar = await page.find("ic-search-bar");
281
+ searchBar.setProperty("options", options);
282
+ await page.waitForChanges();
283
+ await focusAndTypeIntoInput("bar", page);
284
+ await page.waitForChanges();
285
+ const menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
286
+ expect(menuOptions[0]).not.toHaveClass("focused-option");
287
+ });
288
+ it("should move focus to first option after one ArrowDown press when searchMode is set to `query`", async () => {
289
+ const page = await newE2EPage();
290
+ await page.setContent(`
291
291
  <ic-search-bar label="Test Label" search-mode="query"></ic-search-bar>
292
292
  `);
293
- await page.waitForChanges();
294
- const searchBar = await page.find("ic-search-bar");
295
- searchBar.setProperty("options", options);
296
- await page.waitForChanges();
297
- await focusAndTypeIntoInput("ba", page);
298
- await page.waitForChanges();
299
- await page.keyboard.press("ArrowDown");
300
- await page.waitForChanges();
301
- const menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
302
- expect(menuOptions[0]).toHaveClass("focused-option");
303
- });
304
- it("should add a space to value on Space", async () => {
305
- const page = await newE2EPage();
306
- await page.setContent(`
293
+ await page.waitForChanges();
294
+ const searchBar = await page.find("ic-search-bar");
295
+ searchBar.setProperty("options", options);
296
+ await page.waitForChanges();
297
+ await focusAndTypeIntoInput("ba", page);
298
+ await page.waitForChanges();
299
+ await page.keyboard.press("ArrowDown");
300
+ await page.waitForChanges();
301
+ const menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
302
+ expect(menuOptions[0]).toHaveClass("focused-option");
303
+ });
304
+ it("should add a space to value on Space", async () => {
305
+ const page = await newE2EPage();
306
+ await page.setContent(`
307
307
  <ic-search-bar label="Test Label"></ic-search-bar>
308
308
  `);
309
- await page.waitForChanges();
310
- const searchBar = await page.find("ic-search-bar");
311
- searchBar.setProperty("options", options);
312
- await page.waitForChanges();
313
- await focusAndTypeIntoInput("ba", page);
314
- await page.waitForChanges();
315
- const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
316
- await menu.press("Space");
317
- expect(await searchBar.getProperty("value")).toBe("ba ");
318
- });
319
- it("should remove a character from value on Backspace", async () => {
320
- const page = await newE2EPage();
321
- await page.setContent(`
309
+ await page.waitForChanges();
310
+ const searchBar = await page.find("ic-search-bar");
311
+ searchBar.setProperty("options", options);
312
+ await page.waitForChanges();
313
+ await focusAndTypeIntoInput("ba", page);
314
+ await page.waitForChanges();
315
+ const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
316
+ await menu.press("Space");
317
+ expect(await searchBar.getProperty("value")).toBe("ba ");
318
+ });
319
+ it("should remove a character from value on Backspace", async () => {
320
+ const page = await newE2EPage();
321
+ await page.setContent(`
322
322
  <ic-search-bar label="Test Label"></ic-search-bar>
323
323
  `);
324
- await page.waitForChanges();
325
- const searchBar = await page.find("ic-search-bar");
326
- searchBar.setProperty("options", options);
327
- await page.waitForChanges();
328
- await focusAndTypeIntoInput("ba", page);
329
- await page.waitForChanges();
330
- const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
331
- await menu.press("Backspace");
332
- expect(await searchBar.getProperty("value")).toBe("b");
333
- });
334
- it("should set value to last option when pressing up on input", async () => {
335
- const page = await newE2EPage();
336
- await page.setContent(`
324
+ await page.waitForChanges();
325
+ const searchBar = await page.find("ic-search-bar");
326
+ searchBar.setProperty("options", options);
327
+ await page.waitForChanges();
328
+ await focusAndTypeIntoInput("ba", page);
329
+ await page.waitForChanges();
330
+ const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
331
+ await menu.press("Backspace");
332
+ expect(await searchBar.getProperty("value")).toBe("b");
333
+ });
334
+ it("should set value to last option when pressing up on input", async () => {
335
+ const page = await newE2EPage();
336
+ await page.setContent(`
337
337
  <ic-search-bar label="Test Label"></ic-search-bar>
338
338
  `);
339
- await page.waitForChanges();
340
- const searchBar = await page.find("ic-search-bar");
341
- searchBar.setProperty("options", options);
342
- await page.waitForChanges();
343
- await focusAndTypeIntoInput("ba", page);
344
- await page.waitForChanges();
345
- await searchBar.press("ArrowUp");
346
- const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
347
- await menu.press("Enter");
348
- expect(await searchBar.getProperty("value")).toBe("qux");
349
- });
350
- it("menu should close on Escape", async () => {
351
- const page = await newE2EPage();
352
- await page.setContent(`
339
+ await page.waitForChanges();
340
+ const searchBar = await page.find("ic-search-bar");
341
+ searchBar.setProperty("options", options);
342
+ await page.waitForChanges();
343
+ await focusAndTypeIntoInput("ba", page);
344
+ await page.waitForChanges();
345
+ await searchBar.press("ArrowUp");
346
+ const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
347
+ await menu.press("Enter");
348
+ expect(await searchBar.getProperty("value")).toBe("qux");
349
+ });
350
+ it("menu should close on Escape", async () => {
351
+ const page = await newE2EPage();
352
+ await page.setContent(`
353
353
  <ic-search-bar label="Test Label"></ic-search-bar>
354
354
  `);
355
- await page.waitForChanges();
356
- const searchBar = await page.find("ic-search-bar");
357
- searchBar.setProperty("options", options);
358
- await page.waitForChanges();
359
- await focusAndTypeIntoInput("ba", page);
360
- await page.waitForChanges();
361
- await page.keyboard.press("ArrowUp");
362
- let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
363
- expect(await menu.isVisible()).toBeTruthy();
364
- await menu.press("Escape");
365
- menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
366
- expect(menu).toBeNull();
367
- });
368
- it("menu should close when blurred and open when focused", async () => {
369
- const page = await newE2EPage();
370
- await page.setContent(`
355
+ await page.waitForChanges();
356
+ const searchBar = await page.find("ic-search-bar");
357
+ searchBar.setProperty("options", options);
358
+ await page.waitForChanges();
359
+ await focusAndTypeIntoInput("ba", page);
360
+ await page.waitForChanges();
361
+ await page.keyboard.press("ArrowUp");
362
+ let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
363
+ expect(await menu.isVisible()).toBeTruthy();
364
+ await menu.press("Escape");
365
+ menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
366
+ expect(menu).toBeNull();
367
+ });
368
+ it("menu should close when blurred and open when focused", async () => {
369
+ const page = await newE2EPage();
370
+ await page.setContent(`
371
371
  <ic-search-bar label="Test Label"></ic-search-bar>
372
372
  `);
373
- await page.waitForChanges();
374
- const searchBar = await page.find("ic-search-bar");
375
- searchBar.setProperty("options", options);
376
- await page.waitForChanges();
377
- await focusAndTypeIntoInput("ba", page);
378
- await page.waitForChanges();
379
- // Will focus clear button then blur
380
- await page.keyboard.press("Tab");
381
- await page.keyboard.press("Tab");
382
- await page.waitForChanges();
383
- let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
384
- expect(menu).toBeNull;
385
- await page.keyboard.down("Shift");
386
- await page.keyboard.press("Tab");
387
- await page.waitForChanges();
388
- menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
389
- expect(await menu.isVisible()).toBeTruthy();
390
- });
391
- it("should emit icOptionSelect when a menu option has been selected", async () => {
392
- const page = await newE2EPage();
393
- await page.setContent(`
373
+ await page.waitForChanges();
374
+ const searchBar = await page.find("ic-search-bar");
375
+ searchBar.setProperty("options", options);
376
+ await page.waitForChanges();
377
+ await focusAndTypeIntoInput("ba", page);
378
+ await page.waitForChanges();
379
+ // Will focus clear button then blur
380
+ await page.keyboard.press("Tab");
381
+ await page.keyboard.press("Tab");
382
+ await page.waitForChanges();
383
+ let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
384
+ expect(menu).toBeNull;
385
+ await page.keyboard.down("Shift");
386
+ await page.keyboard.press("Tab");
387
+ await page.waitForChanges();
388
+ menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
389
+ expect(await menu.isVisible()).toBeTruthy();
390
+ });
391
+ it("should emit icOptionSelect when a menu option has been selected", async () => {
392
+ const page = await newE2EPage();
393
+ await page.setContent(`
394
394
  <ic-search-bar search label="Test Label"></ic-search-bar>
395
395
  `);
396
- const icOptionSelect = await page.spyOnEvent("icOptionSelect");
397
- const searchBar = await page.find("ic-search-bar");
398
- searchBar.setProperty("options", options);
399
- await page.waitForChanges();
400
- await focusAndTypeIntoInput("fo", page);
401
- await page.waitForChanges();
402
- await searchBar.press("ArrowDown");
403
- await page.waitForChanges();
404
- const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
405
- await menu.press("Enter");
406
- expect(icOptionSelect).toHaveReceivedEventDetail({
407
- value: "foo",
396
+ const icOptionSelect = await page.spyOnEvent("icOptionSelect");
397
+ const searchBar = await page.find("ic-search-bar");
398
+ searchBar.setProperty("options", options);
399
+ await page.waitForChanges();
400
+ await focusAndTypeIntoInput("fo", page);
401
+ await page.waitForChanges();
402
+ await searchBar.press("ArrowDown");
403
+ await page.waitForChanges();
404
+ const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
405
+ await menu.press("Enter");
406
+ expect(icOptionSelect).toHaveReceivedEventDetail({
407
+ value: "foo",
408
+ });
408
409
  });
409
- });
410
- it("should emit icMenuChange when opening/closing menu", async () => {
411
- const page = await newE2EPage();
412
- await page.setContent(`
410
+ it("should emit icMenuChange when opening/closing menu", async () => {
411
+ const page = await newE2EPage();
412
+ await page.setContent(`
413
413
  <ic-search-bar label="Test Label"></ic-search-bar>
414
414
  `);
415
- const icMenuChange = await page.spyOnEvent("icMenuChange");
416
- const searchBar = await page.find("ic-search-bar");
417
- searchBar.setProperty("options", options);
418
- await page.waitForChanges();
419
- await focusAndTypeIntoInput("ba", page);
420
- await page.waitForChanges();
421
- expect(icMenuChange).toHaveReceivedEventDetail({
422
- open: true,
423
- });
424
- await page.keyboard.press("Enter");
425
- await page.waitForChanges();
426
- expect(icMenuChange).toHaveReceivedEventDetail({
427
- open: false,
415
+ const icMenuChange = await page.spyOnEvent("icMenuChange");
416
+ const searchBar = await page.find("ic-search-bar");
417
+ searchBar.setProperty("options", options);
418
+ await page.waitForChanges();
419
+ await focusAndTypeIntoInput("ba", page);
420
+ await page.waitForChanges();
421
+ expect(icMenuChange).toHaveReceivedEventDetail({
422
+ open: true,
423
+ });
424
+ await page.keyboard.press("Enter");
425
+ await page.waitForChanges();
426
+ expect(icMenuChange).toHaveReceivedEventDetail({
427
+ open: false,
428
+ });
428
429
  });
429
- });
430
- it("should prepopulate textfield with value in search mode", async () => {
431
- const page = await newE2EPage();
432
- await page.setContent(`
430
+ it("should prepopulate textfield with value in search mode", async () => {
431
+ const page = await newE2EPage();
432
+ await page.setContent(`
433
433
  <ic-search-bar label="Test Label" value="test value"></ic-search-bar>
434
434
  `);
435
- const input = await page.find("ic-search-bar >>> ic-text-field >>> #ic-search-bar-input-0");
436
- expect(await input.getProperty("value")).toBe("test value");
437
- });
438
- it("should filter options", async () => {
439
- const page = await newE2EPage();
440
- await page.setContent(`
435
+ const input = await page.find("ic-search-bar >>> ic-text-field >>> #ic-search-bar-input-0");
436
+ expect(await input.getProperty("value")).toBe("test value");
437
+ });
438
+ it("should filter options", async () => {
439
+ const page = await newE2EPage();
440
+ await page.setContent(`
441
441
  <ic-search-bar label="Test Label"></ic-search-bar>
442
442
  `);
443
- const searchBar = await page.find("ic-search-bar");
444
- searchBar.setProperty("options", options);
445
- await page.waitForChanges();
446
- let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
447
- expect(menu).toBeNull();
448
- await focusAndTypeIntoInput("ba", page);
449
- await page.waitForChanges();
450
- menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
451
- await page.waitForChanges();
452
- let menuItems = menu.findAll("li");
453
- expect((await menuItems).length).toBe(2);
454
- await page.keyboard.press("r");
455
- await page.waitForChanges();
456
- menuItems = menu.findAll("li");
457
- expect((await menuItems).length).toBe(1);
458
- });
459
- it("should prevent form submit event when clear is invoked using Enter", async () => {
460
- const page = await newE2EPage();
461
- await page.setContent(`
443
+ const searchBar = await page.find("ic-search-bar");
444
+ searchBar.setProperty("options", options);
445
+ await page.waitForChanges();
446
+ let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
447
+ expect(menu).toBeNull();
448
+ await focusAndTypeIntoInput("ba", page);
449
+ await page.waitForChanges();
450
+ menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
451
+ await page.waitForChanges();
452
+ let menuItems = menu.findAll("li");
453
+ expect((await menuItems).length).toBe(2);
454
+ await page.keyboard.press("r");
455
+ await page.waitForChanges();
456
+ menuItems = menu.findAll("li");
457
+ expect((await menuItems).length).toBe(1);
458
+ });
459
+ it("should prevent form submit event when clear is invoked using Enter", async () => {
460
+ const page = await newE2EPage();
461
+ await page.setContent(`
462
462
  <form>
463
463
  <ic-search-bar label="Test Label" name="search01"></ic-search-bar>
464
464
  </form>
@@ -469,638 +469,638 @@ describe("ic-search-bar", () => {
469
469
  })
470
470
  </script>
471
471
  `);
472
- const icClear = await page.spyOnEvent("icClear");
473
- const p = await page.find("#text");
474
- await focusAndTypeIntoInput("foo", page);
475
- await page.waitForChanges();
476
- await page.keyboard.press("Tab");
477
- await page.keyboard.press("Enter");
478
- expect(icClear).toHaveReceivedEvent();
479
- expect(p.innerText).toBe("idle");
480
- });
481
- it("should clear the value when clear is invoked using Space - should not add a whitespace", async () => {
482
- const page = await newE2EPage();
483
- await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
484
- const icClear = await page.spyOnEvent("icClear");
485
- const searchBar = await page.find("ic-search-bar");
486
- await focusAndTypeIntoInput("foo", page);
487
- await page.waitForChanges();
488
- await page.keyboard.press("Tab");
489
- await page.keyboard.press("Space");
490
- await page.waitForChanges();
491
- expect(icClear).toHaveReceivedEvent();
492
- expect(searchBar.getAttribute("value")).toBe("");
493
- expect(searchBar.getAttribute("value").length).toBe(0);
494
- });
495
- it("should emit icSubmitSearch when search button pressed with Space", async () => {
496
- const page = await newE2EPage();
497
- await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
498
- const icSubmitSearch = await page.spyOnEvent("icSubmitSearch");
499
- await focusAndTypeIntoInput("foo", page);
500
- await page.waitForChanges();
501
- await page.keyboard.press("Tab");
502
- await page.keyboard.press("Tab");
503
- await page.keyboard.press("Space");
504
- await page.waitForChanges();
505
- expect(icSubmitSearch).toHaveReceivedEventDetail({
506
- value: "foo",
472
+ const icClear = await page.spyOnEvent("icClear");
473
+ const p = await page.find("#text");
474
+ await focusAndTypeIntoInput("foo", page);
475
+ await page.waitForChanges();
476
+ await page.keyboard.press("Tab");
477
+ await page.keyboard.press("Enter");
478
+ expect(icClear).toHaveReceivedEvent();
479
+ expect(p.innerText).toBe("idle");
507
480
  });
508
- });
509
- it("should update value and move focus back to input when focus previously on ic-menu", async () => {
510
- const page = await newE2EPage();
511
- await page.setContent(`
512
- <ic-search-bar label="Test Label"></ic-search-bar>
513
- `);
514
- const searchBar = await page.find("ic-search-bar");
515
- searchBar.setProperty("options", options);
516
- await page.waitForChanges();
517
- await focusAndTypeIntoInput("ba", page);
518
- await page.waitForChanges();
519
- await page.keyboard.press("ArrowDown");
520
- await page.waitForChanges();
521
- const focusedElement = await page.evaluate(() => {
522
- const el = document.querySelector("ic-search-bar").shadowRoot;
523
- return el.activeElement.id;
481
+ it("should clear the value when clear is invoked using Space - should not add a whitespace", async () => {
482
+ const page = await newE2EPage();
483
+ await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
484
+ const icClear = await page.spyOnEvent("icClear");
485
+ const searchBar = await page.find("ic-search-bar");
486
+ await focusAndTypeIntoInput("foo", page);
487
+ await page.waitForChanges();
488
+ await page.keyboard.press("Tab");
489
+ await page.keyboard.press("Space");
490
+ await page.waitForChanges();
491
+ expect(icClear).toHaveReceivedEvent();
492
+ expect(searchBar.getAttribute("value")).toBe("");
493
+ expect(searchBar.getAttribute("value").length).toBe(0);
524
494
  });
525
- expect(focusedElement).toBe("ic-search-bar-input-0-menu-qux");
526
- await page.keyboard.press("r");
527
- const inputEl = await page.evaluate(() => {
528
- const el = document
529
- .querySelector("ic-search-bar")
530
- .shadowRoot.querySelector("ic-text-field");
531
- return {
532
- focusedEl: el.shadowRoot.activeElement.id,
533
- inputValue: el.value,
534
- };
495
+ it("should emit icSubmitSearch when search button pressed with Space", async () => {
496
+ const page = await newE2EPage();
497
+ await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
498
+ const icSubmitSearch = await page.spyOnEvent("icSubmitSearch");
499
+ await focusAndTypeIntoInput("foo", page);
500
+ await page.waitForChanges();
501
+ await page.keyboard.press("Tab");
502
+ await page.keyboard.press("Tab");
503
+ await page.keyboard.press("Space");
504
+ await page.waitForChanges();
505
+ expect(icSubmitSearch).toHaveReceivedEventDetail({
506
+ value: "foo",
507
+ });
535
508
  });
536
- expect(inputEl.focusedEl).toBe("ic-search-bar-input-0");
537
- expect(inputEl.inputValue).toBe("bar");
538
- });
539
- it("should render suggestions after number of characters in value set to 3", async () => {
540
- const page = await newE2EPage();
541
- await page.setContent(`
509
+ it("should update value and move focus back to input when focus previously on ic-menu", async () => {
510
+ const page = await newE2EPage();
511
+ await page.setContent(`
542
512
  <ic-search-bar label="Test Label"></ic-search-bar>
543
513
  `);
544
- const searchBar = await page.find("ic-search-bar");
545
- searchBar.setProperty("options", options);
546
- searchBar.setProperty("charactersUntilSuggestion", 3);
547
- await page.waitForChanges();
548
- await focusAndTypeIntoInput("ba", page);
549
- await page.waitForChanges();
550
- let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
551
- expect(menu).toBeNull();
552
- await page.waitForChanges();
553
- await focusAndTypeIntoInput("r", page);
554
- await page.waitForChanges();
555
- menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
556
- expect(await menu.isVisible()).toBeTruthy();
557
- });
558
- it("should render no results available if no matches", async () => {
559
- const page = await newE2EPage();
560
- await page.setContent(`
514
+ const searchBar = await page.find("ic-search-bar");
515
+ searchBar.setProperty("options", options);
516
+ await page.waitForChanges();
517
+ await focusAndTypeIntoInput("ba", page);
518
+ await page.waitForChanges();
519
+ await page.keyboard.press("ArrowDown");
520
+ await page.waitForChanges();
521
+ const focusedElement = await page.evaluate(() => {
522
+ const el = document.querySelector("ic-search-bar").shadowRoot;
523
+ return el.activeElement.id;
524
+ });
525
+ expect(focusedElement).toBe("ic-search-bar-input-0-menu-qux");
526
+ await page.keyboard.press("r");
527
+ const inputEl = await page.evaluate(() => {
528
+ const el = document
529
+ .querySelector("ic-search-bar")
530
+ .shadowRoot.querySelector("ic-text-field");
531
+ return {
532
+ focusedEl: el.shadowRoot.activeElement.id,
533
+ inputValue: el.value,
534
+ };
535
+ });
536
+ expect(inputEl.focusedEl).toBe("ic-search-bar-input-0");
537
+ expect(inputEl.inputValue).toBe("bar");
538
+ });
539
+ it("should render suggestions after number of characters in value set to 3", async () => {
540
+ const page = await newE2EPage();
541
+ await page.setContent(`
561
542
  <ic-search-bar label="Test Label"></ic-search-bar>
562
543
  `);
563
- const searchBar = await page.find("ic-search-bar");
564
- searchBar.setProperty("options", options);
565
- await page.waitForChanges();
566
- await focusAndTypeIntoInput("zzz", page);
567
- await page.waitForChanges();
568
- const noOptionsLabel = await page.evaluate(() => {
569
- const menuEl = document
570
- .querySelector("ic-search-bar")
571
- .shadowRoot.querySelector("ic-menu");
572
- const noOptionsItem = menuEl.querySelectorAll("li")[0];
573
- return noOptionsItem.innerText;
544
+ const searchBar = await page.find("ic-search-bar");
545
+ searchBar.setProperty("options", options);
546
+ searchBar.setProperty("charactersUntilSuggestion", 3);
547
+ await page.waitForChanges();
548
+ await focusAndTypeIntoInput("ba", page);
549
+ await page.waitForChanges();
550
+ let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
551
+ expect(menu).toBeNull();
552
+ await page.waitForChanges();
553
+ await focusAndTypeIntoInput("r", page);
554
+ await page.waitForChanges();
555
+ menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
556
+ expect(await menu.isVisible()).toBeTruthy();
574
557
  });
575
- expect(noOptionsLabel).toBe("No results found");
576
- });
577
- it("should render 0 results if no matches (updated no options text)", async () => {
578
- const NO_OPTIONS = "0 results";
579
- const page = await newE2EPage();
580
- await page.setContent(`
558
+ it("should render no results available if no matches", async () => {
559
+ const page = await newE2EPage();
560
+ await page.setContent(`
581
561
  <ic-search-bar label="Test Label"></ic-search-bar>
582
562
  `);
583
- const searchBar = await page.find("ic-search-bar");
584
- searchBar.setProperty("options", options);
585
- searchBar.setProperty("emptyOptionListText", NO_OPTIONS);
586
- await page.waitForChanges();
587
- await focusAndTypeIntoInput("zzz", page);
588
- await page.waitForChanges();
589
- const noOptionsLabel = await page.evaluate(() => {
590
- const menuEl = document
591
- .querySelector("ic-search-bar")
592
- .shadowRoot.querySelector("ic-menu");
593
- const noOptionsItem = menuEl.querySelectorAll("li")[0];
594
- return noOptionsItem.innerText;
563
+ const searchBar = await page.find("ic-search-bar");
564
+ searchBar.setProperty("options", options);
565
+ await page.waitForChanges();
566
+ await focusAndTypeIntoInput("zzz", page);
567
+ await page.waitForChanges();
568
+ const noOptionsLabel = await page.evaluate(() => {
569
+ const menuEl = document
570
+ .querySelector("ic-search-bar")
571
+ .shadowRoot.querySelector("ic-menu");
572
+ const noOptionsItem = menuEl.querySelectorAll("li")[0];
573
+ return noOptionsItem.innerText;
574
+ });
575
+ expect(noOptionsLabel).toBe("No results found");
595
576
  });
596
- expect(noOptionsLabel).toBe(NO_OPTIONS);
597
- });
598
- it("should disable search button on 0 results", async () => {
599
- const page = await newE2EPage();
600
- await page.setContent(`
577
+ it("should render 0 results if no matches (updated no options text)", async () => {
578
+ const NO_OPTIONS = "0 results";
579
+ const page = await newE2EPage();
580
+ await page.setContent(`
601
581
  <ic-search-bar label="Test Label"></ic-search-bar>
602
582
  `);
603
- const searchBar = await page.find("ic-search-bar");
604
- searchBar.setProperty("options", options);
605
- await page.waitForChanges();
606
- await focusAndTypeIntoInput("zzz", page);
607
- await page.waitForChanges();
608
- const searchSubmitBtn = await page.find("ic-search-bar >>> ic-text-field ic-button.search-submit-button");
609
- expect(await searchSubmitBtn.getProperty("disabled")).toBeTruthy();
610
- });
611
- it("should focus on first option when ic-menu rendered and Enter should select option", async () => {
612
- const page = await newE2EPage();
613
- await page.setContent(`
583
+ const searchBar = await page.find("ic-search-bar");
584
+ searchBar.setProperty("options", options);
585
+ searchBar.setProperty("emptyOptionListText", NO_OPTIONS);
586
+ await page.waitForChanges();
587
+ await focusAndTypeIntoInput("zzz", page);
588
+ await page.waitForChanges();
589
+ const noOptionsLabel = await page.evaluate(() => {
590
+ const menuEl = document
591
+ .querySelector("ic-search-bar")
592
+ .shadowRoot.querySelector("ic-menu");
593
+ const noOptionsItem = menuEl.querySelectorAll("li")[0];
594
+ return noOptionsItem.innerText;
595
+ });
596
+ expect(noOptionsLabel).toBe(NO_OPTIONS);
597
+ });
598
+ it("should disable search button on 0 results", async () => {
599
+ const page = await newE2EPage();
600
+ await page.setContent(`
614
601
  <ic-search-bar label="Test Label"></ic-search-bar>
615
602
  `);
616
- const searchBar = await page.find("ic-search-bar");
617
- searchBar.setProperty("options", options);
618
- await page.waitForChanges();
619
- await focusAndTypeIntoInput("ba", page);
620
- await page.waitForChanges();
621
- const FirstOptionClassIsFocusedOption = await page.evaluate(() => {
622
- const menuEl = document
623
- .querySelector("ic-search-bar")
624
- .shadowRoot.querySelector("ic-menu");
625
- const firstMenuItem = menuEl.querySelectorAll("li")[0];
626
- return firstMenuItem.classList.contains("focused-option");
603
+ const searchBar = await page.find("ic-search-bar");
604
+ searchBar.setProperty("options", options);
605
+ await page.waitForChanges();
606
+ await focusAndTypeIntoInput("zzz", page);
607
+ await page.waitForChanges();
608
+ const searchSubmitBtn = await page.find("ic-search-bar >>> ic-text-field ic-button.search-submit-button");
609
+ expect(await searchSubmitBtn.getProperty("disabled")).toBeTruthy();
627
610
  });
628
- expect(FirstOptionClassIsFocusedOption).toBeTruthy();
629
- await page.keyboard.press("Enter");
630
- await page.waitForChanges();
631
- const input = await page.find("ic-search-bar >>> ic-text-field >>> #ic-search-bar-input-0");
632
- expect(await input.getProperty("value")).toBe("bar");
633
- });
634
- it("should be able to select second menu item after selecting an initial menu item", async () => {
635
- const page = await newE2EPage();
636
- await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
637
- const searchBar = await page.find("ic-search-bar");
638
- searchBar.setProperty("options", options);
639
- await page.waitForChanges();
640
- await focusAndTypeIntoInput("ba", page);
641
- await page.waitForChanges();
642
- let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
643
- let firstOption = (await menu.findAll("li"))[0];
644
- expect(firstOption).toHaveClass("focused-option");
645
- await searchBar.press("Enter");
646
- await page.waitForChanges();
647
- const value = await searchBar.getProperty("value");
648
- await page.waitForChanges();
649
- expect(value).toBe("bar");
650
- await page.keyboard.press("Backspace");
651
- await page.waitForChanges();
652
- await searchBar.press("ArrowDown");
653
- await page.waitForChanges();
654
- menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
655
- firstOption = (await menu.findAll("li"))[0];
656
- const lastOption = (await menu.findAll("li"))[1];
657
- expect(firstOption).not.toHaveClass("focused-option");
658
- expect(lastOption).toHaveClass("focused-option");
659
- await searchBar.press("Enter");
660
- await page.waitForChanges();
661
- expect(await searchBar.getProperty("value")).toBe("qux");
662
- });
663
- it("should tab through search bar from input > clear > submit > ic-menu (when options are available) > back to search bar", async () => {
664
- const page = await newE2EPage();
665
- await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
666
- const searchBar = await page.find("ic-search-bar");
667
- searchBar.setProperty("options", options);
668
- await page.waitForChanges();
669
- await focusAndTypeIntoInput("ba", page);
670
- await page.waitForChanges();
671
- let focusedElement = await page.evaluate(() => {
672
- const el = document
673
- .querySelector("ic-search-bar")
674
- .shadowRoot.querySelector("ic-text-field");
675
- return el.shadowRoot.activeElement.id;
611
+ it("should focus on first option when ic-menu rendered and Enter should select option", async () => {
612
+ const page = await newE2EPage();
613
+ await page.setContent(`
614
+ <ic-search-bar label="Test Label"></ic-search-bar>
615
+ `);
616
+ const searchBar = await page.find("ic-search-bar");
617
+ searchBar.setProperty("options", options);
618
+ await page.waitForChanges();
619
+ await focusAndTypeIntoInput("ba", page);
620
+ await page.waitForChanges();
621
+ const FirstOptionClassIsFocusedOption = await page.evaluate(() => {
622
+ const menuEl = document
623
+ .querySelector("ic-search-bar")
624
+ .shadowRoot.querySelector("ic-menu");
625
+ const firstMenuItem = menuEl.querySelectorAll("li")[0];
626
+ return firstMenuItem.classList.contains("focused-option");
627
+ });
628
+ expect(FirstOptionClassIsFocusedOption).toBeTruthy();
629
+ await page.keyboard.press("Enter");
630
+ await page.waitForChanges();
631
+ const input = await page.find("ic-search-bar >>> ic-text-field >>> #ic-search-bar-input-0");
632
+ expect(await input.getProperty("value")).toBe("bar");
676
633
  });
677
- expect(focusedElement).toBe("ic-search-bar-input-0");
678
- await page.waitForChanges();
679
- await page.keyboard.press("Tab");
680
- await page.waitForChanges();
681
- focusedElement = await page.evaluate(() => {
682
- const el = document.querySelector("ic-search-bar");
683
- return el.shadowRoot.activeElement.id;
634
+ it("should be able to select second menu item after selecting an initial menu item", async () => {
635
+ const page = await newE2EPage();
636
+ await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
637
+ const searchBar = await page.find("ic-search-bar");
638
+ searchBar.setProperty("options", options);
639
+ await page.waitForChanges();
640
+ await focusAndTypeIntoInput("ba", page);
641
+ await page.waitForChanges();
642
+ let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
643
+ let firstOption = (await menu.findAll("li"))[0];
644
+ expect(firstOption).toHaveClass("focused-option");
645
+ await searchBar.press("Enter");
646
+ await page.waitForChanges();
647
+ const value = await searchBar.getProperty("value");
648
+ await page.waitForChanges();
649
+ expect(value).toBe("bar");
650
+ await page.keyboard.press("Backspace");
651
+ await page.waitForChanges();
652
+ await searchBar.press("ArrowDown");
653
+ await page.waitForChanges();
654
+ menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
655
+ firstOption = (await menu.findAll("li"))[0];
656
+ const lastOption = (await menu.findAll("li"))[1];
657
+ expect(firstOption).not.toHaveClass("focused-option");
658
+ expect(lastOption).toHaveClass("focused-option");
659
+ await searchBar.press("Enter");
660
+ await page.waitForChanges();
661
+ expect(await searchBar.getProperty("value")).toBe("qux");
684
662
  });
685
- expect(focusedElement).toBe("clear-button");
686
- await page.keyboard.press("Tab");
687
- await page.waitForChanges();
688
- focusedElement = await page.evaluate(() => {
689
- const el = document.querySelector("ic-search-bar");
690
- return el.shadowRoot.activeElement.id;
663
+ it("should tab through search bar from input > clear > submit > ic-menu (when options are available) > back to search bar", async () => {
664
+ const page = await newE2EPage();
665
+ await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
666
+ const searchBar = await page.find("ic-search-bar");
667
+ searchBar.setProperty("options", options);
668
+ await page.waitForChanges();
669
+ await focusAndTypeIntoInput("ba", page);
670
+ await page.waitForChanges();
671
+ let focusedElement = await page.evaluate(() => {
672
+ const el = document
673
+ .querySelector("ic-search-bar")
674
+ .shadowRoot.querySelector("ic-text-field");
675
+ return el.shadowRoot.activeElement.id;
676
+ });
677
+ expect(focusedElement).toBe("ic-search-bar-input-0");
678
+ await page.waitForChanges();
679
+ await page.keyboard.press("Tab");
680
+ await page.waitForChanges();
681
+ focusedElement = await page.evaluate(() => {
682
+ const el = document.querySelector("ic-search-bar");
683
+ return el.shadowRoot.activeElement.id;
684
+ });
685
+ expect(focusedElement).toBe("clear-button");
686
+ await page.keyboard.press("Tab");
687
+ await page.waitForChanges();
688
+ focusedElement = await page.evaluate(() => {
689
+ const el = document.querySelector("ic-search-bar");
690
+ return el.shadowRoot.activeElement.id;
691
+ });
692
+ expect(focusedElement).toBe("search-submit-button");
693
+ await page.keyboard.press("Tab");
694
+ await page.waitForChanges();
695
+ focusedElement = await page.evaluate(() => {
696
+ const el = document.querySelector("ic-search-bar").shadowRoot;
697
+ return el.activeElement.id;
698
+ });
699
+ expect(focusedElement).toBe("ic-search-bar-input-0-menu-bar");
700
+ await page.waitForChanges();
701
+ await page.keyboard.down("Shift");
702
+ await page.keyboard.press("Tab");
703
+ await page.keyboard.press("Tab");
704
+ await page.keyboard.press("Tab");
705
+ await page.waitForChanges();
706
+ focusedElement = await page.evaluate(() => {
707
+ const el = document
708
+ .querySelector("ic-search-bar")
709
+ .shadowRoot.querySelector("ic-text-field");
710
+ return el.shadowRoot.activeElement.id;
711
+ });
712
+ expect(focusedElement).toBe("ic-search-bar-input-0");
691
713
  });
692
- expect(focusedElement).toBe("search-submit-button");
693
- await page.keyboard.press("Tab");
694
- await page.waitForChanges();
695
- focusedElement = await page.evaluate(() => {
696
- const el = document.querySelector("ic-search-bar").shadowRoot;
697
- return el.activeElement.id;
714
+ it("menu is still rendered when Shift is pressed while focus on input", async () => {
715
+ const page = await newE2EPage();
716
+ await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
717
+ const searchBar = await page.find("ic-search-bar");
718
+ searchBar.setProperty("options", options);
719
+ await page.waitForChanges();
720
+ await focusAndTypeIntoInput("ba", page);
721
+ await page.waitForChanges();
722
+ await page.keyboard.press("Shift");
723
+ const menu = await page.find("ic-search-bar >>> ic-menu");
724
+ expect(await menu.isVisible()).toBeTruthy();
698
725
  });
699
- expect(focusedElement).toBe("ic-search-bar-input-0-menu-bar");
700
- await page.waitForChanges();
701
- await page.keyboard.down("Shift");
702
- await page.keyboard.press("Tab");
703
- await page.keyboard.press("Tab");
704
- await page.keyboard.press("Tab");
705
- await page.waitForChanges();
706
- focusedElement = await page.evaluate(() => {
707
- const el = document
708
- .querySelector("ic-search-bar")
709
- .shadowRoot.querySelector("ic-text-field");
710
- return el.shadowRoot.activeElement.id;
726
+ it("displays tooltip on search buttons when enabled", async () => {
727
+ const page = await newE2EPage();
728
+ await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
729
+ await page.keyboard.press("Tab");
730
+ await page.keyboard.press("Tab");
731
+ await page.waitForChanges();
732
+ let submitSearchTooltipDisplay = await page.evaluate(() => {
733
+ const tooltip = document
734
+ .querySelector("ic-search-bar")
735
+ .shadowRoot.querySelector("#search-submit-button")
736
+ .shadowRoot.querySelector("ic-tooltip")
737
+ .shadowRoot.querySelector(".ic-tooltip-container");
738
+ return window.getComputedStyle(tooltip).display;
739
+ });
740
+ expect(submitSearchTooltipDisplay).toBe("none");
741
+ await focusAndTypeIntoInput("ba", page);
742
+ await page.waitForChanges();
743
+ await page.keyboard.press("Tab");
744
+ await page.waitForTimeout(300);
745
+ const clearTooltipDisplay = await page.evaluate(() => {
746
+ const tooltip = document
747
+ .querySelector("ic-search-bar")
748
+ .shadowRoot.querySelector("#clear-button")
749
+ .shadowRoot.querySelector("ic-tooltip")
750
+ .shadowRoot.querySelector(".ic-tooltip-container");
751
+ return window.getComputedStyle(tooltip).display;
752
+ });
753
+ expect(clearTooltipDisplay).toBe("block");
754
+ await page.keyboard.press("Tab");
755
+ await page.waitForTimeout(300);
756
+ submitSearchTooltipDisplay = await page.evaluate(() => {
757
+ const tooltip = document
758
+ .querySelector("ic-search-bar")
759
+ .shadowRoot.querySelector("#search-submit-button")
760
+ .shadowRoot.querySelector("ic-tooltip")
761
+ .shadowRoot.querySelector(".ic-tooltip-container");
762
+ return window.getComputedStyle(tooltip).display;
763
+ });
764
+ expect(submitSearchTooltipDisplay).toBe("block");
711
765
  });
712
- expect(focusedElement).toBe("ic-search-bar-input-0");
713
- });
714
- it("menu is still rendered when Shift is pressed while focus on input", async () => {
715
- const page = await newE2EPage();
716
- await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
717
- const searchBar = await page.find("ic-search-bar");
718
- searchBar.setProperty("options", options);
719
- await page.waitForChanges();
720
- await focusAndTypeIntoInput("ba", page);
721
- await page.waitForChanges();
722
- await page.keyboard.press("Shift");
723
- const menu = await page.find("ic-search-bar >>> ic-menu");
724
- expect(await menu.isVisible()).toBeTruthy();
725
- });
726
- it("displays tooltip on search buttons when enabled", async () => {
727
- const page = await newE2EPage();
728
- await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
729
- await page.keyboard.press("Tab");
730
- await page.keyboard.press("Tab");
731
- await page.waitForChanges();
732
- let submitSearchTooltipDisplay = await page.evaluate(() => {
733
- const tooltip = document
734
- .querySelector("ic-search-bar")
735
- .shadowRoot.querySelector("#search-submit-button")
736
- .shadowRoot.querySelector("ic-tooltip")
737
- .shadowRoot.querySelector(".ic-tooltip-container");
738
- return window.getComputedStyle(tooltip).display;
766
+ it("should highlight first option again after no results found", async () => {
767
+ const page = await newE2EPage();
768
+ await page.setContent(`
769
+ <ic-search-bar label="Test Label"></ic-search-bar>
770
+ `);
771
+ const searchBar = await page.find("ic-search-bar");
772
+ searchBar.setProperty("options", options);
773
+ await page.waitForChanges();
774
+ await focusAndTypeIntoInput("barr", page);
775
+ await page.waitForChanges();
776
+ const noOptionsLabel = await page.evaluate(() => {
777
+ const menuEl = document
778
+ .querySelector("ic-search-bar")
779
+ .shadowRoot.querySelector("ic-menu");
780
+ const noOptionsItem = menuEl.querySelectorAll("li")[0];
781
+ return noOptionsItem.innerText;
782
+ });
783
+ expect(noOptionsLabel).toBe("No results found");
784
+ await page.waitForChanges();
785
+ await page.keyboard.press("Backspace");
786
+ await page.waitForTimeout(500);
787
+ const firstOptionFocused = await page.evaluate(() => {
788
+ const menuEl = document
789
+ .querySelector("ic-search-bar")
790
+ .shadowRoot.querySelector("ic-menu");
791
+ const firstOptionItem = menuEl.querySelectorAll("li")[0];
792
+ return firstOptionItem.classList.contains("focused-option");
793
+ });
794
+ expect(firstOptionFocused).toBeTruthy();
739
795
  });
740
- expect(submitSearchTooltipDisplay).toBe("none");
741
- await focusAndTypeIntoInput("ba", page);
742
- await page.waitForChanges();
743
- await page.keyboard.press("Tab");
744
- await page.waitForTimeout(300);
745
- const clearTooltipDisplay = await page.evaluate(() => {
746
- const tooltip = document
747
- .querySelector("ic-search-bar")
748
- .shadowRoot.querySelector("#clear-button")
749
- .shadowRoot.querySelector("ic-tooltip")
750
- .shadowRoot.querySelector(".ic-tooltip-container");
751
- return window.getComputedStyle(tooltip).display;
796
+ it("focuses onto button from search bar", async () => {
797
+ const page = await newE2EPage();
798
+ await page.setContent(`
799
+ <ic-search-bar label="Test Label"></ic-search-bar>
800
+ <ic-button id="button">Foo</ic-button>
801
+ `);
802
+ const searchBar = await page.find("ic-search-bar");
803
+ searchBar.setProperty("options", options);
804
+ await page.waitForChanges();
805
+ await focusAndTypeIntoInput("ba", page);
806
+ await page.waitForChanges();
807
+ await page.keyboard.press("ArrowDown");
808
+ await page.waitForChanges();
809
+ let focusedElement = await page.evaluate(() => {
810
+ const el = document.querySelector("ic-search-bar").shadowRoot;
811
+ return el.activeElement.id;
812
+ });
813
+ expect(focusedElement).toBe("ic-search-bar-input-0-menu-qux");
814
+ await page.waitForChanges();
815
+ await page.keyboard.press("Tab");
816
+ await page.waitForChanges();
817
+ focusedElement = await page.evaluate(() => {
818
+ return document.activeElement.id;
819
+ });
820
+ expect(focusedElement).toBe("button");
752
821
  });
753
- expect(clearTooltipDisplay).toBe("block");
754
- await page.keyboard.press("Tab");
755
- await page.waitForTimeout(300);
756
- submitSearchTooltipDisplay = await page.evaluate(() => {
757
- const tooltip = document
758
- .querySelector("ic-search-bar")
759
- .shadowRoot.querySelector("#search-submit-button")
760
- .shadowRoot.querySelector("ic-tooltip")
761
- .shadowRoot.querySelector(".ic-tooltip-container");
762
- return window.getComputedStyle(tooltip).display;
822
+ it("should emit icChange on delay", async () => {
823
+ const page = await newE2EPage();
824
+ await page.setContent(`<ic-search-bar label="Test Label" debounce="500"></ic-search-bar>`);
825
+ await page.waitForChanges();
826
+ const icChange = await page.spyOnEvent("icChange");
827
+ await focusAndTypeIntoInput("foo", page);
828
+ await page.waitForTimeout(600);
829
+ expect(icChange).toHaveReceivedEventDetail({
830
+ value: "foo",
831
+ });
832
+ await focusAndTypeIntoInput("bar", page);
833
+ await page.waitForChanges();
834
+ await page.waitForTimeout(100);
835
+ expect(icChange).toHaveReceivedEventDetail({
836
+ value: "foo",
837
+ });
838
+ await page.waitForTimeout(500);
839
+ expect(icChange).toHaveReceivedEventDetail({
840
+ value: "foobar",
841
+ });
763
842
  });
764
- expect(submitSearchTooltipDisplay).toBe("block");
765
- });
766
- it("should highlight first option again after no results found", async () => {
767
- const page = await newE2EPage();
768
- await page.setContent(`
843
+ it("should highlight the menu option items in the correct order with arrowDown", async () => {
844
+ const page = await newE2EPage();
845
+ await page.setContent(`
769
846
  <ic-search-bar label="Test Label"></ic-search-bar>
770
847
  `);
771
- const searchBar = await page.find("ic-search-bar");
772
- searchBar.setProperty("options", options);
773
- await page.waitForChanges();
774
- await focusAndTypeIntoInput("barr", page);
775
- await page.waitForChanges();
776
- const noOptionsLabel = await page.evaluate(() => {
777
- const menuEl = document
778
- .querySelector("ic-search-bar")
779
- .shadowRoot.querySelector("ic-menu");
780
- const noOptionsItem = menuEl.querySelectorAll("li")[0];
781
- return noOptionsItem.innerText;
848
+ const searchBar = await page.find("ic-search-bar");
849
+ searchBar.setProperty("options", longOptions);
850
+ await page.waitForChanges();
851
+ await focusAndTypeIntoInput("it", page);
852
+ await page.waitForChanges();
853
+ const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
854
+ // First option has focused-option
855
+ let option = (await menu.findAll("li"))[0];
856
+ expect(option).toHaveClass("focused-option");
857
+ // Other options should not
858
+ for (let i = 1; i < longOptions.length; i++) {
859
+ option = (await menu.findAll("li"))[i];
860
+ expect(option).not.toHaveClass("focused-option");
861
+ }
862
+ // Highlight the next option
863
+ await page.keyboard.press("ArrowDown");
864
+ await page.waitForChanges();
865
+ option = (await menu.findAll("li"))[1];
866
+ expect(option).toHaveClass("focused-option");
867
+ for (let i = 2; i < longOptions.length; i++) {
868
+ option = (await menu.findAll("li"))[i];
869
+ expect(option).not.toHaveClass("focused-option");
870
+ }
871
+ await page.keyboard.press("ArrowDown");
872
+ await page.waitForChanges();
873
+ option = (await menu.findAll("li"))[2];
874
+ expect(option).toHaveClass("focused-option");
875
+ for (let i = 3; i < longOptions.length; i++) {
876
+ option = (await menu.findAll("li"))[i];
877
+ expect(option).not.toHaveClass("focused-option");
878
+ }
782
879
  });
783
- expect(noOptionsLabel).toBe("No results found");
784
- await page.waitForChanges();
785
- await page.keyboard.press("Backspace");
786
- await page.waitForTimeout(500);
787
- const firstOptionFocused = await page.evaluate(() => {
788
- const menuEl = document
789
- .querySelector("ic-search-bar")
790
- .shadowRoot.querySelector("ic-menu");
791
- const firstOptionItem = menuEl.querySelectorAll("li")[0];
792
- return firstOptionItem.classList.contains("focused-option");
793
- });
794
- expect(firstOptionFocused).toBeTruthy();
795
- });
796
- it("focuses onto button from search bar", async () => {
797
- const page = await newE2EPage();
798
- await page.setContent(`
880
+ it("should highlight the menu option items in the correct order with arrowUp", async () => {
881
+ const page = await newE2EPage();
882
+ await page.setContent(`
799
883
  <ic-search-bar label="Test Label"></ic-search-bar>
800
- <ic-button id="button">Foo</ic-button>
801
884
  `);
802
- const searchBar = await page.find("ic-search-bar");
803
- searchBar.setProperty("options", options);
804
- await page.waitForChanges();
805
- await focusAndTypeIntoInput("ba", page);
806
- await page.waitForChanges();
807
- await page.keyboard.press("ArrowDown");
808
- await page.waitForChanges();
809
- let focusedElement = await page.evaluate(() => {
810
- const el = document.querySelector("ic-search-bar").shadowRoot;
811
- return el.activeElement.id;
885
+ const searchBar = await page.find("ic-search-bar");
886
+ searchBar.setProperty("options", longOptions);
887
+ await page.waitForChanges();
888
+ await focusAndTypeIntoInput("it", page);
889
+ await page.waitForChanges();
890
+ const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
891
+ // First option has focused-option class
892
+ let option = (await menu.findAll("li"))[0];
893
+ expect(option).toHaveClass("focused-option");
894
+ // Other options should not have focused-option class
895
+ for (let i = 1; i < longOptions.length; i++) {
896
+ option = (await menu.findAll("li"))[i];
897
+ expect(option).not.toHaveClass("focused-option");
898
+ }
899
+ // Highlight the last option
900
+ await page.keyboard.press("ArrowUp");
901
+ await page.waitForChanges();
902
+ option = (await menu.findAll("li"))[longOptions.length - 1];
903
+ expect(option).toHaveClass("focused-option");
904
+ for (let i = longOptions.length - 2; i >= 0; i--) {
905
+ option = (await menu.findAll("li"))[i];
906
+ expect(option).not.toHaveClass("focused-option");
907
+ }
908
+ await page.keyboard.press("ArrowUp");
909
+ await page.waitForChanges();
910
+ option = (await menu.findAll("li"))[longOptions.length - 2];
911
+ expect(option).toHaveClass("focused-option");
912
+ for (let i = longOptions.length - 3; i >= 0; i--) {
913
+ option = (await menu.findAll("li"))[i];
914
+ expect(option).not.toHaveClass("focused-option");
915
+ }
812
916
  });
813
- expect(focusedElement).toBe("ic-search-bar-input-0-menu-qux");
814
- await page.waitForChanges();
815
- await page.keyboard.press("Tab");
816
- await page.waitForChanges();
817
- focusedElement = await page.evaluate(() => {
818
- return document.activeElement.id;
917
+ it("should reverse tab to submit button", async () => {
918
+ const page = await newE2EPage();
919
+ await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
920
+ const searchBar = await page.find("ic-search-bar");
921
+ searchBar.setProperty("options", options);
922
+ await page.waitForChanges();
923
+ await focusAndTypeIntoInput("foo", page);
924
+ await page.waitForChanges();
925
+ await page.keyboard.down("ArrowDown");
926
+ await page.waitForChanges();
927
+ await page.keyboard.down("Shift");
928
+ await page.keyboard.press("Tab");
929
+ await page.waitForChanges();
930
+ const activeElId = await page.$eval("ic-search-bar", (el) => {
931
+ return el.shadowRoot.activeElement.id;
932
+ });
933
+ expect(activeElId).toBe("search-submit-button");
819
934
  });
820
- expect(focusedElement).toBe("button");
821
- });
822
- it("should emit icChange on delay", async () => {
823
- const page = await newE2EPage();
824
- await page.setContent(`<ic-search-bar label="Test Label" debounce="500"></ic-search-bar>`);
825
- await page.waitForChanges();
826
- const icChange = await page.spyOnEvent("icChange");
827
- await focusAndTypeIntoInput("foo", page);
828
- await page.waitForTimeout(600);
829
- expect(icChange).toHaveReceivedEventDetail({
830
- value: "foo",
935
+ it("should not filter options when disable-filter is set to true", async () => {
936
+ const page = await newE2EPage();
937
+ await page.setContent(`<ic-search-bar label="Test Label" disable-filter="true"></ic-search-bar>`);
938
+ const searchBar = await page.find("ic-search-bar");
939
+ searchBar.setProperty("options", options);
940
+ await page.waitForChanges();
941
+ await focusAndTypeIntoInput("foo", page);
942
+ await page.waitForChanges();
943
+ const menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
944
+ expect(menuOptions).toHaveLength(options.length);
831
945
  });
832
- await focusAndTypeIntoInput("bar", page);
833
- await page.waitForChanges();
834
- await page.waitForTimeout(100);
835
- expect(icChange).toHaveReceivedEventDetail({
836
- value: "foo",
946
+ it("should select the highlighted option when submit search is clicked", async () => {
947
+ const page = await newE2EPage();
948
+ await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
949
+ const searchBar = await page.find("ic-search-bar");
950
+ const searchSubmitButton = await page.find("ic-search-bar >>> ic-text-field ic-button.search-submit-button");
951
+ searchBar.setProperty("options", options);
952
+ await page.waitForChanges();
953
+ // Select first filtered option
954
+ await focusAndTypeIntoInput("ba", page);
955
+ await page.waitForChanges();
956
+ let menuOption = (await page.findAll("ic-search-bar >>> ic-text-field ic-menu li"))[0];
957
+ expect(menuOption).toHaveClass("focused-option");
958
+ expect(menuOption).toEqualText("bar");
959
+ await searchSubmitButton.click();
960
+ await page.waitForChanges();
961
+ expect(await searchBar.getProperty("value")).toBe("bar");
962
+ // Select second filtered option
963
+ const clearButton = await page.find("ic-search-bar >>> ic-text-field ic-button.clear-button");
964
+ await clearButton.click();
965
+ await page.waitForChanges();
966
+ await focusAndTypeIntoInput("ba", page);
967
+ await page.waitForChanges();
968
+ await page.keyboard.press("ArrowUp");
969
+ await page.waitForChanges();
970
+ menuOption = (await page.findAll("ic-search-bar >>> ic-text-field ic-menu li"))[1];
971
+ expect(menuOption).toHaveClass("focused-option");
972
+ expect(menuOption).toEqualText("baz");
973
+ await searchSubmitButton.click();
974
+ await page.waitForChanges();
975
+ expect(await searchBar.getProperty("value")).toBe("qux");
837
976
  });
838
- await page.waitForTimeout(500);
839
- expect(icChange).toHaveReceivedEventDetail({
840
- value: "foobar",
977
+ it("should display the loading option in the menu when loading then cancel loading when options provided", async () => {
978
+ const page = await newE2EPage();
979
+ await page.setContent(`<ic-search-bar label="Test Label" loading-label="load" disable-filter="true"></ic-search-bar>`);
980
+ const searchBar = await page.find("ic-search-bar");
981
+ searchBar.setProperty("options", options);
982
+ await page.waitForChanges();
983
+ await focusAndTypeIntoInput("ba", page);
984
+ searchBar.setProperty("loading", true);
985
+ await page.waitForChanges();
986
+ let menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
987
+ expect(menuOptions).toHaveLength(1);
988
+ expect(menuOptions[0]).toHaveClass("loading-option");
989
+ expect(menuOptions[0]).toEqualText("load");
990
+ searchBar.setProperty("options", options);
991
+ await page.waitForChanges();
992
+ menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
993
+ expect(menuOptions).toHaveLength(3);
994
+ expect(menuOptions[0]).not.toHaveClass("loading-option");
995
+ expect(searchBar.getProperty("loading")).toBeFalsy;
841
996
  });
842
- });
843
- it("should highlight the menu option items in the correct order with arrowDown", async () => {
844
- const page = await newE2EPage();
845
- await page.setContent(`
846
- <ic-search-bar label="Test Label"></ic-search-bar>
847
- `);
848
- const searchBar = await page.find("ic-search-bar");
849
- searchBar.setProperty("options", longOptions);
850
- await page.waitForChanges();
851
- await focusAndTypeIntoInput("it", page);
852
- await page.waitForChanges();
853
- const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
854
- // First option has focused-option
855
- let option = (await menu.findAll("li"))[0];
856
- expect(option).toHaveClass("focused-option");
857
- // Other options should not
858
- for (let i = 1; i < longOptions.length; i++) {
859
- option = (await menu.findAll("li"))[i];
860
- expect(option).not.toHaveClass("focused-option");
861
- }
862
- // Highlight the next option
863
- await page.keyboard.press("ArrowDown");
864
- await page.waitForChanges();
865
- option = (await menu.findAll("li"))[1];
866
- expect(option).toHaveClass("focused-option");
867
- for (let i = 2; i < longOptions.length; i++) {
868
- option = (await menu.findAll("li"))[i];
869
- expect(option).not.toHaveClass("focused-option");
870
- }
871
- await page.keyboard.press("ArrowDown");
872
- await page.waitForChanges();
873
- option = (await menu.findAll("li"))[2];
874
- expect(option).toHaveClass("focused-option");
875
- for (let i = 3; i < longOptions.length; i++) {
876
- option = (await menu.findAll("li"))[i];
877
- expect(option).not.toHaveClass("focused-option");
878
- }
879
- });
880
- it("should highlight the menu option items in the correct order with arrowUp", async () => {
881
- const page = await newE2EPage();
882
- await page.setContent(`
883
- <ic-search-bar label="Test Label"></ic-search-bar>
884
- `);
885
- const searchBar = await page.find("ic-search-bar");
886
- searchBar.setProperty("options", longOptions);
887
- await page.waitForChanges();
888
- await focusAndTypeIntoInput("it", page);
889
- await page.waitForChanges();
890
- const menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
891
- // First option has focused-option class
892
- let option = (await menu.findAll("li"))[0];
893
- expect(option).toHaveClass("focused-option");
894
- // Other options should not have focused-option class
895
- for (let i = 1; i < longOptions.length; i++) {
896
- option = (await menu.findAll("li"))[i];
897
- expect(option).not.toHaveClass("focused-option");
898
- }
899
- // Highlight the last option
900
- await page.keyboard.press("ArrowUp");
901
- await page.waitForChanges();
902
- option = (await menu.findAll("li"))[longOptions.length - 1];
903
- expect(option).toHaveClass("focused-option");
904
- for (let i = longOptions.length - 2; i >= 0; i--) {
905
- option = (await menu.findAll("li"))[i];
906
- expect(option).not.toHaveClass("focused-option");
907
- }
908
- await page.keyboard.press("ArrowUp");
909
- await page.waitForChanges();
910
- option = (await menu.findAll("li"))[longOptions.length - 2];
911
- expect(option).toHaveClass("focused-option");
912
- for (let i = longOptions.length - 3; i >= 0; i--) {
913
- option = (await menu.findAll("li"))[i];
914
- expect(option).not.toHaveClass("focused-option");
915
- }
916
- });
917
- it("should reverse tab to submit button", async () => {
918
- const page = await newE2EPage();
919
- await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
920
- const searchBar = await page.find("ic-search-bar");
921
- searchBar.setProperty("options", options);
922
- await page.waitForChanges();
923
- await focusAndTypeIntoInput("foo", page);
924
- await page.waitForChanges();
925
- await page.keyboard.down("ArrowDown");
926
- await page.waitForChanges();
927
- await page.keyboard.down("Shift");
928
- await page.keyboard.press("Tab");
929
- await page.waitForChanges();
930
- const activeElId = await page.$eval("ic-search-bar", (el) => {
931
- return el.shadowRoot.activeElement.id;
997
+ it("should display the timeout state in the menu when timed out and should not update the options", async () => {
998
+ const page = await newE2EPage();
999
+ await page.setContent(`<ic-search-bar label="Test Label" loading-error-label="error message" timeout="1000" disable-filter="true"></ic-search-bar>`);
1000
+ const searchBar = await page.find("ic-search-bar");
1001
+ searchBar.setProperty("options", options);
1002
+ await page.waitForChanges();
1003
+ await focusAndTypeIntoInput("ba", page);
1004
+ searchBar.setProperty("loading", true);
1005
+ await page.waitForChanges();
1006
+ await page.waitForTimeout(1000);
1007
+ const menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
1008
+ expect(menuOptions).toHaveLength(1);
1009
+ expect(menuOptions[0]).toHaveClass("timeout");
1010
+ expect(await menuOptions[0].find("ic-typography")).toEqualText("error message");
1011
+ expect(await menuOptions[0].find("#retry-button")).not.toBeNull;
1012
+ const searchSubmitButton = await page.find("ic-search-bar >>> ic-text-field ic-button.search-submit-button");
1013
+ expect(await searchSubmitButton.getProperty("disabled")).toBeTruthy;
1014
+ searchBar.setProperty("options", options);
1015
+ await page.waitForChanges();
1016
+ expect(menuOptions).toHaveLength(1);
1017
+ expect(menuOptions[0]).toHaveClass("timeout");
1018
+ });
1019
+ it("should be able to focus retry button using tab and should keep loading state when menu closed", async () => {
1020
+ const page = await newE2EPage();
1021
+ await page.setContent(`<ic-search-bar label="Test Label" timeout="1000" disable-filter="true"></ic-search-bar>`);
1022
+ const searchBar = await page.find("ic-search-bar");
1023
+ searchBar.setProperty("options", options);
1024
+ await page.waitForChanges();
1025
+ await focusAndTypeIntoInput("ba", page);
1026
+ searchBar.setProperty("loading", true);
1027
+ await page.waitForChanges();
1028
+ await page.waitForTimeout(1000);
1029
+ await page.keyboard.press("Tab");
1030
+ await page.keyboard.press("Tab");
1031
+ await page.waitForChanges();
1032
+ const activeElId = await page.$eval("ic-search-bar", (el) => el.shadowRoot.activeElement.id);
1033
+ expect(activeElId).toBe("retry-button");
1034
+ await page.keyboard.press("Tab");
1035
+ await page.waitForChanges();
1036
+ let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
1037
+ expect(menu).toBeNull;
1038
+ await page.keyboard.down("Shift");
1039
+ await page.keyboard.press("Tab");
1040
+ await page.waitForChanges();
1041
+ menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
1042
+ expect(await menu.isVisible()).toBeTruthy;
1043
+ expect(await menu.findAll("li")).toHaveLength(1);
1044
+ });
1045
+ it("should trigger a retry when the retry button is pressed using space and enter", async () => {
1046
+ const page = await newE2EPage();
1047
+ await page.setContent(`<ic-search-bar label="Test Label" timeout="1000" disable-filter="true"></ic-search-bar>`);
1048
+ const searchBar = await page.find("ic-search-bar");
1049
+ searchBar.setProperty("options", options);
1050
+ await page.waitForChanges();
1051
+ await focusAndTypeIntoInput("ba", page);
1052
+ searchBar.setProperty("loading", true);
1053
+ await page.waitForChanges();
1054
+ await page.waitForTimeout(1000);
1055
+ await page.keyboard.press("Tab");
1056
+ await page.keyboard.press("Tab");
1057
+ await page.waitForChanges();
1058
+ const retryButton = await page.find("ic-search-bar >>> ic-text-field ic-menu #retry-button");
1059
+ await retryButton.press("Enter");
1060
+ await page.waitForChanges();
1061
+ let menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
1062
+ expect(menuOptions[0]).toEqualText("Loading...");
1063
+ await page.waitForTimeout(1000);
1064
+ await page.keyboard.press("Tab");
1065
+ await page.keyboard.press("Tab");
1066
+ await page.waitForChanges();
1067
+ await retryButton.press(" ");
1068
+ await page.waitForChanges();
1069
+ menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
1070
+ expect(menuOptions[0]).toEqualText("Loading...");
1071
+ });
1072
+ it("should cancel loading when clear button is pressed", async () => {
1073
+ const page = await newE2EPage();
1074
+ await page.setContent(`<ic-search-bar label="Test Label" timeout="1000"></ic-search-bar>`);
1075
+ const searchBar = await page.find("ic-search-bar");
1076
+ searchBar.setProperty("options", options);
1077
+ await page.waitForChanges();
1078
+ await focusAndTypeIntoInput("ba", page);
1079
+ searchBar.setProperty("loading", true);
1080
+ await page.waitForChanges();
1081
+ await page.waitForTimeout(1000);
1082
+ const clearButton = await page.find("ic-search-bar >>> ic-text-field .clear-button");
1083
+ await clearButton.click();
1084
+ await page.waitForChanges();
1085
+ await focusAndTypeIntoInput("ba", page);
1086
+ searchBar.setProperty("loading", true);
1087
+ await page.waitForChanges();
1088
+ await page.waitForTimeout(750);
1089
+ let menuOption = await page.find("ic-search-bar >>> ic-text-field ic-menu li");
1090
+ expect(menuOption).toEqualText("Loading...");
1091
+ await clearButton.click();
1092
+ await page.waitForChanges();
1093
+ //Check that the timeout was cancelled
1094
+ await page.waitForTimeout(1000);
1095
+ await searchBar.click();
1096
+ await page.waitForChanges();
1097
+ expect(await page.find("ic-search-bar >>> ic-text-field ic-menu")).toBeNull;
1098
+ await focusAndTypeIntoInput("ba", page);
1099
+ searchBar.setProperty("loading", true);
1100
+ await page.waitForChanges();
1101
+ await page.waitForTimeout(750);
1102
+ menuOption = await page.find("ic-search-bar >>> ic-text-field ic-menu li");
1103
+ expect(menuOption).toEqualText("Loading...");
932
1104
  });
933
- expect(activeElId).toBe("search-submit-button");
934
- });
935
- it("should not filter options when disable-filter is set to true", async () => {
936
- const page = await newE2EPage();
937
- await page.setContent(`<ic-search-bar label="Test Label" disable-filter="true"></ic-search-bar>`);
938
- const searchBar = await page.find("ic-search-bar");
939
- searchBar.setProperty("options", options);
940
- await page.waitForChanges();
941
- await focusAndTypeIntoInput("foo", page);
942
- await page.waitForChanges();
943
- const menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
944
- expect(menuOptions).toHaveLength(options.length);
945
- });
946
- it("should select the highlighted option when submit search is clicked", async () => {
947
- const page = await newE2EPage();
948
- await page.setContent(`<ic-search-bar label="Test Label"></ic-search-bar>`);
949
- const searchBar = await page.find("ic-search-bar");
950
- const searchSubmitButton = await page.find("ic-search-bar >>> ic-text-field ic-button.search-submit-button");
951
- searchBar.setProperty("options", options);
952
- await page.waitForChanges();
953
- // Select first filtered option
954
- await focusAndTypeIntoInput("ba", page);
955
- await page.waitForChanges();
956
- let menuOption = (await page.findAll("ic-search-bar >>> ic-text-field ic-menu li"))[0];
957
- expect(menuOption).toHaveClass("focused-option");
958
- expect(menuOption).toEqualText("bar");
959
- await searchSubmitButton.click();
960
- await page.waitForChanges();
961
- expect(await searchBar.getProperty("value")).toBe("bar");
962
- // Select second filtered option
963
- const clearButton = await page.find("ic-search-bar >>> ic-text-field ic-button.clear-button");
964
- await clearButton.click();
965
- await page.waitForChanges();
966
- await focusAndTypeIntoInput("ba", page);
967
- await page.waitForChanges();
968
- await page.keyboard.press("ArrowUp");
969
- await page.waitForChanges();
970
- menuOption = (await page.findAll("ic-search-bar >>> ic-text-field ic-menu li"))[1];
971
- expect(menuOption).toHaveClass("focused-option");
972
- expect(menuOption).toEqualText("baz");
973
- await searchSubmitButton.click();
974
- await page.waitForChanges();
975
- expect(await searchBar.getProperty("value")).toBe("qux");
976
- });
977
- it("should display the loading option in the menu when loading then cancel loading when options provided", async () => {
978
- const page = await newE2EPage();
979
- await page.setContent(`<ic-search-bar label="Test Label" loading-label="load" disable-filter="true"></ic-search-bar>`);
980
- const searchBar = await page.find("ic-search-bar");
981
- searchBar.setProperty("options", options);
982
- await page.waitForChanges();
983
- await focusAndTypeIntoInput("ba", page);
984
- searchBar.setProperty("loading", true);
985
- await page.waitForChanges();
986
- let menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
987
- expect(menuOptions).toHaveLength(1);
988
- expect(menuOptions[0]).toHaveClass("loading-option");
989
- expect(menuOptions[0]).toEqualText("load");
990
- searchBar.setProperty("options", options);
991
- await page.waitForChanges();
992
- menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
993
- expect(menuOptions).toHaveLength(3);
994
- expect(menuOptions[0]).not.toHaveClass("loading-option");
995
- expect(searchBar.getProperty("loading")).toBeFalsy;
996
- });
997
- it("should display the timeout state in the menu when timed out and should not update the options", async () => {
998
- const page = await newE2EPage();
999
- await page.setContent(`<ic-search-bar label="Test Label" loading-error-label="error message" timeout="1000" disable-filter="true"></ic-search-bar>`);
1000
- const searchBar = await page.find("ic-search-bar");
1001
- searchBar.setProperty("options", options);
1002
- await page.waitForChanges();
1003
- await focusAndTypeIntoInput("ba", page);
1004
- searchBar.setProperty("loading", true);
1005
- await page.waitForChanges();
1006
- await page.waitForTimeout(1000);
1007
- const menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
1008
- expect(menuOptions).toHaveLength(1);
1009
- expect(menuOptions[0]).toHaveClass("timeout");
1010
- expect(await menuOptions[0].find("ic-typography")).toEqualText("error message");
1011
- expect(await menuOptions[0].find("#retry-button")).not.toBeNull;
1012
- const searchSubmitButton = await page.find("ic-search-bar >>> ic-text-field ic-button.search-submit-button");
1013
- expect(await searchSubmitButton.getProperty("disabled")).toBeTruthy;
1014
- searchBar.setProperty("options", options);
1015
- await page.waitForChanges();
1016
- expect(menuOptions).toHaveLength(1);
1017
- expect(menuOptions[0]).toHaveClass("timeout");
1018
- });
1019
- it("should be able to focus retry button using tab and should keep loading state when menu closed", async () => {
1020
- const page = await newE2EPage();
1021
- await page.setContent(`<ic-search-bar label="Test Label" timeout="1000" disable-filter="true"></ic-search-bar>`);
1022
- const searchBar = await page.find("ic-search-bar");
1023
- searchBar.setProperty("options", options);
1024
- await page.waitForChanges();
1025
- await focusAndTypeIntoInput("ba", page);
1026
- searchBar.setProperty("loading", true);
1027
- await page.waitForChanges();
1028
- await page.waitForTimeout(1000);
1029
- await page.keyboard.press("Tab");
1030
- await page.keyboard.press("Tab");
1031
- await page.waitForChanges();
1032
- const activeElId = await page.$eval("ic-search-bar", (el) => el.shadowRoot.activeElement.id);
1033
- expect(activeElId).toBe("retry-button");
1034
- await page.keyboard.press("Tab");
1035
- await page.waitForChanges();
1036
- let menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
1037
- expect(menu).toBeNull;
1038
- await page.keyboard.down("Shift");
1039
- await page.keyboard.press("Tab");
1040
- await page.waitForChanges();
1041
- menu = await page.find("ic-search-bar >>> ic-text-field ic-menu");
1042
- expect(await menu.isVisible()).toBeTruthy;
1043
- expect(await menu.findAll("li")).toHaveLength(1);
1044
- });
1045
- it("should trigger a retry when the retry button is pressed using space and enter", async () => {
1046
- const page = await newE2EPage();
1047
- await page.setContent(`<ic-search-bar label="Test Label" timeout="1000" disable-filter="true"></ic-search-bar>`);
1048
- const searchBar = await page.find("ic-search-bar");
1049
- searchBar.setProperty("options", options);
1050
- await page.waitForChanges();
1051
- await focusAndTypeIntoInput("ba", page);
1052
- searchBar.setProperty("loading", true);
1053
- await page.waitForChanges();
1054
- await page.waitForTimeout(1000);
1055
- await page.keyboard.press("Tab");
1056
- await page.keyboard.press("Tab");
1057
- await page.waitForChanges();
1058
- const retryButton = await page.find("ic-search-bar >>> ic-text-field ic-menu #retry-button");
1059
- await retryButton.press("Enter");
1060
- await page.waitForChanges();
1061
- let menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
1062
- expect(menuOptions[0]).toEqualText("Loading...");
1063
- await page.waitForTimeout(1000);
1064
- await page.keyboard.press("Tab");
1065
- await page.keyboard.press("Tab");
1066
- await page.waitForChanges();
1067
- await retryButton.press(" ");
1068
- await page.waitForChanges();
1069
- menuOptions = await page.findAll("ic-search-bar >>> ic-text-field ic-menu li");
1070
- expect(menuOptions[0]).toEqualText("Loading...");
1071
- });
1072
- it("should cancel loading when clear button is pressed", async () => {
1073
- const page = await newE2EPage();
1074
- await page.setContent(`<ic-search-bar label="Test Label" timeout="1000"></ic-search-bar>`);
1075
- const searchBar = await page.find("ic-search-bar");
1076
- searchBar.setProperty("options", options);
1077
- await page.waitForChanges();
1078
- await focusAndTypeIntoInput("ba", page);
1079
- searchBar.setProperty("loading", true);
1080
- await page.waitForChanges();
1081
- await page.waitForTimeout(1000);
1082
- const clearButton = await page.find("ic-search-bar >>> ic-text-field .clear-button");
1083
- await clearButton.click();
1084
- await page.waitForChanges();
1085
- await focusAndTypeIntoInput("ba", page);
1086
- searchBar.setProperty("loading", true);
1087
- await page.waitForChanges();
1088
- await page.waitForTimeout(750);
1089
- let menuOption = await page.find("ic-search-bar >>> ic-text-field ic-menu li");
1090
- expect(menuOption).toEqualText("Loading...");
1091
- await clearButton.click();
1092
- await page.waitForChanges();
1093
- //Check that the timeout was cancelled
1094
- await page.waitForTimeout(1000);
1095
- await searchBar.click();
1096
- await page.waitForChanges();
1097
- expect(await page.find("ic-search-bar >>> ic-text-field ic-menu")).toBeNull;
1098
- await focusAndTypeIntoInput("ba", page);
1099
- searchBar.setProperty("loading", true);
1100
- await page.waitForChanges();
1101
- await page.waitForTimeout(750);
1102
- menuOption = await page.find("ic-search-bar >>> ic-text-field ic-menu li");
1103
- expect(menuOption).toEqualText("Loading...");
1104
- });
1105
1105
  });
1106
1106
  //# sourceMappingURL=ic-search-bar.e2e.js.map