@ukic/web-components 2.1.0-beta.15 → 2.1.0-beta.16

Sign up to get free protection for your applications and to get access to all the features.
Files changed (744) hide show
  1. package/dist/cjs/core.cjs.js +10 -3
  2. package/dist/cjs/core.cjs.js.map +1 -1
  3. package/dist/cjs/{helpers-d6b5880e.js → helpers-eb53c416.js} +7 -1
  4. package/dist/cjs/helpers-eb53c416.js.map +1 -0
  5. package/dist/cjs/ic-alert.cjs.entry.js +2 -2
  6. package/dist/cjs/ic-back-to-top.cjs.entry.js +2 -2
  7. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +2 -2
  8. package/dist/cjs/ic-breadcrumb.cjs.entry.js +2 -2
  9. package/dist/cjs/ic-button_3.cjs.entry.js +31 -31
  10. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  11. package/dist/cjs/ic-card.cjs.entry.js +4 -3
  12. package/dist/cjs/ic-card.cjs.entry.js.map +1 -1
  13. package/dist/cjs/ic-checkbox-group.cjs.entry.js +5 -2
  14. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  15. package/dist/cjs/ic-checkbox.cjs.entry.js +3 -2
  16. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -1
  17. package/dist/cjs/ic-chip.cjs.entry.js +5 -2
  18. package/dist/cjs/ic-chip.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ic-classification-banner.cjs.entry.js +1 -1
  20. package/dist/cjs/ic-data-entity.cjs.entry.js +1 -1
  21. package/dist/cjs/ic-data-row.cjs.entry.js +2 -2
  22. package/dist/cjs/ic-dialog.cjs.entry.js +296 -0
  23. package/dist/cjs/ic-dialog.cjs.entry.js.map +1 -0
  24. package/dist/cjs/ic-divider.cjs.entry.js +2 -2
  25. package/dist/cjs/ic-footer-link-group.cjs.entry.js +2 -2
  26. package/dist/cjs/ic-footer-link.cjs.entry.js +2 -2
  27. package/dist/cjs/ic-footer.cjs.entry.js +3 -3
  28. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -1
  29. package/dist/cjs/ic-hero.cjs.entry.js +2 -2
  30. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +2 -2
  31. package/dist/cjs/ic-input-component-container_3.cjs.entry.js +65 -26
  32. package/dist/cjs/ic-input-component-container_3.cjs.entry.js.map +1 -1
  33. package/dist/cjs/ic-input-label_2.cjs.entry.js +3 -3
  34. package/dist/cjs/ic-input-label_2.cjs.entry.js.map +1 -1
  35. package/dist/cjs/ic-link.cjs.entry.js +2 -2
  36. package/dist/cjs/ic-menu-group.cjs.entry.js +1 -1
  37. package/dist/cjs/ic-menu-item.cjs.entry.js +4 -3
  38. package/dist/cjs/ic-menu-item.cjs.entry.js.map +1 -1
  39. package/dist/cjs/ic-navigation-button.cjs.entry.js +2 -2
  40. package/dist/cjs/ic-navigation-group.cjs.entry.js +44 -18
  41. package/dist/cjs/ic-navigation-group.cjs.entry.js.map +1 -1
  42. package/dist/cjs/ic-navigation-item.cjs.entry.js +2 -2
  43. package/dist/cjs/ic-navigation-menu.cjs.entry.js +2 -2
  44. package/dist/cjs/ic-page-header.cjs.entry.js +3 -3
  45. package/dist/cjs/ic-page-header.cjs.entry.js.map +1 -1
  46. package/dist/cjs/ic-pagination-item.cjs.entry.js +6 -1
  47. package/dist/cjs/ic-pagination-item.cjs.entry.js.map +1 -1
  48. package/dist/cjs/ic-pagination.cjs.entry.js +3 -2
  49. package/dist/cjs/ic-pagination.cjs.entry.js.map +1 -1
  50. package/dist/cjs/ic-popover-menu.cjs.entry.js +3 -3
  51. package/dist/cjs/ic-popover-menu.cjs.entry.js.map +1 -1
  52. package/dist/cjs/ic-radio-group.cjs.entry.js +16 -5
  53. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -1
  54. package/dist/cjs/ic-radio-option.cjs.entry.js +5 -11
  55. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  56. package/dist/cjs/ic-search-bar.cjs.entry.js +6 -3
  57. package/dist/cjs/ic-search-bar.cjs.entry.js.map +1 -1
  58. package/dist/cjs/ic-section-container.cjs.entry.js +1 -1
  59. package/dist/cjs/ic-select.cjs.entry.js +34 -32
  60. package/dist/cjs/ic-select.cjs.entry.js.map +1 -1
  61. package/dist/cjs/ic-side-navigation.cjs.entry.js +51 -42
  62. package/dist/cjs/ic-side-navigation.cjs.entry.js.map +1 -1
  63. package/dist/cjs/ic-skeleton.cjs.entry.js +1 -1
  64. package/dist/cjs/ic-status-tag.cjs.entry.js +3 -3
  65. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -1
  66. package/dist/cjs/ic-step.cjs.entry.js +1 -1
  67. package/dist/cjs/ic-stepper.cjs.entry.js +2 -2
  68. package/dist/cjs/ic-switch.cjs.entry.js +4 -3
  69. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  70. package/dist/cjs/ic-tab-context.cjs.entry.js +1 -1
  71. package/dist/cjs/ic-tab-group.cjs.entry.js +3 -3
  72. package/dist/cjs/ic-tab-group.cjs.entry.js.map +1 -1
  73. package/dist/cjs/ic-tab-panel.cjs.entry.js +1 -1
  74. package/dist/cjs/ic-tab.cjs.entry.js +5 -1
  75. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -1
  76. package/dist/cjs/ic-text-field.cjs.entry.js +4 -5
  77. package/dist/cjs/ic-text-field.cjs.entry.js.map +1 -1
  78. package/dist/cjs/ic-theme.cjs.entry.js +2 -2
  79. package/dist/cjs/ic-toast-region.cjs.entry.js +1 -1
  80. package/dist/cjs/ic-toast.cjs.entry.js +2 -2
  81. package/dist/cjs/ic-top-navigation.cjs.entry.js +2 -2
  82. package/dist/cjs/ic-typography.cjs.entry.js +2 -2
  83. package/dist/cjs/{index-a62312a7.js → index-014e3058.js} +222 -43
  84. package/dist/cjs/index-014e3058.js.map +1 -0
  85. package/dist/cjs/loader.cjs.js +4 -3
  86. package/dist/cjs/loader.cjs.js.map +1 -1
  87. package/dist/collection/collection-manifest.json +13 -12
  88. package/dist/collection/components/ic-alert/ic-alert.e2e.js +16 -0
  89. package/dist/collection/components/ic-alert/ic-alert.e2e.js.map +1 -0
  90. package/dist/collection/components/ic-alert/ic-alert.spec.js +182 -0
  91. package/dist/collection/components/ic-alert/ic-alert.spec.js.map +1 -0
  92. package/dist/collection/components/ic-back-to-top/ic-back-to-top.e2e.js +68 -0
  93. package/dist/collection/components/ic-back-to-top/ic-back-to-top.e2e.js.map +1 -0
  94. package/dist/collection/components/ic-back-to-top/ic-back-to-top.spec.js +123 -0
  95. package/dist/collection/components/ic-back-to-top/ic-back-to-top.spec.js.map +1 -0
  96. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.spec.js +118 -0
  97. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.spec.js.map +1 -0
  98. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.e2e.js +41 -0
  99. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.e2e.js.map +1 -0
  100. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.spec.js +181 -0
  101. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.spec.js.map +1 -0
  102. package/dist/collection/components/ic-button/ic-button.e2e.js +173 -0
  103. package/dist/collection/components/ic-button/ic-button.e2e.js.map +1 -0
  104. package/dist/collection/components/ic-button/ic-button.js +3 -2
  105. package/dist/collection/components/ic-button/ic-button.js.map +1 -1
  106. package/dist/collection/components/ic-button/ic-button.spec.js +230 -0
  107. package/dist/collection/components/ic-button/ic-button.spec.js.map +1 -0
  108. package/dist/collection/components/ic-card/ic-card.css +3 -2
  109. package/dist/collection/components/ic-card/ic-card.e2e.js +23 -0
  110. package/dist/collection/components/ic-card/ic-card.e2e.js.map +1 -0
  111. package/dist/collection/components/ic-card/ic-card.js +2 -1
  112. package/dist/collection/components/ic-card/ic-card.js.map +1 -1
  113. package/dist/collection/components/ic-card/ic-card.spec.js +152 -0
  114. package/dist/collection/components/ic-card/ic-card.spec.js.map +1 -0
  115. package/dist/collection/components/ic-checkbox/ic-checkbox.js +2 -1
  116. package/dist/collection/components/ic-checkbox/ic-checkbox.js.map +1 -1
  117. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.e2e.js +201 -0
  118. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.e2e.js.map +1 -0
  119. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js +4 -1
  120. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js.map +1 -1
  121. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.spec.js +175 -0
  122. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.spec.js.map +1 -0
  123. package/dist/collection/components/ic-chip/ic-chip.js +4 -1
  124. package/dist/collection/components/ic-chip/ic-chip.js.map +1 -1
  125. package/dist/collection/components/ic-chip/ic-chip.spec.js +110 -0
  126. package/dist/collection/components/ic-chip/ic-chip.spec.js.map +1 -0
  127. package/dist/collection/components/ic-classification-banner/ic-classification-banner.spec.js +140 -0
  128. package/dist/collection/components/ic-classification-banner/ic-classification-banner.spec.js.map +1 -0
  129. package/dist/collection/components/ic-data-entity/ic-data-entity.spec.js +161 -0
  130. package/dist/collection/components/ic-data-entity/ic-data-entity.spec.js.map +1 -0
  131. package/dist/collection/components/ic-data-row/ic-data-row.spec.js +185 -0
  132. package/dist/collection/components/ic-data-row/ic-data-row.spec.js.map +1 -0
  133. package/dist/collection/components/ic-dialog/ic-dialog.css +595 -0
  134. package/dist/collection/components/ic-dialog/ic-dialog.e2e.js +204 -0
  135. package/dist/collection/components/ic-dialog/ic-dialog.e2e.js.map +1 -0
  136. package/dist/collection/components/ic-dialog/ic-dialog.js +641 -0
  137. package/dist/collection/components/ic-dialog/ic-dialog.js.map +1 -0
  138. package/dist/collection/components/ic-dialog/ic-dialog.spec.js +520 -0
  139. package/dist/collection/components/ic-dialog/ic-dialog.spec.js.map +1 -0
  140. package/dist/collection/components/ic-dialog/ic-dialog.test.a11y.js +28 -0
  141. package/dist/collection/components/ic-dialog/ic-dialog.test.a11y.js.map +1 -0
  142. package/dist/collection/components/ic-divider/ic-divider.spec.js +24 -0
  143. package/dist/collection/components/ic-divider/ic-divider.spec.js.map +1 -0
  144. package/dist/collection/components/ic-footer/ic-footer.e2e.js +50 -0
  145. package/dist/collection/components/ic-footer/ic-footer.e2e.js.map +1 -0
  146. package/dist/collection/components/ic-footer/ic-footer.js +1 -1
  147. package/dist/collection/components/ic-footer/ic-footer.js.map +1 -1
  148. package/dist/collection/components/ic-footer/ic-footer.spec.js +140 -0
  149. package/dist/collection/components/ic-footer/ic-footer.spec.js.map +1 -0
  150. package/dist/collection/components/ic-footer-link/ic-footer-link.spec.js +62 -0
  151. package/dist/collection/components/ic-footer-link/ic-footer-link.spec.js.map +1 -0
  152. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.spec.js +98 -0
  153. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.spec.js.map +1 -0
  154. package/dist/collection/components/ic-hero/ic-hero.spec.js +76 -0
  155. package/dist/collection/components/ic-hero/ic-hero.spec.js.map +1 -0
  156. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.spec.js +180 -0
  157. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.spec.js.map +1 -0
  158. package/dist/collection/components/ic-input-component-container/ic-input-component-container.css +32 -4
  159. package/dist/collection/components/ic-input-component-container/ic-input-component-container.spec.js +117 -0
  160. package/dist/collection/components/ic-input-component-container/ic-input-component-container.spec.js.map +1 -0
  161. package/dist/collection/components/ic-input-container/ic-input-container.spec.js +38 -0
  162. package/dist/collection/components/ic-input-container/ic-input-container.spec.js.map +1 -0
  163. package/dist/collection/components/ic-input-label/ic-input-label.spec.js +98 -0
  164. package/dist/collection/components/ic-input-label/ic-input-label.spec.js.map +1 -0
  165. package/dist/collection/components/ic-input-validation/ic-input-validation.css +0 -8
  166. package/dist/collection/components/ic-input-validation/ic-input-validation.spec.js +89 -0
  167. package/dist/collection/components/ic-input-validation/ic-input-validation.spec.js.map +1 -0
  168. package/dist/collection/components/ic-link/ic-link.spec.js +203 -0
  169. package/dist/collection/components/ic-link/ic-link.spec.js.map +1 -0
  170. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.e2e.js +34 -0
  171. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.e2e.js.map +1 -0
  172. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.spec.js +141 -0
  173. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.spec.js.map +1 -0
  174. package/dist/collection/components/ic-menu/ic-menu.css +9 -1
  175. package/dist/collection/components/ic-menu/ic-menu.js +85 -22
  176. package/dist/collection/components/ic-menu/ic-menu.js.map +1 -1
  177. package/dist/collection/components/ic-menu/ic-menu.spec.js +650 -0
  178. package/dist/collection/components/ic-menu/ic-menu.spec.js.map +1 -0
  179. package/dist/collection/components/ic-menu-group/ic-menu-group.spec.js +94 -0
  180. package/dist/collection/components/ic-menu-group/ic-menu-group.spec.js.map +1 -0
  181. package/dist/collection/components/ic-menu-item/ic-menu-item.css +2 -2
  182. package/dist/collection/components/ic-menu-item/ic-menu-item.js +2 -1
  183. package/dist/collection/components/ic-menu-item/ic-menu-item.js.map +1 -1
  184. package/dist/collection/components/ic-menu-item/ic-menu-item.spec.js +105 -0
  185. package/dist/collection/components/ic-menu-item/ic-menu-item.spec.js.map +1 -0
  186. package/dist/collection/components/ic-navigation-button/ic-navigation-button.spec.js +84 -0
  187. package/dist/collection/components/ic-navigation-button/ic-navigation-button.spec.js.map +1 -0
  188. package/dist/collection/components/ic-navigation-group/ic-navigation-group.css +1 -1
  189. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js +41 -15
  190. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js.map +1 -1
  191. package/dist/collection/components/ic-navigation-group/ic-navigation-group.spec.js +309 -0
  192. package/dist/collection/components/ic-navigation-group/ic-navigation-group.spec.js.map +1 -0
  193. package/dist/collection/components/ic-navigation-item/ic-navigation-item.spec.js +118 -0
  194. package/dist/collection/components/ic-navigation-item/ic-navigation-item.spec.js.map +1 -0
  195. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.e2e.js +29 -0
  196. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.e2e.js.map +1 -0
  197. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.spec.js +176 -0
  198. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.spec.js.map +1 -0
  199. package/dist/collection/components/ic-page-header/ic-page-header.css +1 -1
  200. package/dist/collection/components/ic-page-header/ic-page-header.e2e.js +177 -0
  201. package/dist/collection/components/ic-page-header/ic-page-header.e2e.js.map +1 -0
  202. package/dist/collection/components/ic-page-header/ic-page-header.spec.js +284 -0
  203. package/dist/collection/components/ic-page-header/ic-page-header.spec.js.map +1 -0
  204. package/dist/collection/components/ic-pagination/ic-pagination.e2e.js +128 -0
  205. package/dist/collection/components/ic-pagination/ic-pagination.e2e.js.map +1 -0
  206. package/dist/collection/components/ic-pagination/ic-pagination.js +3 -2
  207. package/dist/collection/components/ic-pagination/ic-pagination.js.map +1 -1
  208. package/dist/collection/components/ic-pagination/ic-pagination.spec.js +325 -0
  209. package/dist/collection/components/ic-pagination/ic-pagination.spec.js.map +1 -0
  210. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js +5 -1
  211. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js.map +1 -1
  212. package/dist/collection/components/ic-popover-menu/ic-popover-menu.css +1 -1
  213. package/dist/collection/components/ic-popover-menu/ic-popover-menu.e2e.js +30 -0
  214. package/dist/collection/components/ic-popover-menu/ic-popover-menu.e2e.js.map +1 -0
  215. package/dist/collection/components/ic-popover-menu/ic-popover-menu.spec.js +381 -0
  216. package/dist/collection/components/ic-popover-menu/ic-popover-menu.spec.js.map +1 -0
  217. package/dist/collection/components/ic-radio-group/ic-radio-group.e2e.js +343 -0
  218. package/dist/collection/components/ic-radio-group/ic-radio-group.e2e.js.map +1 -0
  219. package/dist/collection/components/ic-radio-group/ic-radio-group.js +19 -8
  220. package/dist/collection/components/ic-radio-group/ic-radio-group.js.map +1 -1
  221. package/dist/collection/components/ic-radio-group/ic-radio-group.spec.js +303 -0
  222. package/dist/collection/components/ic-radio-group/ic-radio-group.spec.js.map +1 -0
  223. package/dist/collection/components/ic-radio-group/ic-radio-group.types.js +2 -0
  224. package/dist/collection/components/ic-radio-group/ic-radio-group.types.js.map +1 -0
  225. package/dist/collection/components/ic-radio-option/ic-radio-option.css +1 -1
  226. package/dist/collection/components/ic-radio-option/ic-radio-option.js +5 -14
  227. package/dist/collection/components/ic-radio-option/ic-radio-option.js.map +1 -1
  228. package/dist/collection/components/ic-search-bar/ic-search-bar.e2e.js +1054 -0
  229. package/dist/collection/components/ic-search-bar/ic-search-bar.e2e.js.map +1 -0
  230. package/dist/collection/components/ic-search-bar/ic-search-bar.js +12 -9
  231. package/dist/collection/components/ic-search-bar/ic-search-bar.js.map +1 -1
  232. package/dist/collection/components/ic-search-bar/ic-search-bar.spec.js +570 -0
  233. package/dist/collection/components/ic-search-bar/ic-search-bar.spec.js.map +1 -0
  234. package/dist/collection/components/ic-search-bar/ic-search-bar.types.js.map +1 -1
  235. package/dist/collection/components/ic-section-container/ic-section-container.spec.js +69 -0
  236. package/dist/collection/components/ic-section-container/ic-section-container.spec.js.map +1 -0
  237. package/dist/collection/components/ic-select/ic-select.e2e.js +1765 -0
  238. package/dist/collection/components/ic-select/ic-select.e2e.js.map +1 -0
  239. package/dist/collection/components/ic-select/ic-select.js +35 -33
  240. package/dist/collection/components/ic-select/ic-select.js.map +1 -1
  241. package/dist/collection/components/ic-select/ic-select.spec.js +1276 -0
  242. package/dist/collection/components/ic-select/ic-select.spec.js.map +1 -0
  243. package/dist/collection/components/ic-side-navigation/ic-side-navigation.css +0 -7
  244. package/dist/collection/components/ic-side-navigation/ic-side-navigation.e2e.js +412 -0
  245. package/dist/collection/components/ic-side-navigation/ic-side-navigation.e2e.js.map +1 -0
  246. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js +48 -39
  247. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js.map +1 -1
  248. package/dist/collection/components/ic-side-navigation/ic-side-navigation.spec.js +470 -0
  249. package/dist/collection/components/ic-side-navigation/ic-side-navigation.spec.js.map +1 -0
  250. package/dist/collection/components/ic-skeleton/ic-skeleton.spec.js +89 -0
  251. package/dist/collection/components/ic-skeleton/ic-skeleton.spec.js.map +1 -0
  252. package/dist/collection/components/ic-status-tag/ic-status-tag.css +2 -6
  253. package/dist/collection/components/ic-status-tag/ic-status-tag.spec.js +43 -0
  254. package/dist/collection/components/ic-status-tag/ic-status-tag.spec.js.map +1 -0
  255. package/dist/collection/components/ic-step/ic-step.spec.js +176 -0
  256. package/dist/collection/components/ic-step/ic-step.spec.js.map +1 -0
  257. package/dist/collection/components/ic-stepper/ic-stepper.e2e.js +49 -0
  258. package/dist/collection/components/ic-stepper/ic-stepper.e2e.js.map +1 -0
  259. package/dist/collection/components/ic-stepper/ic-stepper.spec.js +706 -0
  260. package/dist/collection/components/ic-stepper/ic-stepper.spec.js.map +1 -0
  261. package/dist/collection/components/ic-switch/ic-switch.css +1 -1
  262. package/dist/collection/components/ic-switch/ic-switch.js +2 -1
  263. package/dist/collection/components/ic-switch/ic-switch.js.map +1 -1
  264. package/dist/collection/components/ic-switch/ic-switch.spec.js +104 -0
  265. package/dist/collection/components/ic-switch/ic-switch.spec.js.map +1 -0
  266. package/dist/collection/components/ic-tab/ic-tab.e2e.js +32 -0
  267. package/dist/collection/components/ic-tab/ic-tab.e2e.js.map +1 -0
  268. package/dist/collection/components/ic-tab/ic-tab.js +4 -0
  269. package/dist/collection/components/ic-tab/ic-tab.js.map +1 -1
  270. package/dist/collection/components/ic-tab/ic-tab.spec.js +159 -0
  271. package/dist/collection/components/ic-tab/ic-tab.spec.js.map +1 -0
  272. package/dist/collection/components/ic-tab-context/ic-tab-context.e2e.js +317 -0
  273. package/dist/collection/components/ic-tab-context/ic-tab-context.e2e.js.map +1 -0
  274. package/dist/collection/components/ic-tab-context/ic-tab-context.spec.js +369 -0
  275. package/dist/collection/components/ic-tab-context/ic-tab-context.spec.js.map +1 -0
  276. package/dist/collection/components/ic-tab-group/ic-tab-group.css +2 -2
  277. package/dist/collection/components/ic-tab-panel/ic-tab-panel.spec.js +65 -0
  278. package/dist/collection/components/ic-tab-panel/ic-tab-panel.spec.js.map +1 -0
  279. package/dist/collection/components/ic-text-field/ic-text-field.css +0 -4
  280. package/dist/collection/components/ic-text-field/ic-text-field.e2e.js +98 -0
  281. package/dist/collection/components/ic-text-field/ic-text-field.e2e.js.map +1 -0
  282. package/dist/collection/components/ic-text-field/ic-text-field.input.spec.js +236 -0
  283. package/dist/collection/components/ic-text-field/ic-text-field.input.spec.js.map +1 -0
  284. package/dist/collection/components/ic-text-field/ic-text-field.js +11 -12
  285. package/dist/collection/components/ic-text-field/ic-text-field.js.map +1 -1
  286. package/dist/collection/components/ic-text-field/ic-text-field.textarea.spec.js +310 -0
  287. package/dist/collection/components/ic-text-field/ic-text-field.textarea.spec.js.map +1 -0
  288. package/dist/collection/components/ic-theme/ic-theme.e2e.js +72 -0
  289. package/dist/collection/components/ic-theme/ic-theme.e2e.js.map +1 -0
  290. package/dist/collection/components/ic-theme/ic-theme.spec.js +77 -0
  291. package/dist/collection/components/ic-theme/ic-theme.spec.js.map +1 -0
  292. package/dist/collection/components/ic-toast/ic-toast.e2e.js +82 -0
  293. package/dist/collection/components/ic-toast/ic-toast.e2e.js.map +1 -0
  294. package/dist/collection/components/ic-toast/ic-toast.spec.js +278 -0
  295. package/dist/collection/components/ic-toast/ic-toast.spec.js.map +1 -0
  296. package/dist/collection/components/ic-toast-region/ic-toast-region.spec.js +62 -0
  297. package/dist/collection/components/ic-toast-region/ic-toast-region.spec.js.map +1 -0
  298. package/dist/collection/components/ic-tooltip/ic-tooltip.css +22 -8
  299. package/dist/collection/components/ic-tooltip/ic-tooltip.e2e.js +115 -0
  300. package/dist/collection/components/ic-tooltip/ic-tooltip.e2e.js.map +1 -0
  301. package/dist/collection/components/ic-tooltip/ic-tooltip.js +26 -27
  302. package/dist/collection/components/ic-tooltip/ic-tooltip.js.map +1 -1
  303. package/dist/collection/components/ic-tooltip/ic-tooltip.spec.js +128 -0
  304. package/dist/collection/components/ic-tooltip/ic-tooltip.spec.js.map +1 -0
  305. package/dist/collection/components/ic-top-navigation/ic-top-navigation.e2e.js +42 -0
  306. package/dist/collection/components/ic-top-navigation/ic-top-navigation.e2e.js.map +1 -0
  307. package/dist/collection/components/ic-top-navigation/ic-top-navigation.mobile.e2e.js +242 -0
  308. package/dist/collection/components/ic-top-navigation/ic-top-navigation.mobile.e2e.js.map +1 -0
  309. package/dist/collection/components/ic-top-navigation/ic-top-navigation.spec.js +286 -0
  310. package/dist/collection/components/ic-top-navigation/ic-top-navigation.spec.js.map +1 -0
  311. package/dist/collection/components/ic-typography/ic-typography.e2e.js +36 -0
  312. package/dist/collection/components/ic-typography/ic-typography.e2e.js.map +1 -0
  313. package/dist/collection/components/ic-typography/ic-typography.spec.js +296 -0
  314. package/dist/collection/components/ic-typography/ic-typography.spec.js.map +1 -0
  315. package/dist/collection/testspec.setup.js +11 -0
  316. package/dist/collection/testspec.setup.js.map +1 -1
  317. package/dist/collection/utils/helpers.js +5 -0
  318. package/dist/collection/utils/helpers.js.map +1 -1
  319. package/dist/components/helpers.js +6 -1
  320. package/dist/components/helpers.js.map +1 -1
  321. package/dist/components/ic-alert.js +1 -113
  322. package/dist/components/ic-alert.js.map +1 -1
  323. package/dist/components/ic-alert2.js +117 -0
  324. package/dist/components/ic-alert2.js.map +1 -0
  325. package/dist/components/ic-back-to-top.js +2 -2
  326. package/dist/components/ic-breadcrumb-group.js +2 -2
  327. package/dist/components/ic-breadcrumb2.js +1 -1
  328. package/dist/components/ic-button2.js +4 -3
  329. package/dist/components/ic-button2.js.map +1 -1
  330. package/dist/components/ic-card.js +4 -3
  331. package/dist/components/ic-card.js.map +1 -1
  332. package/dist/components/ic-checkbox-group.js +5 -2
  333. package/dist/components/ic-checkbox-group.js.map +1 -1
  334. package/dist/components/ic-checkbox.js +3 -2
  335. package/dist/components/ic-checkbox.js.map +1 -1
  336. package/dist/components/ic-chip.js +5 -2
  337. package/dist/components/ic-chip.js.map +1 -1
  338. package/dist/components/ic-classification-banner.js +1 -1
  339. package/dist/components/ic-data-entity.js +1 -1
  340. package/dist/components/ic-data-row.js +2 -2
  341. package/dist/components/ic-dialog.d.ts +11 -0
  342. package/dist/components/ic-dialog.js +357 -0
  343. package/dist/components/ic-dialog.js.map +1 -0
  344. package/dist/components/ic-divider2.js +2 -2
  345. package/dist/components/ic-footer-link-group.js +2 -2
  346. package/dist/components/ic-footer-link.js +2 -2
  347. package/dist/components/ic-footer.js +3 -3
  348. package/dist/components/ic-footer.js.map +1 -1
  349. package/dist/components/ic-hero.js +2 -2
  350. package/dist/components/ic-horizontal-scroll2.js +2 -2
  351. package/dist/components/ic-input-component-container2.js +3 -3
  352. package/dist/components/ic-input-component-container2.js.map +1 -1
  353. package/dist/components/ic-input-container2.js +1 -1
  354. package/dist/components/ic-input-label2.js +2 -2
  355. package/dist/components/ic-input-validation2.js +3 -3
  356. package/dist/components/ic-input-validation2.js.map +1 -1
  357. package/dist/components/ic-link2.js +2 -2
  358. package/dist/components/ic-loading-indicator2.js +1 -1
  359. package/dist/components/ic-menu-group.js +1 -1
  360. package/dist/components/ic-menu-item2.js +4 -3
  361. package/dist/components/ic-menu-item2.js.map +1 -1
  362. package/dist/components/ic-menu2.js +65 -26
  363. package/dist/components/ic-menu2.js.map +1 -1
  364. package/dist/components/ic-navigation-button.js +2 -2
  365. package/dist/components/ic-navigation-group.js +44 -18
  366. package/dist/components/ic-navigation-group.js.map +1 -1
  367. package/dist/components/ic-navigation-item.js +2 -2
  368. package/dist/components/ic-navigation-menu2.js +2 -2
  369. package/dist/components/ic-page-header.js +3 -3
  370. package/dist/components/ic-page-header.js.map +1 -1
  371. package/dist/components/ic-pagination-item2.js +5 -1
  372. package/dist/components/ic-pagination-item2.js.map +1 -1
  373. package/dist/components/ic-pagination.js +3 -2
  374. package/dist/components/ic-pagination.js.map +1 -1
  375. package/dist/components/ic-popover-menu.js +3 -3
  376. package/dist/components/ic-popover-menu.js.map +1 -1
  377. package/dist/components/ic-radio-group.js +16 -5
  378. package/dist/components/ic-radio-group.js.map +1 -1
  379. package/dist/components/ic-radio-option.js +5 -11
  380. package/dist/components/ic-radio-option.js.map +1 -1
  381. package/dist/components/ic-search-bar.js +6 -3
  382. package/dist/components/ic-search-bar.js.map +1 -1
  383. package/dist/components/ic-section-container2.js +1 -1
  384. package/dist/components/ic-select.js +34 -32
  385. package/dist/components/ic-select.js.map +1 -1
  386. package/dist/components/ic-side-navigation.js +51 -42
  387. package/dist/components/ic-side-navigation.js.map +1 -1
  388. package/dist/components/ic-skeleton.js +1 -1
  389. package/dist/components/ic-status-tag.js +3 -3
  390. package/dist/components/ic-status-tag.js.map +1 -1
  391. package/dist/components/ic-step.js +1 -1
  392. package/dist/components/ic-stepper.js +2 -2
  393. package/dist/components/ic-switch.js +4 -3
  394. package/dist/components/ic-switch.js.map +1 -1
  395. package/dist/components/ic-tab-context.js +1 -1
  396. package/dist/components/ic-tab-group.js +3 -3
  397. package/dist/components/ic-tab-group.js.map +1 -1
  398. package/dist/components/ic-tab-panel.js +1 -1
  399. package/dist/components/ic-tab.js +5 -1
  400. package/dist/components/ic-tab.js.map +1 -1
  401. package/dist/components/ic-text-field2.js +4 -5
  402. package/dist/components/ic-text-field2.js.map +1 -1
  403. package/dist/components/ic-theme.js +2 -2
  404. package/dist/components/ic-toast-region.js +1 -1
  405. package/dist/components/ic-toast.js +2 -2
  406. package/dist/components/ic-tooltip2.js +29 -30
  407. package/dist/components/ic-tooltip2.js.map +1 -1
  408. package/dist/components/ic-top-navigation.js +2 -2
  409. package/dist/components/ic-typography2.js +1 -1
  410. package/dist/components/index.d.ts +9 -60
  411. package/dist/components/index.js +1 -58
  412. package/dist/components/index.js.map +1 -1
  413. package/dist/core/core.css +41 -2
  414. package/dist/core/core.esm.js +1 -1
  415. package/dist/core/core.esm.js.map +1 -1
  416. package/dist/core/index.esm.js.map +1 -1
  417. package/dist/core/{p-de45134c.entry.js → p-04d626ee.entry.js} +2 -2
  418. package/dist/core/p-04d626ee.entry.js.map +1 -0
  419. package/dist/core/p-06321d19.js.map +1 -1
  420. package/dist/core/{p-050dbce8.entry.js → p-0d325b4c.entry.js} +2 -2
  421. package/dist/core/p-0d325b4c.entry.js.map +1 -0
  422. package/dist/core/{p-46371c05.entry.js → p-249af8ab.entry.js} +2 -2
  423. package/dist/core/p-249af8ab.entry.js.map +1 -0
  424. package/dist/core/{p-36e0671f.entry.js → p-29d9fea1.entry.js} +2 -2
  425. package/dist/core/p-29d9fea1.entry.js.map +1 -0
  426. package/dist/core/p-2e051e1e.entry.js +2 -0
  427. package/dist/core/p-2e051e1e.entry.js.map +1 -0
  428. package/dist/core/{p-bffa2e1a.entry.js → p-2ec49a7e.entry.js} +2 -2
  429. package/dist/core/p-2ec49a7e.entry.js.map +1 -0
  430. package/dist/core/{p-223a214f.entry.js → p-3114a4b3.entry.js} +2 -2
  431. package/dist/core/p-3114a4b3.entry.js.map +1 -0
  432. package/dist/core/{p-50421f27.entry.js → p-311c38b3.entry.js} +2 -2
  433. package/dist/core/p-311c38b3.entry.js.map +1 -0
  434. package/dist/core/p-31ccdd50.entry.js +2 -0
  435. package/dist/core/p-31ccdd50.entry.js.map +1 -0
  436. package/dist/core/p-31e80ccb.entry.js +2 -0
  437. package/dist/core/p-31e80ccb.entry.js.map +1 -0
  438. package/dist/core/p-323bce82.entry.js +2 -0
  439. package/dist/core/p-323bce82.entry.js.map +1 -0
  440. package/dist/core/{p-a9184841.entry.js → p-3918c27a.entry.js} +2 -2
  441. package/dist/core/p-3918c27a.entry.js.map +1 -0
  442. package/dist/core/p-3ce0aa02.entry.js +2 -0
  443. package/dist/core/p-3ce0aa02.entry.js.map +1 -0
  444. package/dist/core/p-44512ebe.js.map +1 -1
  445. package/dist/core/{p-471820e6.js → p-4a385752.js} +2 -2
  446. package/dist/core/p-4a385752.js.map +1 -0
  447. package/dist/core/{p-312c10b0.entry.js → p-4c4fa082.entry.js} +2 -2
  448. package/dist/core/p-4c4fa082.entry.js.map +1 -0
  449. package/dist/core/{p-fc7dce3d.entry.js → p-4f7b34ed.entry.js} +2 -2
  450. package/dist/core/p-4f7b34ed.entry.js.map +1 -0
  451. package/dist/core/{p-c85476c0.entry.js → p-524557bc.entry.js} +2 -2
  452. package/dist/core/p-524557bc.entry.js.map +1 -0
  453. package/dist/core/p-551986d1.entry.js +2 -0
  454. package/dist/core/p-551986d1.entry.js.map +1 -0
  455. package/dist/core/p-57460fa3.entry.js +2 -0
  456. package/dist/core/p-57460fa3.entry.js.map +1 -0
  457. package/dist/core/p-5fcd965f.entry.js +2 -0
  458. package/dist/core/p-5fcd965f.entry.js.map +1 -0
  459. package/dist/core/{p-68547339.entry.js → p-617950f8.entry.js} +2 -2
  460. package/dist/core/p-617950f8.entry.js.map +1 -0
  461. package/dist/core/{p-af815dfb.entry.js → p-68308ecd.entry.js} +2 -2
  462. package/dist/core/p-68308ecd.entry.js.map +1 -0
  463. package/dist/core/p-6c76c6ba.entry.js +2 -0
  464. package/dist/core/p-6c76c6ba.entry.js.map +1 -0
  465. package/dist/core/p-6f57b13c.js.map +1 -1
  466. package/dist/core/p-79914e0c.entry.js +2 -0
  467. package/dist/core/p-79914e0c.entry.js.map +1 -0
  468. package/dist/core/{p-e6217f40.entry.js → p-820e4c17.entry.js} +2 -2
  469. package/dist/core/p-820e4c17.entry.js.map +1 -0
  470. package/dist/core/{p-1585e5c1.entry.js → p-84c8c4c7.entry.js} +2 -2
  471. package/dist/core/p-84c8c4c7.entry.js.map +1 -0
  472. package/dist/core/{p-29ea6f88.entry.js → p-8911656b.entry.js} +2 -2
  473. package/dist/core/p-8911656b.entry.js.map +1 -0
  474. package/dist/core/p-8c7f4343.js.map +1 -1
  475. package/dist/core/p-8d4f7027.js.map +1 -1
  476. package/dist/core/p-97286148.entry.js +2 -0
  477. package/dist/core/p-97286148.entry.js.map +1 -0
  478. package/dist/core/{p-454b1ecd.entry.js → p-97fd0cc1.entry.js} +2 -2
  479. package/dist/core/p-97fd0cc1.entry.js.map +1 -0
  480. package/dist/core/p-a74b8476.entry.js +2 -0
  481. package/dist/core/p-a74b8476.entry.js.map +1 -0
  482. package/dist/core/{p-4dd0eb6a.entry.js → p-a9de9aba.entry.js} +2 -2
  483. package/dist/core/p-a9de9aba.entry.js.map +1 -0
  484. package/dist/core/p-ad6c4c02.entry.js +2 -0
  485. package/dist/core/p-ad6c4c02.entry.js.map +1 -0
  486. package/dist/core/{p-ca20c9c3.entry.js → p-aeef3c9d.entry.js} +2 -2
  487. package/dist/core/p-aeef3c9d.entry.js.map +1 -0
  488. package/dist/core/p-b03bd9c6.entry.js +2 -0
  489. package/dist/core/p-b03bd9c6.entry.js.map +1 -0
  490. package/dist/core/p-b0685167.entry.js +2 -0
  491. package/dist/core/p-b0685167.entry.js.map +1 -0
  492. package/dist/core/p-b35a9909.entry.js +2 -0
  493. package/dist/core/p-b35a9909.entry.js.map +1 -0
  494. package/dist/core/p-bad10f6c.entry.js +2 -0
  495. package/dist/core/p-bad10f6c.entry.js.map +1 -0
  496. package/dist/core/{p-a18c0672.entry.js → p-bda4414e.entry.js} +2 -2
  497. package/dist/core/p-bda4414e.entry.js.map +1 -0
  498. package/dist/core/p-c0333310.entry.js +2 -0
  499. package/dist/core/p-c0333310.entry.js.map +1 -0
  500. package/dist/core/{p-2e63f202.entry.js → p-c3f9fb1d.entry.js} +2 -2
  501. package/dist/core/p-c3f9fb1d.entry.js.map +1 -0
  502. package/dist/core/{p-fb5861c6.entry.js → p-ca6820dc.entry.js} +2 -2
  503. package/dist/core/p-ca6820dc.entry.js.map +1 -0
  504. package/dist/core/p-d6694b41.entry.js +2 -0
  505. package/dist/core/p-d6694b41.entry.js.map +1 -0
  506. package/dist/core/{p-70124e59.entry.js → p-da4c1409.entry.js} +2 -2
  507. package/dist/core/p-da4c1409.entry.js.map +1 -0
  508. package/dist/core/p-dbe06c3b.entry.js +2 -0
  509. package/dist/core/p-dbe06c3b.entry.js.map +1 -0
  510. package/dist/core/{p-28bc3bf0.entry.js → p-df67b151.entry.js} +2 -2
  511. package/dist/core/p-df67b151.entry.js.map +1 -0
  512. package/dist/core/{p-df1b0f17.entry.js → p-dfd31e28.entry.js} +2 -2
  513. package/dist/core/p-dfd31e28.entry.js.map +1 -0
  514. package/dist/core/{p-5e896163.entry.js → p-e3e6308b.entry.js} +2 -2
  515. package/dist/core/p-e3e6308b.entry.js.map +1 -0
  516. package/dist/core/{p-b7cf6411.entry.js → p-ea233813.entry.js} +2 -2
  517. package/dist/core/p-ea233813.entry.js.map +1 -0
  518. package/dist/core/p-ec26fc38.js.map +1 -1
  519. package/dist/core/{p-d2d5132d.entry.js → p-ecdcae46.entry.js} +2 -2
  520. package/dist/core/p-ecdcae46.entry.js.map +1 -0
  521. package/dist/core/{p-443052a7.entry.js → p-ef91c17e.entry.js} +2 -2
  522. package/dist/core/p-ef91c17e.entry.js.map +1 -0
  523. package/dist/core/{p-cee45622.entry.js → p-f0714432.entry.js} +2 -2
  524. package/dist/core/p-f0714432.entry.js.map +1 -0
  525. package/dist/core/p-f3053872.js +3 -0
  526. package/dist/core/p-f3053872.js.map +1 -0
  527. package/dist/core/{p-a8dc8196.entry.js → p-f381e93f.entry.js} +2 -2
  528. package/dist/core/p-f381e93f.entry.js.map +1 -0
  529. package/dist/core/p-fd482bd7.entry.js +2 -0
  530. package/dist/core/p-fd482bd7.entry.js.map +1 -0
  531. package/dist/core/p-fe2c4009.entry.js +2 -0
  532. package/dist/core/p-fe2c4009.entry.js.map +1 -0
  533. package/dist/esm/core.js +7 -3
  534. package/dist/esm/core.js.map +1 -1
  535. package/dist/esm/{helpers-73666f14.js → helpers-8e57082b.js} +7 -2
  536. package/dist/esm/helpers-8e57082b.js.map +1 -0
  537. package/dist/esm/ic-alert.entry.js +2 -2
  538. package/dist/esm/ic-back-to-top.entry.js +2 -2
  539. package/dist/esm/ic-breadcrumb-group.entry.js +2 -2
  540. package/dist/esm/ic-breadcrumb.entry.js +2 -2
  541. package/dist/esm/ic-button_3.entry.js +31 -31
  542. package/dist/esm/ic-button_3.entry.js.map +1 -1
  543. package/dist/esm/ic-card.entry.js +4 -3
  544. package/dist/esm/ic-card.entry.js.map +1 -1
  545. package/dist/esm/ic-checkbox-group.entry.js +5 -2
  546. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  547. package/dist/esm/ic-checkbox.entry.js +3 -2
  548. package/dist/esm/ic-checkbox.entry.js.map +1 -1
  549. package/dist/esm/ic-chip.entry.js +5 -2
  550. package/dist/esm/ic-chip.entry.js.map +1 -1
  551. package/dist/esm/ic-classification-banner.entry.js +1 -1
  552. package/dist/esm/ic-data-entity.entry.js +1 -1
  553. package/dist/esm/ic-data-row.entry.js +2 -2
  554. package/dist/esm/ic-dialog.entry.js +292 -0
  555. package/dist/esm/ic-dialog.entry.js.map +1 -0
  556. package/dist/esm/ic-divider.entry.js +2 -2
  557. package/dist/esm/ic-footer-link-group.entry.js +2 -2
  558. package/dist/esm/ic-footer-link.entry.js +2 -2
  559. package/dist/esm/ic-footer.entry.js +3 -3
  560. package/dist/esm/ic-footer.entry.js.map +1 -1
  561. package/dist/esm/ic-hero.entry.js +2 -2
  562. package/dist/esm/ic-horizontal-scroll.entry.js +2 -2
  563. package/dist/esm/ic-input-component-container_3.entry.js +65 -26
  564. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -1
  565. package/dist/esm/ic-input-label_2.entry.js +3 -3
  566. package/dist/esm/ic-input-label_2.entry.js.map +1 -1
  567. package/dist/esm/ic-link.entry.js +2 -2
  568. package/dist/esm/ic-menu-group.entry.js +1 -1
  569. package/dist/esm/ic-menu-item.entry.js +4 -3
  570. package/dist/esm/ic-menu-item.entry.js.map +1 -1
  571. package/dist/esm/ic-navigation-button.entry.js +2 -2
  572. package/dist/esm/ic-navigation-group.entry.js +44 -18
  573. package/dist/esm/ic-navigation-group.entry.js.map +1 -1
  574. package/dist/esm/ic-navigation-item.entry.js +2 -2
  575. package/dist/esm/ic-navigation-menu.entry.js +2 -2
  576. package/dist/esm/ic-page-header.entry.js +3 -3
  577. package/dist/esm/ic-page-header.entry.js.map +1 -1
  578. package/dist/esm/ic-pagination-item.entry.js +6 -1
  579. package/dist/esm/ic-pagination-item.entry.js.map +1 -1
  580. package/dist/esm/ic-pagination.entry.js +3 -2
  581. package/dist/esm/ic-pagination.entry.js.map +1 -1
  582. package/dist/esm/ic-popover-menu.entry.js +3 -3
  583. package/dist/esm/ic-popover-menu.entry.js.map +1 -1
  584. package/dist/esm/ic-radio-group.entry.js +16 -5
  585. package/dist/esm/ic-radio-group.entry.js.map +1 -1
  586. package/dist/esm/ic-radio-option.entry.js +5 -11
  587. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  588. package/dist/esm/ic-search-bar.entry.js +6 -3
  589. package/dist/esm/ic-search-bar.entry.js.map +1 -1
  590. package/dist/esm/ic-section-container.entry.js +1 -1
  591. package/dist/esm/ic-select.entry.js +34 -32
  592. package/dist/esm/ic-select.entry.js.map +1 -1
  593. package/dist/esm/ic-side-navigation.entry.js +51 -42
  594. package/dist/esm/ic-side-navigation.entry.js.map +1 -1
  595. package/dist/esm/ic-skeleton.entry.js +1 -1
  596. package/dist/esm/ic-status-tag.entry.js +3 -3
  597. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  598. package/dist/esm/ic-step.entry.js +1 -1
  599. package/dist/esm/ic-stepper.entry.js +2 -2
  600. package/dist/esm/ic-switch.entry.js +4 -3
  601. package/dist/esm/ic-switch.entry.js.map +1 -1
  602. package/dist/esm/ic-tab-context.entry.js +1 -1
  603. package/dist/esm/ic-tab-group.entry.js +3 -3
  604. package/dist/esm/ic-tab-group.entry.js.map +1 -1
  605. package/dist/esm/ic-tab-panel.entry.js +1 -1
  606. package/dist/esm/ic-tab.entry.js +5 -1
  607. package/dist/esm/ic-tab.entry.js.map +1 -1
  608. package/dist/esm/ic-text-field.entry.js +4 -5
  609. package/dist/esm/ic-text-field.entry.js.map +1 -1
  610. package/dist/esm/ic-theme.entry.js +2 -2
  611. package/dist/esm/ic-toast-region.entry.js +1 -1
  612. package/dist/esm/ic-toast.entry.js +2 -2
  613. package/dist/esm/ic-top-navigation.entry.js +2 -2
  614. package/dist/esm/ic-typography.entry.js +2 -2
  615. package/dist/esm/{index-3b144b17.js → index-a77644e1.js} +222 -44
  616. package/dist/esm/index-a77644e1.js.map +1 -0
  617. package/dist/esm/loader.js +4 -3
  618. package/dist/esm/loader.js.map +1 -1
  619. package/dist/esm/polyfills/css-shim.js +1 -1
  620. package/dist/types/components/ic-breadcrumb/ic-breadcrumb.types.d.ts +1 -1
  621. package/dist/types/components/ic-button/ic-button.types.d.ts +4 -4
  622. package/dist/types/components/ic-checkbox-group/ic-checkbox-group.d.ts +1 -0
  623. package/dist/types/components/ic-chip/ic-chip.d.ts +1 -0
  624. package/dist/types/components/ic-chip/ic-chip.types.d.ts +2 -2
  625. package/dist/types/components/ic-classification-banner/ic-classification-banner.types.d.ts +1 -1
  626. package/dist/types/components/ic-dialog/ic-dialog.d.ts +123 -0
  627. package/dist/types/components/ic-dialog/ic-dialog.test.a11y.d.ts +1 -0
  628. package/dist/types/components/ic-footer/ic-footer.types.d.ts +1 -1
  629. package/dist/types/components/ic-footer-link/ic-footer-link.d.ts +1 -1
  630. package/dist/types/components/ic-hero/ic-hero.types.d.ts +1 -1
  631. package/dist/types/components/ic-input-validation/ic-input-validation.types.d.ts +1 -1
  632. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.types.d.ts +2 -2
  633. package/dist/types/components/ic-menu/ic-menu.d.ts +6 -0
  634. package/dist/types/components/ic-menu-item/ic-menu-item.types.d.ts +1 -1
  635. package/dist/types/components/ic-navigation-button/ic-navigation-button.types.d.ts +1 -1
  636. package/dist/types/components/ic-navigation-group/ic-navigation-group.d.ts +3 -1
  637. package/dist/types/components/ic-pagination/ic-pagination.d.ts +1 -1
  638. package/dist/types/components/ic-pagination/ic-pagination.types.d.ts +1 -1
  639. package/dist/types/components/ic-pagination-item/ic-pagination-item.d.ts +2 -1
  640. package/dist/types/components/ic-pagination-item/ic-pagination-item.types.d.ts +1 -1
  641. package/dist/types/components/ic-radio-group/ic-radio-group.d.ts +4 -3
  642. package/dist/types/components/ic-radio-group/ic-radio-group.types.d.ts +7 -0
  643. package/dist/types/components/ic-radio-option/ic-radio-option.d.ts +1 -3
  644. package/dist/types/components/ic-search-bar/ic-search-bar.d.ts +1 -1
  645. package/dist/types/components/ic-search-bar/ic-search-bar.types.d.ts +1 -1
  646. package/dist/types/components/ic-select/ic-select.d.ts +3 -3
  647. package/dist/types/components/ic-skeleton/ic-skeleton.types.d.ts +1 -1
  648. package/dist/types/components/ic-status-tag/ic-status-tag.types.d.ts +2 -2
  649. package/dist/types/components/ic-step/ic-step.types.d.ts +3 -3
  650. package/dist/types/components/ic-stepper/ic-stepper.types.d.ts +1 -1
  651. package/dist/types/components/ic-tab/ic-tab.d.ts +1 -0
  652. package/dist/types/components/ic-text-field/ic-text-field.d.ts +1 -1
  653. package/dist/types/components/ic-text-field/ic-text-field.types.d.ts +3 -3
  654. package/dist/types/components/ic-toast/ic-toast.types.d.ts +1 -1
  655. package/dist/types/components/ic-tooltip/ic-tooltip.types.d.ts +1 -1
  656. package/dist/types/components.d.ts +187 -27
  657. package/dist/types/stencil-public-runtime.d.ts +72 -15
  658. package/dist/types/testspec.setup.d.ts +9 -0
  659. package/dist/types/utils/helpers.d.ts +1 -0
  660. package/dist/types/utils/types.d.ts +22 -22
  661. package/hydrate/index.d.ts +17 -16
  662. package/hydrate/index.js +699 -262
  663. package/loader/index.d.ts +9 -0
  664. package/package.json +5 -5
  665. package/dist/cjs/helpers-d6b5880e.js.map +0 -1
  666. package/dist/cjs/index-a62312a7.js.map +0 -1
  667. package/dist/core/p-050dbce8.entry.js.map +0 -1
  668. package/dist/core/p-06962e10.entry.js +0 -2
  669. package/dist/core/p-06962e10.entry.js.map +0 -1
  670. package/dist/core/p-0969a95a.entry.js +0 -2
  671. package/dist/core/p-0969a95a.entry.js.map +0 -1
  672. package/dist/core/p-0a11ec35.entry.js +0 -2
  673. package/dist/core/p-0a11ec35.entry.js.map +0 -1
  674. package/dist/core/p-0f153569.entry.js +0 -2
  675. package/dist/core/p-0f153569.entry.js.map +0 -1
  676. package/dist/core/p-1585e5c1.entry.js.map +0 -1
  677. package/dist/core/p-223a214f.entry.js.map +0 -1
  678. package/dist/core/p-28bc3bf0.entry.js.map +0 -1
  679. package/dist/core/p-29ea6f88.entry.js.map +0 -1
  680. package/dist/core/p-2e63f202.entry.js.map +0 -1
  681. package/dist/core/p-2e6ea6d3.entry.js +0 -2
  682. package/dist/core/p-2e6ea6d3.entry.js.map +0 -1
  683. package/dist/core/p-2fb97a1b.entry.js +0 -2
  684. package/dist/core/p-2fb97a1b.entry.js.map +0 -1
  685. package/dist/core/p-312c10b0.entry.js.map +0 -1
  686. package/dist/core/p-31b4b684.entry.js +0 -2
  687. package/dist/core/p-31b4b684.entry.js.map +0 -1
  688. package/dist/core/p-32cc8827.entry.js +0 -2
  689. package/dist/core/p-32cc8827.entry.js.map +0 -1
  690. package/dist/core/p-3498db0b.entry.js +0 -2
  691. package/dist/core/p-3498db0b.entry.js.map +0 -1
  692. package/dist/core/p-36e0671f.entry.js.map +0 -1
  693. package/dist/core/p-443052a7.entry.js.map +0 -1
  694. package/dist/core/p-454b1ecd.entry.js.map +0 -1
  695. package/dist/core/p-46371c05.entry.js.map +0 -1
  696. package/dist/core/p-471820e6.js.map +0 -1
  697. package/dist/core/p-4dd0eb6a.entry.js.map +0 -1
  698. package/dist/core/p-50421f27.entry.js.map +0 -1
  699. package/dist/core/p-559b3d17.entry.js +0 -2
  700. package/dist/core/p-559b3d17.entry.js.map +0 -1
  701. package/dist/core/p-589f6dd3.js +0 -3
  702. package/dist/core/p-589f6dd3.js.map +0 -1
  703. package/dist/core/p-5a3f3f37.entry.js +0 -2
  704. package/dist/core/p-5a3f3f37.entry.js.map +0 -1
  705. package/dist/core/p-5e896163.entry.js.map +0 -1
  706. package/dist/core/p-68547339.entry.js.map +0 -1
  707. package/dist/core/p-6f2be5bd.entry.js +0 -2
  708. package/dist/core/p-6f2be5bd.entry.js.map +0 -1
  709. package/dist/core/p-70124e59.entry.js.map +0 -1
  710. package/dist/core/p-80164baa.entry.js +0 -2
  711. package/dist/core/p-80164baa.entry.js.map +0 -1
  712. package/dist/core/p-80eff050.entry.js +0 -2
  713. package/dist/core/p-80eff050.entry.js.map +0 -1
  714. package/dist/core/p-8edd3a9b.entry.js +0 -2
  715. package/dist/core/p-8edd3a9b.entry.js.map +0 -1
  716. package/dist/core/p-9715ec62.entry.js +0 -2
  717. package/dist/core/p-9715ec62.entry.js.map +0 -1
  718. package/dist/core/p-983cb33c.entry.js +0 -2
  719. package/dist/core/p-983cb33c.entry.js.map +0 -1
  720. package/dist/core/p-a18c0672.entry.js.map +0 -1
  721. package/dist/core/p-a8dc8196.entry.js.map +0 -1
  722. package/dist/core/p-a9184841.entry.js.map +0 -1
  723. package/dist/core/p-af815dfb.entry.js.map +0 -1
  724. package/dist/core/p-b69226d2.entry.js +0 -2
  725. package/dist/core/p-b69226d2.entry.js.map +0 -1
  726. package/dist/core/p-b7cf6411.entry.js.map +0 -1
  727. package/dist/core/p-bffa2e1a.entry.js.map +0 -1
  728. package/dist/core/p-c85476c0.entry.js.map +0 -1
  729. package/dist/core/p-ca20c9c3.entry.js.map +0 -1
  730. package/dist/core/p-cee45622.entry.js.map +0 -1
  731. package/dist/core/p-d2d5132d.entry.js.map +0 -1
  732. package/dist/core/p-de45134c.entry.js.map +0 -1
  733. package/dist/core/p-df1b0f17.entry.js.map +0 -1
  734. package/dist/core/p-e16e817e.entry.js +0 -2
  735. package/dist/core/p-e16e817e.entry.js.map +0 -1
  736. package/dist/core/p-e6217f40.entry.js.map +0 -1
  737. package/dist/core/p-faeedfd1.entry.js +0 -2
  738. package/dist/core/p-faeedfd1.entry.js.map +0 -1
  739. package/dist/core/p-fb5861c6.entry.js.map +0 -1
  740. package/dist/core/p-fc7dce3d.entry.js.map +0 -1
  741. package/dist/core/p-fd18d7a3.entry.js +0 -2
  742. package/dist/core/p-fd18d7a3.entry.js.map +0 -1
  743. package/dist/esm/helpers-73666f14.js.map +0 -1
  744. package/dist/esm/index-3b144b17.js.map +0 -1
@@ -0,0 +1,369 @@
1
+ import { newSpecPage } from "@stencil/core/testing";
2
+ import { TabGroup } from "../ic-tab-group/ic-tab-group";
3
+ import { TabPanel } from "../ic-tab-panel/ic-tab-panel";
4
+ import { Tab } from "../ic-tab/ic-tab";
5
+ import { TabContext } from "./ic-tab-context";
6
+ beforeAll(() => {
7
+ jest.spyOn(console, "warn").mockImplementation(jest.fn());
8
+ });
9
+ describe("ic-tab-context component", () => {
10
+ it("should render tab context with tabs", async () => {
11
+ const page = await newSpecPage({
12
+ components: [TabContext, TabGroup, Tab, TabPanel],
13
+ html: `<ic-tab-context>
14
+ <ic-tab-group label="Example tab group">
15
+ <ic-tab>One</ic-tab>
16
+ <ic-tab>Two</ic-tab>
17
+ <ic-tab>Three</ic-tab>
18
+ </ic-tab-group>
19
+ <ic-tab-panel>Tab One</ic-tab-panel>
20
+ <ic-tab-panel>Tab Two</ic-tab-panel>
21
+ <ic-tab-panel>Tab Three</ic-tab-panel>
22
+ </ic-tab-context>`,
23
+ });
24
+ expect(page.root).toMatchSnapshot();
25
+ //test disconnected callback for automatic activation
26
+ page.setContent("");
27
+ });
28
+ it("should render tab context with tabs - light appearance", async () => {
29
+ const page = await newSpecPage({
30
+ components: [TabContext, TabGroup, Tab, TabPanel],
31
+ html: `<ic-tab-context appearance="light">
32
+ <ic-tab-group label="Example tab group" appearance="light">
33
+ <ic-tab>One</ic-tab>
34
+ <ic-tab>Two</ic-tab>
35
+ <ic-tab>Three</ic-tab>
36
+ </ic-tab-group>
37
+ <ic-tab-panel>Tab One</ic-tab-panel>
38
+ <ic-tab-panel>Tab Two</ic-tab-panel>
39
+ <ic-tab-panel>Tab Three</ic-tab-panel>
40
+ </ic-tab-context>`,
41
+ });
42
+ expect(page.root).toMatchSnapshot();
43
+ });
44
+ it("should render tab context with tabs - selected tab", async () => {
45
+ const page = await newSpecPage({
46
+ components: [TabContext, TabGroup, Tab, TabPanel],
47
+ html: `<ic-tab-context selected-tab-index="2">
48
+ <ic-tab-group label="Example tab group">
49
+ <ic-tab>One</ic-tab>
50
+ <ic-tab>Two</ic-tab>
51
+ <ic-tab>Three</ic-tab>
52
+ </ic-tab-group>
53
+ <ic-tab-panel>Tab One</ic-tab-panel>
54
+ <ic-tab-panel>Tab Two</ic-tab-panel>
55
+ <ic-tab-panel>Tab Three</ic-tab-panel>
56
+ </ic-tab-context>`,
57
+ });
58
+ expect(page.root).toMatchSnapshot();
59
+ });
60
+ it("should test controlled mode - selected tab", async () => {
61
+ const page = await newSpecPage({
62
+ components: [TabContext, TabGroup, Tab, TabPanel],
63
+ html: `<ic-tab-context selected-tab-index="2">
64
+ <ic-tab-group label="Example tab group">
65
+ <ic-tab>One</ic-tab>
66
+ <ic-tab>Two</ic-tab>
67
+ <ic-tab>Three</ic-tab>
68
+ </ic-tab-group>
69
+ <ic-tab-panel>Tab One</ic-tab-panel>
70
+ <ic-tab-panel>Tab Two</ic-tab-panel>
71
+ <ic-tab-panel>Tab Three</ic-tab-panel>
72
+ </ic-tab-context>`,
73
+ });
74
+ expect(page.rootInstance.selectedTab).toBe(2);
75
+ const eventSpy = jest.fn();
76
+ page.root.addEventListener("icTabSelect", eventSpy);
77
+ const tabGroup = page.root.querySelector("ic-tab-group");
78
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
79
+ key: "Home",
80
+ bubbles: true,
81
+ cancelable: true,
82
+ }));
83
+ await page.waitForChanges();
84
+ expect(eventSpy).toHaveBeenCalled();
85
+ });
86
+ it("should render tab context with tabs - manual activation", async () => {
87
+ const page = await newSpecPage({
88
+ components: [TabContext, TabGroup, Tab, TabPanel],
89
+ html: `<ic-tab-context activation-type="manual">
90
+ <ic-tab-group label="Example tab group">
91
+ <ic-tab>One</ic-tab>
92
+ <ic-tab>Two</ic-tab>
93
+ <ic-tab>Three</ic-tab>
94
+ </ic-tab-group>
95
+ <ic-tab-panel>Tab One</ic-tab-panel>
96
+ <ic-tab-panel>Tab Two</ic-tab-panel>
97
+ <ic-tab-panel>Tab Three</ic-tab-panel>
98
+ </ic-tab-context>`,
99
+ });
100
+ expect(page.root).toMatchSnapshot();
101
+ //test disconnected callback for manual activation
102
+ page.setContent("");
103
+ });
104
+ it("should render tab context with custom contextId", async () => {
105
+ const page = await newSpecPage({
106
+ components: [TabContext, TabGroup, Tab, TabPanel],
107
+ html: `<ic-tab-context context-id="custom-context">
108
+ <ic-tab-group label="Example tab group">
109
+ <ic-tab>One</ic-tab>
110
+ <ic-tab>Two</ic-tab>
111
+ <ic-tab>Three</ic-tab>
112
+ </ic-tab-group>
113
+ <ic-tab-panel>Tab One</ic-tab-panel>
114
+ <ic-tab-panel>Tab Two</ic-tab-panel>
115
+ <ic-tab-panel>Tab Three</ic-tab-panel>
116
+ </ic-tab-context>`,
117
+ });
118
+ expect(page.root).toMatchSnapshot();
119
+ });
120
+ it("should test setting selected tab", async () => {
121
+ const page = await newSpecPage({
122
+ components: [TabContext, TabGroup, Tab, TabPanel],
123
+ html: `<ic-tab-context>
124
+ <ic-tab-group label="Example tab group">
125
+ <ic-tab>One</ic-tab>
126
+ <ic-tab>Two</ic-tab>
127
+ <ic-tab>Three</ic-tab>
128
+ </ic-tab-group>
129
+ <ic-tab-panel>Tab One</ic-tab-panel>
130
+ <ic-tab-panel>Tab Two</ic-tab-panel>
131
+ <ic-tab-panel>Tab Three</ic-tab-panel>
132
+ </ic-tab-context>`,
133
+ });
134
+ expect(page.rootInstance.selectedTab).toBe(0);
135
+ page.root.selectedTabIndex = 1;
136
+ await page.waitForChanges();
137
+ expect(page.rootInstance.selectedTab).toBe(1);
138
+ });
139
+ it("should test tab click handler", async () => {
140
+ const page = await newSpecPage({
141
+ components: [TabContext, TabGroup, Tab, TabPanel],
142
+ html: `<ic-tab-context>
143
+ <ic-tab-group label="Example tab group">
144
+ <ic-tab>One</ic-tab>
145
+ <ic-tab>Two</ic-tab>
146
+ <ic-tab>Three</ic-tab>
147
+ </ic-tab-group>
148
+ <ic-tab-panel>Tab One</ic-tab-panel>
149
+ <ic-tab-panel>Tab Two</ic-tab-panel>
150
+ <ic-tab-panel>Tab Three</ic-tab-panel>
151
+ </ic-tab-context>`,
152
+ });
153
+ expect(page.rootInstance.selectedTabIndex).toBe(undefined);
154
+ const eventSpy = jest.fn();
155
+ page.root.addEventListener("icTabSelect", eventSpy);
156
+ await page.rootInstance.tabClickHandler({
157
+ stopImmediatePropagation: jest.fn(),
158
+ detail: {
159
+ contextId: "default",
160
+ position: 1,
161
+ tabId: "ic-tab--1-context-default",
162
+ },
163
+ });
164
+ await page.waitForChanges();
165
+ expect(page.rootInstance.selectedTab).toBe(1);
166
+ expect(eventSpy).toHaveBeenCalled();
167
+ });
168
+ it("should test key down handler - automatic", async () => {
169
+ const page = await newSpecPage({
170
+ components: [TabContext, TabGroup, Tab, TabPanel],
171
+ html: `<ic-tab-context>
172
+ <ic-tab-group label="Example tab group">
173
+ <ic-tab>One</ic-tab>
174
+ <ic-tab>Two</ic-tab>
175
+ <ic-tab>Three</ic-tab>
176
+ </ic-tab-group>
177
+ <ic-tab-panel>Tab One</ic-tab-panel>
178
+ <ic-tab-panel>Tab Two</ic-tab-panel>
179
+ <ic-tab-panel>Tab Three</ic-tab-panel>
180
+ </ic-tab-context>`,
181
+ });
182
+ const tabGroup = page.root.querySelector("ic-tab-group");
183
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
184
+ key: "End",
185
+ bubbles: true,
186
+ cancelable: true,
187
+ }));
188
+ await page.waitForChanges();
189
+ expect(page.rootInstance.selectedTab).toBe(2);
190
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
191
+ key: "Home",
192
+ bubbles: true,
193
+ cancelable: true,
194
+ }));
195
+ await page.waitForChanges();
196
+ expect(page.rootInstance.selectedTab).toBe(0);
197
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
198
+ key: "ArrowLeft",
199
+ bubbles: true,
200
+ cancelable: true,
201
+ }));
202
+ await page.waitForChanges();
203
+ expect(page.rootInstance.selectedTab).toBe(2);
204
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
205
+ key: "ArrowLeft",
206
+ bubbles: true,
207
+ cancelable: true,
208
+ }));
209
+ await page.waitForChanges();
210
+ expect(page.rootInstance.selectedTab).toBe(1);
211
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
212
+ key: "ArrowRight",
213
+ bubbles: true,
214
+ cancelable: true,
215
+ }));
216
+ await page.waitForChanges();
217
+ expect(page.rootInstance.selectedTab).toBe(2);
218
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
219
+ key: "ArrowRight",
220
+ bubbles: true,
221
+ cancelable: true,
222
+ }));
223
+ await page.waitForChanges();
224
+ expect(page.rootInstance.selectedTab).toBe(0);
225
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
226
+ key: "Escape",
227
+ bubbles: true,
228
+ cancelable: true,
229
+ }));
230
+ await page.waitForChanges();
231
+ expect(page.rootInstance.selectedTab).toBe(0);
232
+ });
233
+ it("should test key down handler - manual", async () => {
234
+ const page = await newSpecPage({
235
+ components: [TabContext, TabGroup, Tab, TabPanel],
236
+ html: `<ic-tab-context activation-type="manual">
237
+ <ic-tab-group label="Example tab group">
238
+ <ic-tab>One</ic-tab>
239
+ <ic-tab>Two</ic-tab>
240
+ <ic-tab>Three</ic-tab>
241
+ </ic-tab-group>
242
+ <ic-tab-panel>Tab One</ic-tab-panel>
243
+ <ic-tab-panel>Tab Two</ic-tab-panel>
244
+ <ic-tab-panel>Tab Three</ic-tab-panel>
245
+ </ic-tab-context>`,
246
+ });
247
+ const tabGroup = page.root.querySelector("ic-tab-group");
248
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
249
+ key: "End",
250
+ bubbles: true,
251
+ cancelable: true,
252
+ }));
253
+ await page.waitForChanges();
254
+ expect(page.rootInstance.selectedTab).toBe(0);
255
+ expect(page.rootInstance.focusedTabIndex).toBe(2);
256
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
257
+ key: "Enter",
258
+ bubbles: true,
259
+ cancelable: true,
260
+ }));
261
+ await page.waitForChanges();
262
+ expect(page.rootInstance.selectedTab).toBe(2);
263
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
264
+ key: "Home",
265
+ bubbles: true,
266
+ cancelable: true,
267
+ }));
268
+ await page.waitForChanges();
269
+ expect(page.rootInstance.focusedTabIndex).toBe(0);
270
+ expect(page.rootInstance.selectedTab).toBe(2);
271
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
272
+ key: " ",
273
+ bubbles: true,
274
+ cancelable: true,
275
+ }));
276
+ await page.waitForChanges();
277
+ expect(page.rootInstance.selectedTab).toBe(0);
278
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
279
+ key: "ArrowLeft",
280
+ bubbles: true,
281
+ cancelable: true,
282
+ }));
283
+ await page.waitForChanges();
284
+ expect(page.rootInstance.focusedTabIndex).toBe(2);
285
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
286
+ key: "ArrowLeft",
287
+ bubbles: true,
288
+ cancelable: true,
289
+ }));
290
+ await page.waitForChanges();
291
+ expect(page.rootInstance.focusedTabIndex).toBe(1);
292
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
293
+ key: "ArrowRight",
294
+ bubbles: true,
295
+ cancelable: true,
296
+ }));
297
+ await page.waitForChanges();
298
+ expect(page.rootInstance.focusedTabIndex).toBe(2);
299
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
300
+ key: "ArrowRight",
301
+ bubbles: true,
302
+ cancelable: true,
303
+ }));
304
+ await page.waitForChanges();
305
+ expect(page.rootInstance.focusedTabIndex).toBe(0);
306
+ tabGroup.dispatchEvent(new window.window.KeyboardEvent("keydown", {
307
+ key: "Escape",
308
+ bubbles: true,
309
+ cancelable: true,
310
+ }));
311
+ await page.waitForChanges();
312
+ expect(page.rootInstance.focusedTabIndex).toBe(0);
313
+ });
314
+ it("should apply tab and panel ids to elements added after initial render of the context", async () => {
315
+ const page = await newSpecPage({
316
+ components: [TabContext, TabGroup, Tab, TabPanel],
317
+ html: `<ic-tab-context>
318
+ <ic-tab-group label="Example tab group">
319
+ <ic-tab>One</ic-tab>
320
+ <ic-tab>Two</ic-tab>
321
+ <ic-tab>Three</ic-tab>
322
+ </ic-tab-group>
323
+ <ic-tab-panel>Tab One</ic-tab-panel>
324
+ <ic-tab-panel>Tab Two</ic-tab-panel>
325
+ <ic-tab-panel>Tab Three</ic-tab-panel>
326
+ </ic-tab-context>`,
327
+ });
328
+ const tabGroup = page.root.querySelector("ic-tab-group");
329
+ tabGroup.insertAdjacentHTML("beforeend", "<ic-tab>Four</ic-tab>");
330
+ page.root.insertAdjacentHTML("beforeend", "<ic-tab-panel>Four</ic-tab-panel>");
331
+ await page.waitForChanges();
332
+ const newTab = page.root.querySelector('[id*="ic-tab-3-context-default"]');
333
+ const newTabPanel = page.root.querySelector('[id*="ic-tab-panel-3-context-default"]');
334
+ expect(newTab.tabId).toBe("ic-tab--3-context-default");
335
+ expect(newTabPanel.panelId).toBe("ic-tab--3-context-default");
336
+ });
337
+ it("should reassign ids if tab and tab panel are dynamically removed", async () => {
338
+ const page = await newSpecPage({
339
+ components: [TabContext, TabGroup, Tab, TabPanel],
340
+ html: `<ic-tab-context>
341
+ <ic-tab-group label="Example tab group">
342
+ <ic-tab>One</ic-tab>
343
+ <ic-tab>Two</ic-tab>
344
+ <ic-tab>Three</ic-tab>
345
+ </ic-tab-group>
346
+ <ic-tab-panel>Tab One</ic-tab-panel>
347
+ <ic-tab-panel>Tab Two</ic-tab-panel>
348
+ <ic-tab-panel>Tab Three</ic-tab-panel>
349
+ </ic-tab-context>`,
350
+ });
351
+ const tabGroup = page.root.querySelector("ic-tab-group");
352
+ let allTabs = tabGroup.querySelectorAll("ic-tab");
353
+ let allTabPanels = page.root.querySelectorAll("ic-tab-panel");
354
+ expect(allTabs.length).toBe(3);
355
+ expect(allTabPanels.length).toBe(3);
356
+ allTabPanels[allTabPanels.length - 2].remove();
357
+ allTabs[allTabs.length - 2].remove();
358
+ await page.waitForChanges();
359
+ allTabs = tabGroup.querySelectorAll("ic-tab");
360
+ allTabPanels = page.root.querySelectorAll("ic-tab-panel");
361
+ expect(allTabs.length).toBe(2);
362
+ expect(allTabPanels.length).toBe(2);
363
+ const newlyUpdatedTab = page.root.querySelector('[id*="ic-tab-1-context-default"]');
364
+ const newlyUpdatedTabPanel = page.root.querySelector('[id*="ic-tab-panel-1-context-default"]');
365
+ expect(newlyUpdatedTab.tabId).toBe("ic-tab--1-context-default");
366
+ expect(newlyUpdatedTabPanel.panelId).toBe("ic-tab--1-context-default");
367
+ });
368
+ });
369
+ //# sourceMappingURL=ic-tab-context.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ic-tab-context.spec.js","sourceRoot":"","sources":["../../../src/components/ic-tab-context/ic-tab-context.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import { newSpecPage } from \"@stencil/core/testing\";\nimport { TabGroup } from \"../ic-tab-group/ic-tab-group\";\nimport { TabPanel } from \"../ic-tab-panel/ic-tab-panel\";\nimport { Tab } from \"../ic-tab/ic-tab\";\nimport { TabContext } from \"./ic-tab-context\";\n\nbeforeAll(() => {\n jest.spyOn(console, \"warn\").mockImplementation(jest.fn());\n});\n\ndescribe(\"ic-tab-context component\", () => {\n it(\"should render tab context with tabs\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context>\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n expect(page.root).toMatchSnapshot();\n\n //test disconnected callback for automatic activation\n page.setContent(\"\");\n });\n\n it(\"should render tab context with tabs - light appearance\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context appearance=\"light\">\n <ic-tab-group label=\"Example tab group\" appearance=\"light\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render tab context with tabs - selected tab\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context selected-tab-index=\"2\">\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should test controlled mode - selected tab\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context selected-tab-index=\"2\">\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n expect(page.rootInstance.selectedTab).toBe(2);\n\n const eventSpy = jest.fn();\n page.root.addEventListener(\"icTabSelect\", eventSpy);\n\n const tabGroup = page.root.querySelector(\"ic-tab-group\");\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"Home\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(eventSpy).toHaveBeenCalled();\n });\n\n it(\"should render tab context with tabs - manual activation\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context activation-type=\"manual\">\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n expect(page.root).toMatchSnapshot();\n\n //test disconnected callback for manual activation\n page.setContent(\"\");\n });\n\n it(\"should render tab context with custom contextId\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context context-id=\"custom-context\">\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should test setting selected tab\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context>\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n expect(page.rootInstance.selectedTab).toBe(0);\n\n page.root.selectedTabIndex = 1;\n await page.waitForChanges();\n\n expect(page.rootInstance.selectedTab).toBe(1);\n });\n\n it(\"should test tab click handler\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context>\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n expect(page.rootInstance.selectedTabIndex).toBe(undefined);\n\n const eventSpy = jest.fn();\n page.root.addEventListener(\"icTabSelect\", eventSpy);\n\n await page.rootInstance.tabClickHandler({\n stopImmediatePropagation: jest.fn(),\n detail: {\n contextId: \"default\",\n position: 1,\n tabId: \"ic-tab--1-context-default\",\n },\n });\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(1);\n expect(eventSpy).toHaveBeenCalled();\n });\n\n it(\"should test key down handler - automatic\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context>\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n const tabGroup = page.root.querySelector(\"ic-tab-group\");\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"End\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(2);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"Home\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(0);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"ArrowLeft\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(2);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"ArrowLeft\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(1);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"ArrowRight\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(2);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"ArrowRight\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(0);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"Escape\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(0);\n });\n\n it(\"should test key down handler - manual\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context activation-type=\"manual\">\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n const tabGroup = page.root.querySelector(\"ic-tab-group\");\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"End\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(0);\n expect(page.rootInstance.focusedTabIndex).toBe(2);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"Enter\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(2);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"Home\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.focusedTabIndex).toBe(0);\n expect(page.rootInstance.selectedTab).toBe(2);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \" \",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.selectedTab).toBe(0);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"ArrowLeft\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.focusedTabIndex).toBe(2);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"ArrowLeft\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.focusedTabIndex).toBe(1);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"ArrowRight\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.focusedTabIndex).toBe(2);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"ArrowRight\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.focusedTabIndex).toBe(0);\n\n tabGroup.dispatchEvent(\n new window.window.KeyboardEvent(\"keydown\", {\n key: \"Escape\",\n bubbles: true,\n cancelable: true,\n })\n );\n\n await page.waitForChanges();\n expect(page.rootInstance.focusedTabIndex).toBe(0);\n });\n\n it(\"should apply tab and panel ids to elements added after initial render of the context\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context>\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n const tabGroup = page.root.querySelector(\"ic-tab-group\");\n\n tabGroup.insertAdjacentHTML(\"beforeend\", \"<ic-tab>Four</ic-tab>\");\n page.root.insertAdjacentHTML(\n \"beforeend\",\n \"<ic-tab-panel>Four</ic-tab-panel>\"\n );\n await page.waitForChanges();\n\n const newTab = page.root.querySelector(\n '[id*=\"ic-tab-3-context-default\"]'\n ) as HTMLIcTabElement;\n const newTabPanel = page.root.querySelector(\n '[id*=\"ic-tab-panel-3-context-default\"]'\n ) as HTMLIcTabPanelElement;\n\n expect(newTab.tabId).toBe(\"ic-tab--3-context-default\");\n expect(newTabPanel.panelId).toBe(\"ic-tab--3-context-default\");\n });\n\n it(\"should reassign ids if tab and tab panel are dynamically removed\", async () => {\n const page = await newSpecPage({\n components: [TabContext, TabGroup, Tab, TabPanel],\n html: `<ic-tab-context>\n <ic-tab-group label=\"Example tab group\">\n <ic-tab>One</ic-tab>\n <ic-tab>Two</ic-tab>\n <ic-tab>Three</ic-tab>\n </ic-tab-group>\n <ic-tab-panel>Tab One</ic-tab-panel>\n <ic-tab-panel>Tab Two</ic-tab-panel>\n <ic-tab-panel>Tab Three</ic-tab-panel>\n </ic-tab-context>`,\n });\n\n const tabGroup = page.root.querySelector(\"ic-tab-group\");\n\n let allTabs = tabGroup.querySelectorAll(\"ic-tab\");\n let allTabPanels = page.root.querySelectorAll(\"ic-tab-panel\");\n\n expect(allTabs.length).toBe(3);\n expect(allTabPanels.length).toBe(3);\n\n allTabPanels[allTabPanels.length - 2].remove();\n allTabs[allTabs.length - 2].remove();\n\n await page.waitForChanges();\n\n allTabs = tabGroup.querySelectorAll(\"ic-tab\");\n allTabPanels = page.root.querySelectorAll(\"ic-tab-panel\");\n\n expect(allTabs.length).toBe(2);\n expect(allTabPanels.length).toBe(2);\n\n const newlyUpdatedTab = page.root.querySelector(\n '[id*=\"ic-tab-1-context-default\"]'\n ) as HTMLIcTabElement;\n const newlyUpdatedTabPanel = page.root.querySelector(\n '[id*=\"ic-tab-panel-1-context-default\"]'\n ) as HTMLIcTabPanelElement;\n\n expect(newlyUpdatedTab.tabId).toBe(\"ic-tab--1-context-default\");\n expect(newlyUpdatedTabPanel.panelId).toBe(\"ic-tab--1-context-default\");\n });\n});\n"]}
@@ -3,7 +3,7 @@
3
3
 
4
4
  display: block;
5
5
  margin-bottom: var(--ic-space-md);
6
- border-bottom: 1px solid var(--border-bottom-color);
6
+ border-bottom: var(--ic-border-default);
7
7
  }
8
8
 
9
9
  :host(.inline) {
@@ -12,7 +12,7 @@
12
12
  }
13
13
 
14
14
  .light {
15
- --border-bottom-color: var(--ic-architectural-white);
15
+ border-bottom: var(--ic-space-1px) solid var(--ic-architectural-white);
16
16
  }
17
17
 
18
18
  .tabs-container {
@@ -0,0 +1,65 @@
1
+ import { newSpecPage } from "@stencil/core/testing";
2
+ import { TabPanel } from "./ic-tab-panel";
3
+ describe("ic-tab component", () => {
4
+ it("should not be hidden if the corresponding tab is selected", async () => {
5
+ const page = await newSpecPage({
6
+ components: [TabPanel],
7
+ html: `<ic-tab-panel panel-id="1" selected-tab="1" tab-position=1>IC Tab Test</ic-tab-panel>`,
8
+ });
9
+ expect(page.root)
10
+ .toEqualHtml(`<ic-tab-panel panel-id="1" selected-tab="1" context-id="default" role="tabpanel" tab-position="1">
11
+ <mock:shadow-root>
12
+ <div>
13
+ <slot></slot>
14
+ </div>
15
+ </mock:shadow-root>
16
+ IC Tab Test
17
+ </ic-tab-panel>`);
18
+ });
19
+ it("should be hidden if the corresponding tab is not selected", async () => {
20
+ const page = await newSpecPage({
21
+ components: [TabPanel],
22
+ html: `<ic-tab-panel panel-id="1" selected-tab="2" tab-position=1>IC Tab Test</ic-tab-panel>`,
23
+ });
24
+ expect(page.root)
25
+ .toEqualHtml(`<ic-tab-panel panel-id="1" selected-tab="2" context-id="default" hidden="" role="tabpanel" tab-position="1">
26
+ <mock:shadow-root>
27
+ <div>
28
+ <slot></slot>
29
+ </div>
30
+ </mock:shadow-root>
31
+ IC Tab Test
32
+ </ic-tab-panel>`);
33
+ });
34
+ it("should be hidden if selectedTab and panelId are undefined", async () => {
35
+ const page = await newSpecPage({
36
+ components: [TabPanel],
37
+ html: `<ic-tab-panel tab-position=1>IC Tab Test</ic-tab-panel>`,
38
+ });
39
+ expect(page.root)
40
+ .toEqualHtml(`<ic-tab-panel context-id="default" hidden="" role="tabpanel" tab-position="1">
41
+ <mock:shadow-root>
42
+ <div>
43
+ <slot></slot>
44
+ </div>
45
+ </mock:shadow-root>
46
+ IC Tab Test
47
+ </ic-tab-panel>`);
48
+ });
49
+ it("should be hidden if selectedTab and panelId are undefined", async () => {
50
+ const page = await newSpecPage({
51
+ components: [TabPanel],
52
+ html: `<ic-tab-panel>IC Tab Test</ic-tab-panel>`,
53
+ });
54
+ expect(page.root)
55
+ .toEqualHtml(`<ic-tab-panel context-id="default" hidden="" role="tabpanel">
56
+ <mock:shadow-root>
57
+ <div>
58
+ <slot></slot>
59
+ </div>
60
+ </mock:shadow-root>
61
+ IC Tab Test
62
+ </ic-tab-panel>`);
63
+ });
64
+ });
65
+ //# sourceMappingURL=ic-tab-panel.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ic-tab-panel.spec.js","sourceRoot":"","sources":["../../../src/components/ic-tab-panel/ic-tab-panel.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;EAChC,EAAE,CAAC,2DAA2D,EAAE,KAAK,IAAI,EAAE;IACzE,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,QAAQ,CAAC;MACtB,IAAI,EAAE,uFAAuF;KAC9F,CAAC,CAAC;IAEH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;OACd,WAAW,CAAC;;;;;;;kBAOD,CAAC,CAAC;EAClB,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,2DAA2D,EAAE,KAAK,IAAI,EAAE;IACzE,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,QAAQ,CAAC;MACtB,IAAI,EAAE,uFAAuF;KAC9F,CAAC,CAAC;IAEH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;OACd,WAAW,CAAC;;;;;;;kBAOD,CAAC,CAAC;EAClB,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,2DAA2D,EAAE,KAAK,IAAI,EAAE;IACzE,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,QAAQ,CAAC;MACtB,IAAI,EAAE,yDAAyD;KAChE,CAAC,CAAC;IAEH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;OACd,WAAW,CAAC;;;;;;;kBAOD,CAAC,CAAC;EAClB,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,2DAA2D,EAAE,KAAK,IAAI,EAAE;IACzE,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,QAAQ,CAAC;MACtB,IAAI,EAAE,0CAA0C;KACjD,CAAC,CAAC;IAEH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;OACd,WAAW,CAAC;;;;;;;kBAOD,CAAC,CAAC;EAClB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newSpecPage } from \"@stencil/core/testing\";\nimport { TabPanel } from \"./ic-tab-panel\";\n\ndescribe(\"ic-tab component\", () => {\n it(\"should not be hidden if the corresponding tab is selected\", async () => {\n const page = await newSpecPage({\n components: [TabPanel],\n html: `<ic-tab-panel panel-id=\"1\" selected-tab=\"1\" tab-position=1>IC Tab Test</ic-tab-panel>`,\n });\n\n expect(page.root)\n .toEqualHtml(`<ic-tab-panel panel-id=\"1\" selected-tab=\"1\" context-id=\"default\" role=\"tabpanel\" tab-position=\"1\">\n <mock:shadow-root>\n <div>\n <slot></slot>\n </div>\n </mock:shadow-root>\n IC Tab Test\n </ic-tab-panel>`);\n });\n\n it(\"should be hidden if the corresponding tab is not selected\", async () => {\n const page = await newSpecPage({\n components: [TabPanel],\n html: `<ic-tab-panel panel-id=\"1\" selected-tab=\"2\" tab-position=1>IC Tab Test</ic-tab-panel>`,\n });\n\n expect(page.root)\n .toEqualHtml(`<ic-tab-panel panel-id=\"1\" selected-tab=\"2\" context-id=\"default\" hidden=\"\" role=\"tabpanel\" tab-position=\"1\">\n <mock:shadow-root>\n <div>\n <slot></slot>\n </div>\n </mock:shadow-root>\n IC Tab Test\n </ic-tab-panel>`);\n });\n\n it(\"should be hidden if selectedTab and panelId are undefined\", async () => {\n const page = await newSpecPage({\n components: [TabPanel],\n html: `<ic-tab-panel tab-position=1>IC Tab Test</ic-tab-panel>`,\n });\n\n expect(page.root)\n .toEqualHtml(`<ic-tab-panel context-id=\"default\" hidden=\"\" role=\"tabpanel\" tab-position=\"1\">\n <mock:shadow-root>\n <div>\n <slot></slot>\n </div>\n </mock:shadow-root>\n IC Tab Test\n </ic-tab-panel>`);\n });\n\n it(\"should be hidden if selectedTab and panelId are undefined\", async () => {\n const page = await newSpecPage({\n components: [TabPanel],\n html: `<ic-tab-panel>IC Tab Test</ic-tab-panel>`,\n });\n\n expect(page.root)\n .toEqualHtml(`<ic-tab-panel context-id=\"default\" hidden=\"\" role=\"tabpanel\">\n <mock:shadow-root>\n <div>\n <slot></slot>\n </div>\n </mock:shadow-root>\n IC Tab Test\n </ic-tab-panel>`);\n });\n});\n"]}
@@ -516,10 +516,6 @@ textarea.no-resize {
516
516
  color: var(--ic-color-secondary-text);
517
517
  }
518
518
 
519
- .error {
520
- color: var(--ic-status-error);
521
- }
522
-
523
519
  .disabled {
524
520
  color: var(--ic-architectural-200);
525
521
  }
@@ -0,0 +1,98 @@
1
+ import { newE2EPage } from "@stencil/core/testing";
2
+ describe("ic-text-field", () => {
3
+ it("should trigger max length validation when long value set", async () => {
4
+ const page = await newE2EPage();
5
+ await page.setContent('<ic-text-field label="Test label" max-length="20">');
6
+ await page.waitForChanges();
7
+ const element = await page.find("ic-text-field");
8
+ element.setProperty("value", "a really long test value");
9
+ await page.waitForChanges();
10
+ const input = await page.find("ic-text-field >>> #ic-text-field-input-0");
11
+ const value = await input.getProperty("value");
12
+ expect(value).toBe("a really long test value");
13
+ let icon = await page.find("ic-text-field >>> .icon-error");
14
+ let iconVis = await icon.isVisible();
15
+ expect(iconVis).toBeTruthy();
16
+ const validationText = await page.find("ic-text-field >>> #ic-text-field-input-0-validation-text");
17
+ expect(validationText).toEqualText("Maximum length exceeded");
18
+ const charCountText = await page.find("ic-text-field >>> #ic-text-field-input-0-charcount");
19
+ expect(charCountText).toEqualText("24/20");
20
+ await input.press("Backspace");
21
+ await input.press("Backspace");
22
+ await input.press("Backspace");
23
+ await input.press("Backspace");
24
+ expect(charCountText).toEqualText("20/20");
25
+ expect(validationText).toEqualText("");
26
+ icon = await page.find("ic-text-field >>> .icon-error");
27
+ expect(icon).toBeNull();
28
+ await input.press("a");
29
+ expect(charCountText).toEqualText("21/20");
30
+ expect(validationText).toEqualText("Maximum length exceeded");
31
+ icon = await page.find("ic-text-field >>> .icon-error");
32
+ iconVis = await icon.isVisible();
33
+ expect(iconVis).toBeTruthy();
34
+ });
35
+ it("should trigger min/max value validation when lower/higher value set", async () => {
36
+ const page = await newE2EPage();
37
+ await page.setContent('<ic-text-field label="Test label" min=1 max=4 inputmode="numeric" type="number"');
38
+ await page.waitForChanges();
39
+ const element = await page.find("ic-text-field");
40
+ element.setProperty("value", "5");
41
+ await page.waitForChanges();
42
+ const input = await page.find("ic-text-field >>> #ic-text-field-input-0");
43
+ const value = await input.getProperty("value");
44
+ expect(value).toBe("5");
45
+ const icon = await page.find("ic-text-field >>> .icon-error");
46
+ const iconVis = await icon.isVisible();
47
+ expect(iconVis).toBeTruthy();
48
+ let validationText = await page.find("ic-text-field >>> #ic-text-field-input-0-validation-text");
49
+ expect(validationText).toEqualText("Maximum value of 4 exceeded");
50
+ element.setProperty("value", "4");
51
+ await page.waitForChanges();
52
+ validationText = await page.find("ic-text-field >>> #ic-text-field-input-0-validation-text");
53
+ expect(validationText).toBeNull();
54
+ element.setProperty("value", "0");
55
+ await page.waitForChanges();
56
+ validationText = await page.find("ic-text-field >>> #ic-text-field-input-0-validation-text");
57
+ expect(validationText).toEqualText("Minimum value of 1 not met");
58
+ });
59
+ it("should focus input when setFocus method called", async () => {
60
+ const page = await newE2EPage();
61
+ await page.setContent('<ic-text-field label="Test label">');
62
+ await page.waitForChanges();
63
+ const element = await page.find("ic-text-field");
64
+ await element.callMethod("setFocus");
65
+ await page.waitForChanges();
66
+ const activeElId = await page.$eval("ic-text-field", (el) => el.shadowRoot.activeElement.id);
67
+ expect(activeElId).toBe("ic-text-field-input-0");
68
+ });
69
+ it("works on a form", async () => {
70
+ const page = await newE2EPage();
71
+ await page.setContent('<form><ic-text-field label="Test label" name="formInputEl"></ic-text-field><button id="resetButton" type="reset">Reset</button></form>');
72
+ await page.waitForChanges();
73
+ let input = await page.find("ic-text-field >>> #ic-text-field-input-0");
74
+ await input.press("s");
75
+ await input.press("o");
76
+ await input.press("m");
77
+ await input.press("e");
78
+ await input.press("Space");
79
+ await input.press("t");
80
+ await input.press("e");
81
+ await input.press("x");
82
+ await input.press("t");
83
+ let value = await input.getProperty("value");
84
+ expect(value).toBe("some text");
85
+ //check value on underlying hidden form control
86
+ const formInput = await page.find("input[name=formInputEl]");
87
+ const visible = await formInput.isVisible();
88
+ expect(visible).toBe(false);
89
+ const formInputvalue = await formInput.getProperty("value");
90
+ expect(formInputvalue).toBe("some text");
91
+ const resetButton = await page.find("#resetButton");
92
+ await resetButton.click();
93
+ input = await page.find("ic-text-field >>> #ic-text-field-input-0");
94
+ value = await input.getProperty("value");
95
+ expect(value).toBe("");
96
+ });
97
+ });
98
+ //# sourceMappingURL=ic-text-field.e2e.js.map