@ukic/web-components 2.1.0-beta.8 → 2.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1215) hide show
  1. package/dist/cjs/OpenInNew-f9958725.js +7 -0
  2. package/dist/cjs/OpenInNew-f9958725.js.map +1 -0
  3. package/dist/cjs/chevron-icon-2bb3a907.js +10 -0
  4. package/dist/cjs/chevron-icon-2bb3a907.js.map +1 -0
  5. package/dist/cjs/core.cjs.js +10 -3
  6. package/dist/cjs/core.cjs.js.map +1 -1
  7. package/dist/cjs/{helpers-5f391578.js → helpers-eb53c416.js} +96 -27
  8. package/dist/cjs/helpers-eb53c416.js.map +1 -0
  9. package/dist/cjs/ic-alert.cjs.entry.js +12 -35
  10. package/dist/cjs/ic-alert.cjs.entry.js.map +1 -1
  11. package/dist/cjs/ic-back-to-top.cjs.entry.js +6 -5
  12. package/dist/cjs/ic-back-to-top.cjs.entry.js.map +1 -1
  13. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +39 -33
  14. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js.map +1 -1
  15. package/dist/cjs/ic-breadcrumb.cjs.entry.js +16 -14
  16. package/dist/cjs/ic-breadcrumb.cjs.entry.js.map +1 -1
  17. package/dist/cjs/ic-button_3.cjs.entry.js +179 -104
  18. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ic-card.cjs.entry.js +46 -45
  20. package/dist/cjs/ic-card.cjs.entry.js.map +1 -1
  21. package/dist/cjs/ic-checkbox-group.cjs.entry.js +24 -23
  22. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  23. package/dist/cjs/ic-checkbox.cjs.entry.js +42 -29
  24. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ic-chip.cjs.entry.js +19 -15
  26. package/dist/cjs/ic-chip.cjs.entry.js.map +1 -1
  27. package/dist/cjs/ic-classification-banner.cjs.entry.js +1 -1
  28. package/dist/cjs/ic-classification-banner.cjs.entry.js.map +1 -1
  29. package/dist/cjs/ic-data-entity.cjs.entry.js +2 -2
  30. package/dist/cjs/ic-data-entity.cjs.entry.js.map +1 -1
  31. package/dist/cjs/ic-data-row.cjs.entry.js +38 -24
  32. package/dist/cjs/ic-data-row.cjs.entry.js.map +1 -1
  33. package/dist/cjs/ic-dialog.cjs.entry.js +295 -0
  34. package/dist/cjs/ic-dialog.cjs.entry.js.map +1 -0
  35. package/dist/cjs/ic-divider.cjs.entry.js +3 -3
  36. package/dist/cjs/ic-divider.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ic-footer-link-group.cjs.entry.js +19 -18
  38. package/dist/cjs/ic-footer-link-group.cjs.entry.js.map +1 -1
  39. package/dist/cjs/ic-footer-link.cjs.entry.js +24 -17
  40. package/dist/cjs/ic-footer-link.cjs.entry.js.map +1 -1
  41. package/dist/cjs/ic-footer.cjs.entry.js +23 -21
  42. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -1
  43. package/dist/cjs/ic-hero.cjs.entry.js +23 -21
  44. package/dist/cjs/ic-hero.cjs.entry.js.map +1 -1
  45. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +177 -0
  46. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js.map +1 -0
  47. package/dist/cjs/ic-input-component-container_3.cjs.entry.js +300 -161
  48. package/dist/cjs/ic-input-component-container_3.cjs.entry.js.map +1 -1
  49. package/dist/cjs/ic-input-label_2.cjs.entry.js +14 -16
  50. package/dist/cjs/ic-input-label_2.cjs.entry.js.map +1 -1
  51. package/dist/cjs/ic-link.cjs.entry.js +23 -23
  52. package/dist/cjs/ic-link.cjs.entry.js.map +1 -1
  53. package/dist/cjs/ic-menu-group.cjs.entry.js +24 -0
  54. package/dist/cjs/ic-menu-group.cjs.entry.js.map +1 -0
  55. package/dist/cjs/ic-menu-item.cjs.entry.js +122 -0
  56. package/dist/cjs/ic-menu-item.cjs.entry.js.map +1 -0
  57. package/dist/cjs/ic-navigation-button.cjs.entry.js +20 -19
  58. package/dist/cjs/ic-navigation-button.cjs.entry.js.map +1 -1
  59. package/dist/cjs/ic-navigation-group.cjs.entry.js +88 -58
  60. package/dist/cjs/ic-navigation-group.cjs.entry.js.map +1 -1
  61. package/dist/cjs/ic-navigation-item.cjs.entry.js +50 -42
  62. package/dist/cjs/ic-navigation-item.cjs.entry.js.map +1 -1
  63. package/dist/cjs/ic-navigation-menu.cjs.entry.js +31 -37
  64. package/dist/cjs/ic-navigation-menu.cjs.entry.js.map +1 -1
  65. package/dist/cjs/ic-page-header.cjs.entry.js +25 -28
  66. package/dist/cjs/ic-page-header.cjs.entry.js.map +1 -1
  67. package/dist/cjs/ic-pagination-item.cjs.entry.js +56 -0
  68. package/dist/cjs/ic-pagination-item.cjs.entry.js.map +1 -0
  69. package/dist/cjs/ic-pagination.cjs.entry.js +227 -0
  70. package/dist/cjs/ic-pagination.cjs.entry.js.map +1 -0
  71. package/dist/cjs/ic-popover-menu.cjs.entry.js +237 -0
  72. package/dist/cjs/ic-popover-menu.cjs.entry.js.map +1 -0
  73. package/dist/cjs/ic-radio-group.cjs.entry.js +43 -25
  74. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -1
  75. package/dist/cjs/ic-radio-option.cjs.entry.js +40 -38
  76. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  77. package/dist/cjs/ic-search-bar.cjs.entry.js +181 -101
  78. package/dist/cjs/ic-search-bar.cjs.entry.js.map +1 -1
  79. package/dist/cjs/ic-section-container.cjs.entry.js +2 -2
  80. package/dist/cjs/ic-section-container.cjs.entry.js.map +1 -1
  81. package/dist/cjs/ic-select.cjs.entry.js +360 -177
  82. package/dist/cjs/ic-select.cjs.entry.js.map +1 -1
  83. package/dist/cjs/ic-side-navigation.cjs.entry.js +116 -87
  84. package/dist/cjs/ic-side-navigation.cjs.entry.js.map +1 -1
  85. package/dist/cjs/ic-skeleton.cjs.entry.js +4 -4
  86. package/dist/cjs/ic-skeleton.cjs.entry.js.map +1 -1
  87. package/dist/cjs/ic-status-tag.cjs.entry.js +6 -6
  88. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -1
  89. package/dist/cjs/ic-step.cjs.entry.js +10 -10
  90. package/dist/cjs/ic-step.cjs.entry.js.map +1 -1
  91. package/dist/cjs/ic-stepper.cjs.entry.js +15 -15
  92. package/dist/cjs/ic-stepper.cjs.entry.js.map +1 -1
  93. package/dist/cjs/ic-switch.cjs.entry.js +21 -19
  94. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  95. package/dist/cjs/ic-tab-context.cjs.entry.js +68 -32
  96. package/dist/cjs/ic-tab-context.cjs.entry.js.map +1 -1
  97. package/dist/cjs/ic-tab-group.cjs.entry.js +10 -118
  98. package/dist/cjs/ic-tab-group.cjs.entry.js.map +1 -1
  99. package/dist/cjs/ic-tab-panel.cjs.entry.js +15 -4
  100. package/dist/cjs/ic-tab-panel.cjs.entry.js.map +1 -1
  101. package/dist/cjs/ic-tab.cjs.entry.js +32 -7
  102. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -1
  103. package/dist/cjs/ic-text-field.cjs.entry.js +102 -72
  104. package/dist/cjs/ic-text-field.cjs.entry.js.map +1 -1
  105. package/dist/cjs/ic-theme.cjs.entry.js +2 -2
  106. package/dist/cjs/ic-theme.cjs.entry.js.map +1 -1
  107. package/dist/cjs/ic-toast-region.cjs.entry.js +48 -0
  108. package/dist/cjs/ic-toast-region.cjs.entry.js.map +1 -0
  109. package/dist/cjs/ic-toast.cjs.entry.js +169 -0
  110. package/dist/cjs/ic-toast.cjs.entry.js.map +1 -0
  111. package/dist/cjs/ic-top-navigation.cjs.entry.js +52 -48
  112. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -1
  113. package/dist/cjs/ic-typography.cjs.entry.js +97 -5
  114. package/dist/cjs/ic-typography.cjs.entry.js.map +1 -1
  115. package/dist/cjs/{index-3ef30d9d.js → index-2a0c6769.js} +272 -44
  116. package/dist/cjs/index-2a0c6769.js.map +1 -0
  117. package/dist/cjs/loader.cjs.js +4 -3
  118. package/dist/cjs/loader.cjs.js.map +1 -1
  119. package/dist/cjs/{popper-11d5f714.js → popper-d7adcfc6.js} +10 -17
  120. package/dist/cjs/popper-d7adcfc6.js.map +1 -0
  121. package/dist/cjs/types-3eb02246.js.map +1 -1
  122. package/dist/collection/assets/error-icon.svg +2 -2
  123. package/dist/collection/assets/info-icon.svg +2 -2
  124. package/dist/collection/assets/neutral-icon.svg +2 -2
  125. package/dist/collection/assets/pagination-first-last.svg +3 -0
  126. package/dist/collection/assets/pagination-next-previous.svg +3 -0
  127. package/dist/collection/assets/success-icon.svg +2 -2
  128. package/dist/collection/assets/warning-icon.svg +2 -2
  129. package/dist/collection/collection-manifest.json +20 -11
  130. package/dist/collection/components/ic-alert/ic-alert.css +1 -1
  131. package/dist/collection/components/ic-alert/ic-alert.js +51 -62
  132. package/dist/collection/components/ic-alert/ic-alert.js.map +1 -1
  133. package/dist/collection/components/ic-alert/{ic-alert.test.a11y.js → test/a11y/ic-alert.test.a11y.js} +1 -1
  134. package/dist/collection/components/ic-alert/test/a11y/ic-alert.test.a11y.js.map +1 -0
  135. package/dist/collection/components/ic-alert/test/basic/ic-alert.e2e.js +16 -0
  136. package/dist/collection/components/ic-alert/test/basic/ic-alert.e2e.js.map +1 -0
  137. package/dist/collection/components/ic-alert/test/basic/ic-alert.spec.js +182 -0
  138. package/dist/collection/components/ic-alert/test/basic/ic-alert.spec.js.map +1 -0
  139. package/dist/collection/components/ic-back-to-top/ic-back-to-top.css +8 -4
  140. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js +5 -4
  141. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js.map +1 -1
  142. package/dist/collection/components/ic-back-to-top/test/a11y/ic-back-to-top.test.a11y.js.map +1 -0
  143. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.e2e.js +68 -0
  144. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.e2e.js.map +1 -0
  145. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.spec.js +123 -0
  146. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.spec.js.map +1 -0
  147. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.css +19 -4
  148. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js +30 -28
  149. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js.map +1 -1
  150. package/dist/collection/components/ic-breadcrumb/test/basic/ic-breadcrumb.spec.js +118 -0
  151. package/dist/collection/components/ic-breadcrumb/test/basic/ic-breadcrumb.spec.js.map +1 -0
  152. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js +37 -31
  153. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js.map +1 -1
  154. package/dist/collection/components/ic-breadcrumb-group/{ic-breadcrumb-group.test.a11y.js → test/a11y/ic-breadcrumb-group.test.a11y.js} +1 -1
  155. package/dist/collection/components/ic-breadcrumb-group/test/a11y/ic-breadcrumb-group.test.a11y.js.map +1 -0
  156. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group-test-examples.js.map +1 -0
  157. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.e2e.js +41 -0
  158. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.e2e.js.map +1 -0
  159. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.spec.js +181 -0
  160. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.spec.js.map +1 -0
  161. package/dist/collection/components/ic-button/ic-button.css +23 -8
  162. package/dist/collection/components/ic-button/ic-button.js +270 -114
  163. package/dist/collection/components/ic-button/ic-button.js.map +1 -1
  164. package/dist/collection/components/ic-button/{ic-button.test.a11y.js → test/a11y/ic-button.test.a11y.js} +1 -1
  165. package/dist/collection/components/ic-button/test/a11y/ic-button.test.a11y.js.map +1 -0
  166. package/dist/collection/components/ic-button/test/basic/ic-button.e2e.js +198 -0
  167. package/dist/collection/components/ic-button/test/basic/ic-button.e2e.js.map +1 -0
  168. package/dist/collection/components/ic-button/test/basic/ic-button.spec.js +256 -0
  169. package/dist/collection/components/ic-button/test/basic/ic-button.spec.js.map +1 -0
  170. package/dist/collection/components/ic-card/ic-card.css +35 -10
  171. package/dist/collection/components/ic-card/ic-card.js +123 -122
  172. package/dist/collection/components/ic-card/ic-card.js.map +1 -1
  173. package/dist/collection/components/ic-card/{ic-card.test.a11y.js → test/a11y/ic-card.test.a11y.js} +1 -1
  174. package/dist/collection/components/ic-card/test/a11y/ic-card.test.a11y.js.map +1 -0
  175. package/dist/collection/components/ic-card/test/basic/ic-card.e2e.js +23 -0
  176. package/dist/collection/components/ic-card/test/basic/ic-card.e2e.js.map +1 -0
  177. package/dist/collection/components/ic-card/test/basic/ic-card.spec.js +152 -0
  178. package/dist/collection/components/ic-card/test/basic/ic-card.spec.js.map +1 -0
  179. package/dist/collection/components/ic-checkbox/ic-checkbox.css +11 -8
  180. package/dist/collection/components/ic-checkbox/ic-checkbox.js +108 -76
  181. package/dist/collection/components/ic-checkbox/ic-checkbox.js.map +1 -1
  182. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.css +3 -3
  183. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js +64 -67
  184. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js.map +1 -1
  185. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.types.js.map +1 -1
  186. package/dist/collection/components/ic-checkbox-group/{ic-checkbox-group.test.a11y.js → test/a11y/ic-checkbox-group.test.a11y.js} +1 -1
  187. package/dist/collection/components/ic-checkbox-group/test/a11y/ic-checkbox-group.test.a11y.js.map +1 -0
  188. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.e2e.js +201 -0
  189. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.e2e.js.map +1 -0
  190. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.spec.js +175 -0
  191. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.spec.js.map +1 -0
  192. package/dist/collection/components/ic-chip/ic-chip.css +11 -10
  193. package/dist/collection/components/ic-chip/ic-chip.js +56 -52
  194. package/dist/collection/components/ic-chip/ic-chip.js.map +1 -1
  195. package/dist/collection/components/ic-chip/{ic-chip.test.a11y.js → test/a11y/ic-chip.test.a11y.js} +1 -1
  196. package/dist/collection/components/ic-chip/test/a11y/ic-chip.test.a11y.js.map +1 -0
  197. package/dist/collection/components/ic-chip/test/basic/ic-chip.spec.js +110 -0
  198. package/dist/collection/components/ic-chip/test/basic/ic-chip.spec.js.map +1 -0
  199. package/dist/collection/components/ic-classification-banner/ic-classification-banner.css +4 -0
  200. package/dist/collection/components/ic-classification-banner/{ic-classification-banner.test.a11y.js → test/a11y/ic-classification-banner.test.a11y.js} +1 -1
  201. package/dist/collection/components/ic-classification-banner/test/a11y/ic-classification-banner.test.a11y.js.map +1 -0
  202. package/dist/collection/components/ic-classification-banner/test/basic/ic-classification-banner.spec.js +140 -0
  203. package/dist/collection/components/ic-classification-banner/test/basic/ic-classification-banner.spec.js.map +1 -0
  204. package/dist/collection/components/ic-data-entity/ic-data-entity.css +1 -1
  205. package/dist/collection/components/ic-data-entity/{ic-data-entity.test.a11y.js → test/a11y/ic-data-entity.test.a11y.js} +1 -1
  206. package/dist/collection/components/ic-data-entity/test/a11y/ic-data-entity.test.a11y.js.map +1 -0
  207. package/dist/collection/components/ic-data-entity/test/basic/ic-data-entity.spec.js +161 -0
  208. package/dist/collection/components/ic-data-entity/test/basic/ic-data-entity.spec.js.map +1 -0
  209. package/dist/collection/components/ic-data-row/ic-data-row.css +1 -1
  210. package/dist/collection/components/ic-data-row/ic-data-row.js +51 -37
  211. package/dist/collection/components/ic-data-row/ic-data-row.js.map +1 -1
  212. package/dist/collection/components/ic-data-row/{ic-data-row.test.a11y.js → test/a11y/ic-data-row.test.a11y.js} +1 -1
  213. package/dist/collection/components/ic-data-row/test/a11y/ic-data-row.test.a11y.js.map +1 -0
  214. package/dist/collection/components/ic-data-row/test/basic/ic-data-row.spec.js +74 -0
  215. package/dist/collection/components/ic-data-row/test/basic/ic-data-row.spec.js.map +1 -0
  216. package/dist/collection/components/ic-dialog/ic-dialog.css +592 -0
  217. package/dist/collection/components/ic-dialog/ic-dialog.js +640 -0
  218. package/dist/collection/components/ic-dialog/ic-dialog.js.map +1 -0
  219. package/dist/collection/components/ic-dialog/test/a11y/ic-dialog.test.a11y.js +28 -0
  220. package/dist/collection/components/ic-dialog/test/a11y/ic-dialog.test.a11y.js.map +1 -0
  221. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.e2e.js +207 -0
  222. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.e2e.js.map +1 -0
  223. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.spec.js +520 -0
  224. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.spec.js.map +1 -0
  225. package/dist/collection/components/ic-divider/ic-divider.css +1 -1
  226. package/dist/collection/components/ic-divider/test/basic/ic-divider.spec.js +24 -0
  227. package/dist/collection/components/ic-divider/test/basic/ic-divider.spec.js.map +1 -0
  228. package/dist/collection/components/ic-footer/ic-footer.css +2 -2
  229. package/dist/collection/components/ic-footer/ic-footer.js +51 -49
  230. package/dist/collection/components/ic-footer/ic-footer.js.map +1 -1
  231. package/dist/collection/components/ic-footer/{ic-footer.test.a11y.js → test/a11y/ic-footer.test.a11y.js} +1 -1
  232. package/dist/collection/components/ic-footer/test/a11y/ic-footer.test.a11y.js.map +1 -0
  233. package/dist/collection/components/ic-footer/test/basic/ic-footer.e2e.js +50 -0
  234. package/dist/collection/components/ic-footer/test/basic/ic-footer.e2e.js.map +1 -0
  235. package/dist/collection/components/ic-footer/test/basic/ic-footer.spec.js +140 -0
  236. package/dist/collection/components/ic-footer/test/basic/ic-footer.spec.js.map +1 -0
  237. package/dist/collection/components/ic-footer-link/ic-footer-link.css +36 -4
  238. package/dist/collection/components/ic-footer-link/ic-footer-link.js +112 -15
  239. package/dist/collection/components/ic-footer-link/ic-footer-link.js.map +1 -1
  240. package/dist/collection/components/ic-footer-link/{ic-footer-link.test.a11y.js → test/a11y/ic-footer-link.test.a11y.js} +1 -1
  241. package/dist/collection/components/ic-footer-link/test/a11y/ic-footer-link.test.a11y.js.map +1 -0
  242. package/dist/collection/components/ic-footer-link/test/basic/ic-footer-link.spec.js +62 -0
  243. package/dist/collection/components/ic-footer-link/test/basic/ic-footer-link.spec.js.map +1 -0
  244. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js +19 -18
  245. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js.map +1 -1
  246. package/dist/collection/components/ic-footer-link-group/{ic-footer-link-group.test.a11y.js → test/a11y/ic-footer-link-group.test.a11y.js} +1 -1
  247. package/dist/collection/components/ic-footer-link-group/test/a11y/ic-footer-link-group.test.a11y.js.map +1 -0
  248. package/dist/collection/components/ic-footer-link-group/test/basic/ic-footer-link-group.spec.js +98 -0
  249. package/dist/collection/components/ic-footer-link-group/test/basic/ic-footer-link-group.spec.js.map +1 -0
  250. package/dist/collection/components/ic-hero/ic-hero.css +23 -22
  251. package/dist/collection/components/ic-hero/ic-hero.js +97 -95
  252. package/dist/collection/components/ic-hero/ic-hero.js.map +1 -1
  253. package/dist/collection/components/ic-hero/{ic-hero.test.a11y.js → test/a11y/ic-hero.test.a11y.js} +1 -1
  254. package/dist/collection/components/ic-hero/test/a11y/ic-hero.test.a11y.js.map +1 -0
  255. package/dist/collection/components/ic-hero/test/basic/ic-hero.spec.js +76 -0
  256. package/dist/collection/components/ic-hero/test/basic/ic-hero.spec.js.map +1 -0
  257. package/dist/collection/components/ic-horizontal-scroll/assets/left-arrow.svg +3 -0
  258. package/dist/collection/components/ic-horizontal-scroll/assets/right-arrow.svg +3 -0
  259. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.css +535 -0
  260. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js +232 -0
  261. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js.map +1 -0
  262. package/dist/collection/components/ic-horizontal-scroll/test/a11y/ic-horizontal-scroll.test.a11y.js +34 -0
  263. package/dist/collection/components/ic-horizontal-scroll/test/a11y/ic-horizontal-scroll.test.a11y.js.map +1 -0
  264. package/dist/collection/components/ic-horizontal-scroll/test/basic/ic-horizontal-scroll.spec.js +180 -0
  265. package/dist/collection/components/ic-horizontal-scroll/test/basic/ic-horizontal-scroll.spec.js.map +1 -0
  266. package/dist/collection/components/ic-input-component-container/ic-input-component-container.css +38 -9
  267. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js +45 -45
  268. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js.map +1 -1
  269. package/dist/collection/components/ic-input-component-container/test/basic/ic-input-component-container.spec.js +117 -0
  270. package/dist/collection/components/ic-input-component-container/test/basic/ic-input-component-container.spec.js.map +1 -0
  271. package/dist/collection/components/ic-input-container/test/basic/ic-input-container.spec.js +38 -0
  272. package/dist/collection/components/ic-input-container/test/basic/ic-input-container.spec.js.map +1 -0
  273. package/dist/collection/components/ic-input-label/ic-input-label.css +0 -4
  274. package/dist/collection/components/ic-input-label/ic-input-label.js +51 -51
  275. package/dist/collection/components/ic-input-label/ic-input-label.js.map +1 -1
  276. package/dist/collection/components/ic-input-label/test/basic/ic-input-label.spec.js +98 -0
  277. package/dist/collection/components/ic-input-label/test/basic/ic-input-label.spec.js.map +1 -0
  278. package/dist/collection/components/ic-input-validation/ic-input-validation.css +0 -8
  279. package/dist/collection/components/ic-input-validation/ic-input-validation.js +41 -41
  280. package/dist/collection/components/ic-input-validation/ic-input-validation.js.map +1 -1
  281. package/dist/collection/components/ic-input-validation/test/basic/ic-input-validation.spec.js +89 -0
  282. package/dist/collection/components/ic-input-validation/test/basic/ic-input-validation.spec.js.map +1 -0
  283. package/dist/collection/components/ic-link/ic-link.css +16 -3
  284. package/dist/collection/components/ic-link/ic-link.js +56 -52
  285. package/dist/collection/components/ic-link/ic-link.js.map +1 -1
  286. package/dist/collection/components/ic-link/{ic-link.test.a11y.js → test/a11y/ic-link.test.a11y.js} +1 -1
  287. package/dist/collection/components/ic-link/test/a11y/ic-link.test.a11y.js.map +1 -0
  288. package/dist/collection/components/ic-link/test/basic/ic-link.spec.js +203 -0
  289. package/dist/collection/components/ic-link/test/basic/ic-link.spec.js.map +1 -0
  290. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.css +5 -5
  291. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js +112 -101
  292. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js.map +1 -1
  293. package/dist/collection/components/ic-loading-indicator/{ic-loading-indicator.test.a11y.js → test/a11y/ic-loading-indicator.test.a11y.js} +1 -1
  294. package/dist/collection/components/ic-loading-indicator/test/a11y/ic-loading-indicator.test.a11y.js.map +1 -0
  295. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.e2e.js +34 -0
  296. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.e2e.js.map +1 -0
  297. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.spec.js +141 -0
  298. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.spec.js.map +1 -0
  299. package/dist/collection/components/ic-menu/ic-menu.css +52 -11
  300. package/dist/collection/components/ic-menu/ic-menu.js +521 -268
  301. package/dist/collection/components/ic-menu/ic-menu.js.map +1 -1
  302. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js +657 -0
  303. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js.map +1 -0
  304. package/dist/collection/components/ic-menu-group/ic-menu-group.css +465 -0
  305. package/dist/collection/components/ic-menu-group/ic-menu-group.js +45 -0
  306. package/dist/collection/components/ic-menu-group/ic-menu-group.js.map +1 -0
  307. package/dist/collection/components/ic-menu-group/test/basic/ic-menu-group.spec.js +94 -0
  308. package/dist/collection/components/ic-menu-group/test/basic/ic-menu-group.spec.js.map +1 -0
  309. package/dist/collection/components/ic-menu-item/ic-menu-item.css +628 -0
  310. package/dist/collection/components/ic-menu-item/ic-menu-item.js +394 -0
  311. package/dist/collection/components/ic-menu-item/ic-menu-item.js.map +1 -0
  312. package/dist/collection/components/ic-menu-item/ic-menu-item.types.js +2 -0
  313. package/dist/collection/components/ic-menu-item/ic-menu-item.types.js.map +1 -0
  314. package/dist/collection/components/ic-menu-item/test/basic/ic-menu-item.spec.js +108 -0
  315. package/dist/collection/components/ic-menu-item/test/basic/ic-menu-item.spec.js.map +1 -0
  316. package/dist/collection/components/ic-navigation-button/ic-navigation-button.css +4 -0
  317. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js +58 -57
  318. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js.map +1 -1
  319. package/dist/collection/components/ic-navigation-button/test/basic/ic-navigation-button.spec.js +84 -0
  320. package/dist/collection/components/ic-navigation-button/test/basic/ic-navigation-button.spec.js.map +1 -0
  321. package/dist/collection/components/ic-navigation-group/ic-navigation-group.css +8 -11
  322. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js +102 -72
  323. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js.map +1 -1
  324. package/dist/collection/components/ic-navigation-group/{ic-navigation-group.test.a11y.js → test/a11y/ic-navigation-group.test.a11y.js} +1 -1
  325. package/dist/collection/components/ic-navigation-group/test/a11y/ic-navigation-group.test.a11y.js.map +1 -0
  326. package/dist/collection/components/ic-navigation-group/test/basic/ic-navigation-group.spec.js +309 -0
  327. package/dist/collection/components/ic-navigation-group/test/basic/ic-navigation-group.spec.js.map +1 -0
  328. package/dist/collection/components/ic-navigation-item/ic-navigation-item.css +70 -20
  329. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js +181 -83
  330. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js.map +1 -1
  331. package/dist/collection/components/ic-navigation-item/{ic-navigation-item.test.a11y.js → test/a11y/ic-navigation-item.test.a11y.js} +1 -1
  332. package/dist/collection/components/ic-navigation-item/test/a11y/ic-navigation-item.test.a11y.js.map +1 -0
  333. package/dist/collection/components/ic-navigation-item/test/basic/ic-navigation-item.spec.js +118 -0
  334. package/dist/collection/components/ic-navigation-item/test/basic/ic-navigation-item.spec.js.map +1 -0
  335. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.css +23 -18
  336. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js +34 -40
  337. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js.map +1 -1
  338. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.e2e.js +29 -0
  339. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.e2e.js.map +1 -0
  340. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.spec.js +176 -0
  341. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.spec.js.map +1 -0
  342. package/dist/collection/components/ic-page-header/ic-page-header.css +12 -1
  343. package/dist/collection/components/ic-page-header/ic-page-header.js +66 -69
  344. package/dist/collection/components/ic-page-header/ic-page-header.js.map +1 -1
  345. package/dist/collection/components/ic-page-header/{ic-page-header.test.a11y.js → test/a11y/ic-page-header.test.a11y.js} +1 -1
  346. package/dist/collection/components/ic-page-header/test/a11y/ic-page-header.test.a11y.js.map +1 -0
  347. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.e2e.js +177 -0
  348. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.e2e.js.map +1 -0
  349. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.spec.js +284 -0
  350. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.spec.js.map +1 -0
  351. package/dist/collection/components/ic-pagination/ic-pagination.css +486 -0
  352. package/dist/collection/components/ic-pagination/ic-pagination.js +498 -0
  353. package/dist/collection/components/ic-pagination/ic-pagination.js.map +1 -0
  354. package/dist/collection/components/ic-pagination/ic-pagination.types.js +2 -0
  355. package/dist/collection/components/ic-pagination/ic-pagination.types.js.map +1 -0
  356. package/dist/collection/components/ic-pagination/test/a11y/ic-pagination.test.a11y.js +11 -0
  357. package/dist/collection/components/ic-pagination/test/a11y/ic-pagination.test.a11y.js.map +1 -0
  358. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.e2e.js +128 -0
  359. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.e2e.js.map +1 -0
  360. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.spec.js +335 -0
  361. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.spec.js.map +1 -0
  362. package/dist/collection/components/ic-pagination-item/ic-pagination-item.css +581 -0
  363. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js +229 -0
  364. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js.map +1 -0
  365. package/dist/collection/components/ic-pagination-item/ic-pagination-item.types.js +2 -0
  366. package/dist/collection/components/ic-pagination-item/ic-pagination-item.types.js.map +1 -0
  367. package/dist/collection/components/ic-popover-menu/ic-popover-menu.css +536 -0
  368. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js +433 -0
  369. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js.map +1 -0
  370. package/dist/collection/components/ic-popover-menu/test/a11y/ic-popover-menu.test.a11y.js +13 -0
  371. package/dist/collection/components/ic-popover-menu/test/a11y/ic-popover-menu.test.a11y.js.map +1 -0
  372. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.e2e.js +30 -0
  373. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.e2e.js.map +1 -0
  374. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.spec.js +381 -0
  375. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.spec.js.map +1 -0
  376. package/dist/collection/components/ic-radio-group/ic-radio-group.css +4 -4
  377. package/dist/collection/components/ic-radio-group/ic-radio-group.js +104 -80
  378. package/dist/collection/components/ic-radio-group/ic-radio-group.js.map +1 -1
  379. package/dist/collection/components/ic-radio-group/ic-radio-group.types.js +2 -0
  380. package/dist/collection/components/ic-radio-group/ic-radio-group.types.js.map +1 -0
  381. package/dist/collection/components/ic-radio-group/{ic-radio-group.test.a11y.js → test/a11y/ic-radio-group.test.a11y.js} +1 -1
  382. package/dist/collection/components/ic-radio-group/test/a11y/ic-radio-group.test.a11y.js.map +1 -0
  383. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.e2e.js +343 -0
  384. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.e2e.js.map +1 -0
  385. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.spec.js +303 -0
  386. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.spec.js.map +1 -0
  387. package/dist/collection/components/ic-radio-option/ic-radio-option.css +6 -6
  388. package/dist/collection/components/ic-radio-option/ic-radio-option.js +112 -96
  389. package/dist/collection/components/ic-radio-option/ic-radio-option.js.map +1 -1
  390. package/dist/collection/components/ic-search-bar/ic-search-bar.css +18 -14
  391. package/dist/collection/components/ic-search-bar/ic-search-bar.js +496 -299
  392. package/dist/collection/components/ic-search-bar/ic-search-bar.js.map +1 -1
  393. package/dist/collection/components/ic-search-bar/ic-search-bar.types.js.map +1 -1
  394. package/dist/collection/components/ic-search-bar/{ic-search-bar.test.a11y.js → test/a11y/ic-search-bar.test.a11y.js} +1 -1
  395. package/dist/collection/components/ic-search-bar/test/a11y/ic-search-bar.test.a11y.js.map +1 -0
  396. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.e2e.js +1099 -0
  397. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.e2e.js.map +1 -0
  398. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.spec.js +584 -0
  399. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.spec.js.map +1 -0
  400. package/dist/collection/components/ic-section-container/ic-section-container.css +1 -0
  401. package/dist/collection/components/ic-section-container/test/basic/ic-section-container.spec.js +69 -0
  402. package/dist/collection/components/ic-section-container/test/basic/ic-section-container.spec.js.map +1 -0
  403. package/dist/collection/components/ic-select/ic-select.css +20 -19
  404. package/dist/collection/components/ic-select/ic-select.js +641 -356
  405. package/dist/collection/components/ic-select/ic-select.js.map +1 -1
  406. package/dist/collection/components/ic-select/{ic-select.test.a11y.js → test/a11y/ic-select.test.a11y.js} +1 -1
  407. package/dist/collection/components/ic-select/test/a11y/ic-select.test.a11y.js.map +1 -0
  408. package/dist/collection/components/ic-select/test/basic/ic-select.e2e.js +1768 -0
  409. package/dist/collection/components/ic-select/test/basic/ic-select.e2e.js.map +1 -0
  410. package/dist/collection/components/ic-select/test/basic/ic-select.spec.js +1296 -0
  411. package/dist/collection/components/ic-select/test/basic/ic-select.spec.js.map +1 -0
  412. package/dist/collection/components/ic-side-navigation/ic-side-navigation.css +55 -46
  413. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js +156 -127
  414. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js.map +1 -1
  415. package/dist/collection/components/ic-side-navigation/{ic-side-navigation.test.a11y.js → test/a11y/ic-side-navigation.test.a11y.js} +1 -1
  416. package/dist/collection/components/ic-side-navigation/test/a11y/ic-side-navigation.test.a11y.js.map +1 -0
  417. package/dist/collection/components/ic-side-navigation/{ic-side-navigation-test-examples.js → test/basic/ic-side-navigation-test-examples.js} +90 -0
  418. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation-test-examples.js.map +1 -0
  419. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.e2e.js +412 -0
  420. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.e2e.js.map +1 -0
  421. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.spec.js +470 -0
  422. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.spec.js.map +1 -0
  423. package/dist/collection/components/ic-skeleton/ic-skeleton.js +22 -22
  424. package/dist/collection/components/ic-skeleton/ic-skeleton.js.map +1 -1
  425. package/dist/collection/components/ic-skeleton/{ic-skeleton.test.a11y.js → test/a11y/ic-skeleton.test.a11y.js} +1 -1
  426. package/dist/collection/components/ic-skeleton/test/a11y/ic-skeleton.test.a11y.js.map +1 -0
  427. package/dist/collection/components/ic-skeleton/test/basic/ic-skeleton.spec.js +89 -0
  428. package/dist/collection/components/ic-skeleton/test/basic/ic-skeleton.spec.js.map +1 -0
  429. package/dist/collection/components/ic-status-tag/ic-status-tag.css +10 -13
  430. package/dist/collection/components/ic-status-tag/ic-status-tag.js +40 -40
  431. package/dist/collection/components/ic-status-tag/ic-status-tag.js.map +1 -1
  432. package/dist/collection/components/ic-status-tag/{ic-status-tag.test.a11y.js → test/a11y/ic-status-tag.test.a11y.js} +1 -1
  433. package/dist/collection/components/ic-status-tag/test/a11y/ic-status-tag.test.a11y.js.map +1 -0
  434. package/dist/collection/components/ic-status-tag/test/basic/ic-status-tag.spec.js +43 -0
  435. package/dist/collection/components/ic-status-tag/test/basic/ic-status-tag.spec.js.map +1 -0
  436. package/dist/collection/components/ic-step/ic-step.css +6 -6
  437. package/dist/collection/components/ic-step/ic-step.js +127 -127
  438. package/dist/collection/components/ic-step/ic-step.js.map +1 -1
  439. package/dist/collection/components/ic-step/test/basic/ic-step.spec.js +176 -0
  440. package/dist/collection/components/ic-step/test/basic/ic-step.spec.js.map +1 -0
  441. package/dist/collection/components/ic-stepper/ic-stepper.js +41 -41
  442. package/dist/collection/components/ic-stepper/ic-stepper.js.map +1 -1
  443. package/dist/collection/components/ic-stepper/{ic-stepper.test.a11y.js → test/a11y/ic-stepper.test.a11y.js} +1 -1
  444. package/dist/collection/components/ic-stepper/test/a11y/ic-stepper.test.a11y.js.map +1 -0
  445. package/dist/collection/components/ic-stepper/test/basic/ic-stepper-test-examples.js.map +1 -0
  446. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.e2e.js +49 -0
  447. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.e2e.js.map +1 -0
  448. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.spec.js +706 -0
  449. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.spec.js.map +1 -0
  450. package/dist/collection/components/ic-switch/ic-switch.css +4 -4
  451. package/dist/collection/components/ic-switch/ic-switch.js +75 -73
  452. package/dist/collection/components/ic-switch/ic-switch.js.map +1 -1
  453. package/dist/collection/components/ic-switch/{ic-switch.test.a11y.js → test/a11y/ic-switch.test.a11y.js} +1 -1
  454. package/dist/collection/components/ic-switch/test/a11y/ic-switch.test.a11y.js.map +1 -0
  455. package/dist/collection/components/ic-switch/test/basic/ic-switch.spec.js +104 -0
  456. package/dist/collection/components/ic-switch/test/basic/ic-switch.spec.js.map +1 -0
  457. package/dist/collection/components/ic-tab/ic-tab.css +4 -4
  458. package/dist/collection/components/ic-tab/ic-tab.js +114 -31
  459. package/dist/collection/components/ic-tab/ic-tab.js.map +1 -1
  460. package/dist/collection/components/ic-tab/test/basic/ic-tab.e2e.js +32 -0
  461. package/dist/collection/components/ic-tab/test/basic/ic-tab.e2e.js.map +1 -0
  462. package/dist/collection/components/ic-tab/test/basic/ic-tab.spec.js +159 -0
  463. package/dist/collection/components/ic-tab/test/basic/ic-tab.spec.js.map +1 -0
  464. package/dist/collection/components/ic-tab-context/ic-tab-context.js +157 -77
  465. package/dist/collection/components/ic-tab-context/ic-tab-context.js.map +1 -1
  466. package/dist/collection/components/ic-tab-context/test/a11y/ic-tab-context.test.a11y.js.map +1 -0
  467. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.e2e.js +317 -0
  468. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.e2e.js.map +1 -0
  469. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.spec.js +390 -0
  470. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.spec.js.map +1 -0
  471. package/dist/collection/components/ic-tab-group/ic-tab-group.css +6 -120
  472. package/dist/collection/components/ic-tab-group/ic-tab-group.js +40 -180
  473. package/dist/collection/components/ic-tab-group/ic-tab-group.js.map +1 -1
  474. package/dist/collection/components/ic-tab-panel/ic-tab-panel.css +0 -4
  475. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js +89 -34
  476. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js.map +1 -1
  477. package/dist/collection/components/ic-tab-panel/test/basic/ic-tab-panel.spec.js +65 -0
  478. package/dist/collection/components/ic-tab-panel/test/basic/ic-tab-panel.spec.js.map +1 -0
  479. package/dist/collection/components/ic-text-field/ic-text-field.css +1 -10
  480. package/dist/collection/components/ic-text-field/ic-text-field.js +456 -345
  481. package/dist/collection/components/ic-text-field/ic-text-field.js.map +1 -1
  482. package/dist/collection/components/ic-text-field/test/a11y/ic-text-field.test.a11y.js.map +1 -0
  483. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.e2e.js +98 -0
  484. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.e2e.js.map +1 -0
  485. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.input.spec.js +236 -0
  486. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.input.spec.js.map +1 -0
  487. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.textarea.spec.js +310 -0
  488. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.textarea.spec.js.map +1 -0
  489. package/dist/collection/components/ic-theme/ic-theme.js.map +1 -1
  490. package/dist/collection/components/ic-theme/test/basic/ic-theme.e2e.js +72 -0
  491. package/dist/collection/components/ic-theme/test/basic/ic-theme.e2e.js.map +1 -0
  492. package/dist/collection/components/ic-theme/test/basic/ic-theme.spec.js +77 -0
  493. package/dist/collection/components/ic-theme/test/basic/ic-theme.spec.js.map +1 -0
  494. package/dist/collection/components/ic-toast/ic-toast.css +602 -0
  495. package/dist/collection/components/ic-toast/ic-toast.js +386 -0
  496. package/dist/collection/components/ic-toast/ic-toast.js.map +1 -0
  497. package/dist/collection/components/ic-toast/ic-toast.types.js +2 -0
  498. package/dist/collection/components/ic-toast/ic-toast.types.js.map +1 -0
  499. package/dist/collection/components/ic-toast/test/a11y/ic-toast.test.a11y.js +16 -0
  500. package/dist/collection/components/ic-toast/test/a11y/ic-toast.test.a11y.js.map +1 -0
  501. package/dist/collection/components/ic-toast/test/basic/ic-toast.e2e.js +82 -0
  502. package/dist/collection/components/ic-toast/test/basic/ic-toast.e2e.js.map +1 -0
  503. package/dist/collection/components/ic-toast/test/basic/ic-toast.spec.js +278 -0
  504. package/dist/collection/components/ic-toast/test/basic/ic-toast.spec.js.map +1 -0
  505. package/dist/collection/components/ic-toast-region/ic-toast-region.js +81 -0
  506. package/dist/collection/components/ic-toast-region/ic-toast-region.js.map +1 -0
  507. package/dist/collection/components/ic-toast-region/test/basic/ic-toast-region.spec.js +62 -0
  508. package/dist/collection/components/ic-toast-region/test/basic/ic-toast-region.spec.js.map +1 -0
  509. package/dist/collection/components/ic-tooltip/ic-tooltip.css +27 -15
  510. package/dist/collection/components/ic-tooltip/ic-tooltip.js +116 -64
  511. package/dist/collection/components/ic-tooltip/ic-tooltip.js.map +1 -1
  512. package/dist/collection/components/ic-tooltip/{ic-tooltip.test.a11y.js → test/a11y/ic-tooltip.test.a11y.js} +1 -1
  513. package/dist/collection/components/ic-tooltip/test/a11y/ic-tooltip.test.a11y.js.map +1 -0
  514. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.e2e.js +115 -0
  515. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.e2e.js.map +1 -0
  516. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.spec.js +128 -0
  517. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.spec.js.map +1 -0
  518. package/dist/collection/components/ic-top-navigation/ic-top-navigation.css +25 -48
  519. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js +108 -86
  520. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js.map +1 -1
  521. package/dist/collection/components/ic-top-navigation/{ic-top-navigation.test.a11y.js → test/a11y/ic-top-navigation.test.a11y.js} +8 -1
  522. package/dist/collection/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.js.map +1 -0
  523. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.e2e.js +61 -0
  524. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.e2e.js.map +1 -0
  525. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.mobile.e2e.js +242 -0
  526. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.mobile.e2e.js.map +1 -0
  527. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.spec.js +299 -0
  528. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.spec.js.map +1 -0
  529. package/dist/collection/components/ic-typography/ic-typography.css +58 -1
  530. package/dist/collection/components/ic-typography/ic-typography.js +140 -22
  531. package/dist/collection/components/ic-typography/ic-typography.js.map +1 -1
  532. package/dist/collection/components/ic-typography/{ic-typography.test.a11y.js → test/a11y/ic-typography.test.a11y.js} +1 -1
  533. package/dist/collection/components/ic-typography/test/a11y/ic-typography.test.a11y.js.map +1 -0
  534. package/dist/collection/components/ic-typography/test/basic/ic-typography.e2e.js +39 -0
  535. package/dist/collection/components/ic-typography/test/basic/ic-typography.e2e.js.map +1 -0
  536. package/dist/collection/components/ic-typography/test/basic/ic-typography.spec.js +296 -0
  537. package/dist/collection/components/ic-typography/test/basic/ic-typography.spec.js.map +1 -0
  538. package/dist/collection/testspec.setup.js +21 -0
  539. package/dist/collection/testspec.setup.js.map +1 -1
  540. package/dist/collection/utils/constants.js +28 -0
  541. package/dist/collection/utils/constants.js.map +1 -1
  542. package/dist/collection/utils/helpers.js +31 -27
  543. package/dist/collection/utils/helpers.js.map +1 -1
  544. package/dist/collection/utils/types.js.map +1 -1
  545. package/dist/components/OpenInNew.js +5 -0
  546. package/dist/components/OpenInNew.js.map +1 -0
  547. package/dist/components/helpers.js +89 -27
  548. package/dist/components/helpers.js.map +1 -1
  549. package/dist/components/ic-alert.js +1 -136
  550. package/dist/components/ic-alert.js.map +1 -1
  551. package/dist/components/ic-alert2.js +117 -0
  552. package/dist/components/ic-alert2.js.map +1 -0
  553. package/dist/components/ic-back-to-top.js +9 -8
  554. package/dist/components/ic-back-to-top.js.map +1 -1
  555. package/dist/components/ic-breadcrumb-group.js +39 -33
  556. package/dist/components/ic-breadcrumb-group.js.map +1 -1
  557. package/dist/components/ic-breadcrumb2.js +16 -14
  558. package/dist/components/ic-breadcrumb2.js.map +1 -1
  559. package/dist/components/ic-button2.js +101 -45
  560. package/dist/components/ic-button2.js.map +1 -1
  561. package/dist/components/ic-card.js +54 -53
  562. package/dist/components/ic-card.js.map +1 -1
  563. package/dist/components/ic-checkbox-group.js +28 -28
  564. package/dist/components/ic-checkbox-group.js.map +1 -1
  565. package/dist/components/ic-checkbox.js +49 -35
  566. package/dist/components/ic-checkbox.js.map +1 -1
  567. package/dist/components/ic-chip.js +24 -20
  568. package/dist/components/ic-chip.js.map +1 -1
  569. package/dist/components/ic-classification-banner.js +1 -1
  570. package/dist/components/ic-classification-banner.js.map +1 -1
  571. package/dist/components/ic-data-entity.js +2 -2
  572. package/dist/components/ic-data-entity.js.map +1 -1
  573. package/dist/components/ic-data-row.js +39 -25
  574. package/dist/components/ic-data-row.js.map +1 -1
  575. package/dist/components/ic-dialog.d.ts +11 -0
  576. package/dist/components/ic-dialog.js +356 -0
  577. package/dist/components/ic-dialog.js.map +1 -0
  578. package/dist/components/ic-divider2.js +3 -3
  579. package/dist/components/ic-divider2.js.map +1 -1
  580. package/dist/components/ic-footer-link-group.js +22 -21
  581. package/dist/components/ic-footer-link-group.js.map +1 -1
  582. package/dist/components/ic-footer-link.js +31 -19
  583. package/dist/components/ic-footer-link.js.map +1 -1
  584. package/dist/components/ic-footer.js +25 -23
  585. package/dist/components/ic-footer.js.map +1 -1
  586. package/dist/components/ic-hero.js +30 -28
  587. package/dist/components/ic-hero.js.map +1 -1
  588. package/dist/components/ic-horizontal-scroll.d.ts +11 -0
  589. package/dist/components/ic-horizontal-scroll.js +8 -0
  590. package/dist/components/ic-horizontal-scroll.js.map +1 -0
  591. package/dist/components/ic-horizontal-scroll2.js +218 -0
  592. package/dist/components/ic-horizontal-scroll2.js.map +1 -0
  593. package/dist/components/ic-input-component-container2.js +11 -12
  594. package/dist/components/ic-input-component-container2.js.map +1 -1
  595. package/dist/components/ic-input-container2.js +1 -1
  596. package/dist/components/ic-input-label2.js +11 -11
  597. package/dist/components/ic-input-label2.js.map +1 -1
  598. package/dist/components/ic-input-validation2.js +9 -11
  599. package/dist/components/ic-input-validation2.js.map +1 -1
  600. package/dist/components/ic-link2.js +26 -26
  601. package/dist/components/ic-link2.js.map +1 -1
  602. package/dist/components/ic-loading-indicator2.js +49 -38
  603. package/dist/components/ic-loading-indicator2.js.map +1 -1
  604. package/dist/components/ic-menu-group.d.ts +11 -0
  605. package/dist/components/ic-menu-group.js +46 -0
  606. package/dist/components/ic-menu-group.js.map +1 -0
  607. package/dist/components/ic-menu-item.d.ts +11 -0
  608. package/dist/components/ic-menu-item.js +8 -0
  609. package/dist/components/ic-menu-item.js.map +1 -0
  610. package/dist/components/ic-menu-item2.js +169 -0
  611. package/dist/components/ic-menu-item2.js.map +1 -0
  612. package/dist/components/ic-menu2.js +326 -169
  613. package/dist/components/ic-menu2.js.map +1 -1
  614. package/dist/components/ic-navigation-button.js +26 -25
  615. package/dist/components/ic-navigation-button.js.map +1 -1
  616. package/dist/components/ic-navigation-group.js +91 -61
  617. package/dist/components/ic-navigation-group.js.map +1 -1
  618. package/dist/components/ic-navigation-item.js +62 -49
  619. package/dist/components/ic-navigation-item.js.map +1 -1
  620. package/dist/components/ic-navigation-menu2.js +33 -39
  621. package/dist/components/ic-navigation-menu2.js.map +1 -1
  622. package/dist/components/ic-page-header.js +57 -36
  623. package/dist/components/ic-page-header.js.map +1 -1
  624. package/dist/components/ic-pagination-item.d.ts +11 -0
  625. package/dist/components/ic-pagination-item.js +8 -0
  626. package/dist/components/ic-pagination-item.js.map +1 -0
  627. package/dist/components/ic-pagination-item2.js +81 -0
  628. package/dist/components/ic-pagination-item2.js.map +1 -0
  629. package/dist/components/ic-pagination.d.ts +11 -0
  630. package/dist/components/ic-pagination.js +288 -0
  631. package/dist/components/ic-pagination.js.map +1 -0
  632. package/dist/components/ic-popover-menu.d.ts +11 -0
  633. package/dist/components/ic-popover-menu.js +290 -0
  634. package/dist/components/ic-popover-menu.js.map +1 -0
  635. package/dist/components/ic-radio-group.js +48 -30
  636. package/dist/components/ic-radio-group.js.map +1 -1
  637. package/dist/components/ic-radio-option.js +46 -44
  638. package/dist/components/ic-radio-option.js.map +1 -1
  639. package/dist/components/ic-search-bar.js +206 -122
  640. package/dist/components/ic-search-bar.js.map +1 -1
  641. package/dist/components/ic-section-container2.js +2 -2
  642. package/dist/components/ic-section-container2.js.map +1 -1
  643. package/dist/components/ic-select.js +391 -200
  644. package/dist/components/ic-select.js.map +1 -1
  645. package/dist/components/ic-side-navigation.js +123 -94
  646. package/dist/components/ic-side-navigation.js.map +1 -1
  647. package/dist/components/ic-skeleton.js +6 -6
  648. package/dist/components/ic-skeleton.js.map +1 -1
  649. package/dist/components/ic-status-tag.js +9 -9
  650. package/dist/components/ic-status-tag.js.map +1 -1
  651. package/dist/components/ic-step.js +18 -18
  652. package/dist/components/ic-step.js.map +1 -1
  653. package/dist/components/ic-stepper.js +21 -21
  654. package/dist/components/ic-stepper.js.map +1 -1
  655. package/dist/components/ic-switch.js +26 -24
  656. package/dist/components/ic-switch.js.map +1 -1
  657. package/dist/components/ic-tab-context.js +73 -36
  658. package/dist/components/ic-tab-context.js.map +1 -1
  659. package/dist/components/ic-tab-group.js +33 -127
  660. package/dist/components/ic-tab-group.js.map +1 -1
  661. package/dist/components/ic-tab-panel.js +18 -7
  662. package/dist/components/ic-tab-panel.js.map +1 -1
  663. package/dist/components/ic-tab.js +33 -8
  664. package/dist/components/ic-tab.js.map +1 -1
  665. package/dist/components/ic-text-field2.js +132 -97
  666. package/dist/components/ic-text-field2.js.map +1 -1
  667. package/dist/components/ic-theme.js +2 -2
  668. package/dist/components/ic-theme.js.map +1 -1
  669. package/dist/components/ic-toast-region.d.ts +11 -0
  670. package/dist/components/ic-toast-region.js +63 -0
  671. package/dist/components/ic-toast-region.js.map +1 -0
  672. package/dist/components/ic-toast.d.ts +11 -0
  673. package/dist/components/ic-toast.js +218 -0
  674. package/dist/components/ic-toast.js.map +1 -0
  675. package/dist/components/ic-tooltip2.js +1854 -49
  676. package/dist/components/ic-tooltip2.js.map +1 -1
  677. package/dist/components/ic-top-navigation.js +70 -59
  678. package/dist/components/ic-top-navigation.js.map +1 -1
  679. package/dist/components/ic-typography2.js +101 -6
  680. package/dist/components/ic-typography2.js.map +1 -1
  681. package/dist/components/index.d.ts +9 -52
  682. package/dist/components/index.js +1 -50
  683. package/dist/components/index.js.map +1 -1
  684. package/dist/components/types.js.map +1 -1
  685. package/dist/core/core.css +47 -3
  686. package/dist/core/core.esm.js +1 -1
  687. package/dist/core/core.esm.js.map +1 -1
  688. package/dist/core/index.esm.js.map +1 -1
  689. package/dist/core/p-0330cb21.entry.js +2 -0
  690. package/dist/core/p-0330cb21.entry.js.map +1 -0
  691. package/dist/core/p-03d1a4a1.entry.js +2 -0
  692. package/dist/core/p-03d1a4a1.entry.js.map +1 -0
  693. package/dist/core/p-041604fc.entry.js +2 -0
  694. package/dist/core/p-041604fc.entry.js.map +1 -0
  695. package/dist/core/{p-24240e11.js → p-06321d19.js} +2 -2
  696. package/dist/core/p-06321d19.js.map +1 -0
  697. package/dist/core/p-1959ec8d.entry.js +2 -0
  698. package/dist/core/p-1959ec8d.entry.js.map +1 -0
  699. package/dist/core/p-1b9b8355.entry.js +2 -0
  700. package/dist/core/p-1b9b8355.entry.js.map +1 -0
  701. package/dist/core/p-26d5fd0f.entry.js +2 -0
  702. package/dist/core/p-26d5fd0f.entry.js.map +1 -0
  703. package/dist/core/p-27d42378.entry.js +2 -0
  704. package/dist/core/p-27d42378.entry.js.map +1 -0
  705. package/dist/core/p-2ae7687a.entry.js +2 -0
  706. package/dist/core/p-2ae7687a.entry.js.map +1 -0
  707. package/dist/core/p-332690f0.entry.js +2 -0
  708. package/dist/core/p-332690f0.entry.js.map +1 -0
  709. package/dist/core/p-39adc795.entry.js +2 -0
  710. package/dist/core/p-39adc795.entry.js.map +1 -0
  711. package/dist/core/{p-6be5e06b.entry.js → p-3adb1167.entry.js} +2 -2
  712. package/dist/core/p-3adb1167.entry.js.map +1 -0
  713. package/dist/core/p-429e4d24.entry.js +2 -0
  714. package/dist/core/p-429e4d24.entry.js.map +1 -0
  715. package/dist/core/{p-ccd078a6.entry.js → p-441e7d98.entry.js} +2 -2
  716. package/dist/core/p-441e7d98.entry.js.map +1 -0
  717. package/dist/core/p-44512ebe.js.map +1 -1
  718. package/dist/core/p-48301eff.entry.js +2 -0
  719. package/dist/core/p-48301eff.entry.js.map +1 -0
  720. package/dist/core/p-5144e840.entry.js +2 -0
  721. package/dist/core/p-5144e840.entry.js.map +1 -0
  722. package/dist/core/p-5c846d0a.entry.js +2 -0
  723. package/dist/core/p-5c846d0a.entry.js.map +1 -0
  724. package/dist/core/p-5c9c940f.entry.js +2 -0
  725. package/dist/core/p-5c9c940f.entry.js.map +1 -0
  726. package/dist/core/p-5dd0b02e.js +2 -0
  727. package/dist/core/p-5dd0b02e.js.map +1 -0
  728. package/dist/core/{p-c2710b13.entry.js → p-65750560.entry.js} +2 -2
  729. package/dist/core/p-65750560.entry.js.map +1 -0
  730. package/dist/core/p-6840589f.entry.js +2 -0
  731. package/dist/core/p-6840589f.entry.js.map +1 -0
  732. package/dist/core/p-69920d86.js +3 -0
  733. package/dist/core/p-69920d86.js.map +1 -0
  734. package/dist/core/p-6bad30aa.entry.js +2 -0
  735. package/dist/core/p-6bad30aa.entry.js.map +1 -0
  736. package/dist/core/p-6f57b13c.js.map +1 -1
  737. package/dist/core/p-7536dd31.entry.js +2 -0
  738. package/dist/core/p-7536dd31.entry.js.map +1 -0
  739. package/dist/core/p-7ae091ef.entry.js +2 -0
  740. package/dist/core/p-7ae091ef.entry.js.map +1 -0
  741. package/dist/core/p-7c0dcd00.js +2 -0
  742. package/dist/core/p-7c0dcd00.js.map +1 -0
  743. package/dist/core/p-7c46caf2.entry.js +2 -0
  744. package/dist/core/p-7c46caf2.entry.js.map +1 -0
  745. package/dist/core/{p-dd194ba9.entry.js → p-83d5bcae.entry.js} +2 -2
  746. package/dist/core/p-83d5bcae.entry.js.map +1 -0
  747. package/dist/core/p-892d9d9f.entry.js +2 -0
  748. package/dist/core/p-892d9d9f.entry.js.map +1 -0
  749. package/dist/core/p-8991f656.entry.js +2 -0
  750. package/dist/core/p-8991f656.entry.js.map +1 -0
  751. package/dist/core/p-8c45ab61.entry.js +2 -0
  752. package/dist/core/p-8c45ab61.entry.js.map +1 -0
  753. package/dist/core/p-8c7f4343.js.map +1 -1
  754. package/dist/core/p-8ca80000.entry.js +2 -0
  755. package/dist/core/p-8ca80000.entry.js.map +1 -0
  756. package/dist/core/p-8d4f7027.js +2 -0
  757. package/dist/core/p-8d4f7027.js.map +1 -0
  758. package/dist/core/p-90d3a41b.entry.js +2 -0
  759. package/dist/core/p-90d3a41b.entry.js.map +1 -0
  760. package/dist/core/p-95992c98.entry.js +2 -0
  761. package/dist/core/p-95992c98.entry.js.map +1 -0
  762. package/dist/core/p-96b71172.entry.js +2 -0
  763. package/dist/core/p-96b71172.entry.js.map +1 -0
  764. package/dist/core/{p-a2d3e955.entry.js → p-96bcd466.entry.js} +2 -2
  765. package/dist/core/p-96bcd466.entry.js.map +1 -0
  766. package/dist/core/p-9e551fe9.entry.js +2 -0
  767. package/dist/core/p-9e551fe9.entry.js.map +1 -0
  768. package/dist/core/{p-0672c783.entry.js → p-a29fe0c6.entry.js} +2 -2
  769. package/dist/core/p-a29fe0c6.entry.js.map +1 -0
  770. package/dist/core/{p-eaf714a3.entry.js → p-a588886f.entry.js} +2 -2
  771. package/dist/core/p-a588886f.entry.js.map +1 -0
  772. package/dist/core/{p-0f773f37.entry.js → p-a8b94619.entry.js} +2 -2
  773. package/dist/core/p-a8b94619.entry.js.map +1 -0
  774. package/dist/core/p-adceb0cf.entry.js +2 -0
  775. package/dist/core/p-adceb0cf.entry.js.map +1 -0
  776. package/dist/core/p-b698b8ad.entry.js +2 -0
  777. package/dist/core/p-b698b8ad.entry.js.map +1 -0
  778. package/dist/core/p-b6c538ea.entry.js +2 -0
  779. package/dist/core/p-b6c538ea.entry.js.map +1 -0
  780. package/dist/core/p-c012b867.entry.js +2 -0
  781. package/dist/core/p-c012b867.entry.js.map +1 -0
  782. package/dist/core/p-c5716cbc.entry.js +2 -0
  783. package/dist/core/p-c5716cbc.entry.js.map +1 -0
  784. package/dist/core/p-ca6d834e.entry.js +2 -0
  785. package/dist/core/p-ca6d834e.entry.js.map +1 -0
  786. package/dist/core/{p-97d4b6cd.entry.js → p-cbbf4b05.entry.js} +2 -2
  787. package/dist/core/p-cbbf4b05.entry.js.map +1 -0
  788. package/dist/core/p-ce791694.entry.js +2 -0
  789. package/dist/core/p-ce791694.entry.js.map +1 -0
  790. package/dist/core/p-cef93d12.entry.js +2 -0
  791. package/dist/core/p-cef93d12.entry.js.map +1 -0
  792. package/dist/core/p-d2215b72.entry.js +2 -0
  793. package/dist/core/p-d2215b72.entry.js.map +1 -0
  794. package/dist/core/p-e0ee714a.entry.js +2 -0
  795. package/dist/core/p-e0ee714a.entry.js.map +1 -0
  796. package/dist/core/p-e6370b7e.entry.js +2 -0
  797. package/dist/core/p-e6370b7e.entry.js.map +1 -0
  798. package/dist/core/p-ee11e185.entry.js +2 -0
  799. package/dist/core/p-ee11e185.entry.js.map +1 -0
  800. package/dist/core/p-f24814b8.entry.js +2 -0
  801. package/dist/core/p-f24814b8.entry.js.map +1 -0
  802. package/dist/core/p-f665242d.entry.js +2 -0
  803. package/dist/core/p-f665242d.entry.js.map +1 -0
  804. package/dist/core/p-f7695299.entry.js +2 -0
  805. package/dist/core/p-f7695299.entry.js.map +1 -0
  806. package/dist/core/p-f923d11b.entry.js +2 -0
  807. package/dist/core/p-f923d11b.entry.js.map +1 -0
  808. package/dist/esm/OpenInNew-67a881e0.js +5 -0
  809. package/dist/esm/OpenInNew-67a881e0.js.map +1 -0
  810. package/dist/esm/chevron-icon-7927f709.js +8 -0
  811. package/dist/esm/chevron-icon-7927f709.js.map +1 -0
  812. package/dist/esm/core.js +7 -3
  813. package/dist/esm/core.js.map +1 -1
  814. package/dist/esm/{helpers-3aa2f5a5.js → helpers-85903813.js} +90 -28
  815. package/dist/esm/helpers-85903813.js.map +1 -0
  816. package/dist/esm/ic-alert.entry.js +12 -35
  817. package/dist/esm/ic-alert.entry.js.map +1 -1
  818. package/dist/esm/ic-back-to-top.entry.js +6 -5
  819. package/dist/esm/ic-back-to-top.entry.js.map +1 -1
  820. package/dist/esm/ic-breadcrumb-group.entry.js +39 -33
  821. package/dist/esm/ic-breadcrumb-group.entry.js.map +1 -1
  822. package/dist/esm/ic-breadcrumb.entry.js +16 -14
  823. package/dist/esm/ic-breadcrumb.entry.js.map +1 -1
  824. package/dist/esm/ic-button_3.entry.js +179 -104
  825. package/dist/esm/ic-button_3.entry.js.map +1 -1
  826. package/dist/esm/ic-card.entry.js +46 -45
  827. package/dist/esm/ic-card.entry.js.map +1 -1
  828. package/dist/esm/ic-checkbox-group.entry.js +24 -23
  829. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  830. package/dist/esm/ic-checkbox.entry.js +42 -29
  831. package/dist/esm/ic-checkbox.entry.js.map +1 -1
  832. package/dist/esm/ic-chip.entry.js +19 -15
  833. package/dist/esm/ic-chip.entry.js.map +1 -1
  834. package/dist/esm/ic-classification-banner.entry.js +1 -1
  835. package/dist/esm/ic-classification-banner.entry.js.map +1 -1
  836. package/dist/esm/ic-data-entity.entry.js +2 -2
  837. package/dist/esm/ic-data-entity.entry.js.map +1 -1
  838. package/dist/esm/ic-data-row.entry.js +38 -24
  839. package/dist/esm/ic-data-row.entry.js.map +1 -1
  840. package/dist/esm/ic-dialog.entry.js +291 -0
  841. package/dist/esm/ic-dialog.entry.js.map +1 -0
  842. package/dist/esm/ic-divider.entry.js +3 -3
  843. package/dist/esm/ic-divider.entry.js.map +1 -1
  844. package/dist/esm/ic-footer-link-group.entry.js +19 -18
  845. package/dist/esm/ic-footer-link-group.entry.js.map +1 -1
  846. package/dist/esm/ic-footer-link.entry.js +24 -17
  847. package/dist/esm/ic-footer-link.entry.js.map +1 -1
  848. package/dist/esm/ic-footer.entry.js +23 -21
  849. package/dist/esm/ic-footer.entry.js.map +1 -1
  850. package/dist/esm/ic-hero.entry.js +23 -21
  851. package/dist/esm/ic-hero.entry.js.map +1 -1
  852. package/dist/esm/ic-horizontal-scroll.entry.js +173 -0
  853. package/dist/esm/ic-horizontal-scroll.entry.js.map +1 -0
  854. package/dist/esm/ic-input-component-container_3.entry.js +299 -160
  855. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -1
  856. package/dist/esm/ic-input-label_2.entry.js +11 -13
  857. package/dist/esm/ic-input-label_2.entry.js.map +1 -1
  858. package/dist/esm/ic-link.entry.js +23 -23
  859. package/dist/esm/ic-link.entry.js.map +1 -1
  860. package/dist/esm/ic-menu-group.entry.js +20 -0
  861. package/dist/esm/ic-menu-group.entry.js.map +1 -0
  862. package/dist/esm/ic-menu-item.entry.js +118 -0
  863. package/dist/esm/ic-menu-item.entry.js.map +1 -0
  864. package/dist/esm/ic-navigation-button.entry.js +20 -19
  865. package/dist/esm/ic-navigation-button.entry.js.map +1 -1
  866. package/dist/esm/ic-navigation-group.entry.js +88 -58
  867. package/dist/esm/ic-navigation-group.entry.js.map +1 -1
  868. package/dist/esm/ic-navigation-item.entry.js +50 -42
  869. package/dist/esm/ic-navigation-item.entry.js.map +1 -1
  870. package/dist/esm/ic-navigation-menu.entry.js +31 -37
  871. package/dist/esm/ic-navigation-menu.entry.js.map +1 -1
  872. package/dist/esm/ic-page-header.entry.js +25 -28
  873. package/dist/esm/ic-page-header.entry.js.map +1 -1
  874. package/dist/esm/ic-pagination-item.entry.js +52 -0
  875. package/dist/esm/ic-pagination-item.entry.js.map +1 -0
  876. package/dist/esm/ic-pagination.entry.js +223 -0
  877. package/dist/esm/ic-pagination.entry.js.map +1 -0
  878. package/dist/esm/ic-popover-menu.entry.js +233 -0
  879. package/dist/esm/ic-popover-menu.entry.js.map +1 -0
  880. package/dist/esm/ic-radio-group.entry.js +43 -25
  881. package/dist/esm/ic-radio-group.entry.js.map +1 -1
  882. package/dist/esm/ic-radio-option.entry.js +40 -38
  883. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  884. package/dist/esm/ic-search-bar.entry.js +181 -101
  885. package/dist/esm/ic-search-bar.entry.js.map +1 -1
  886. package/dist/esm/ic-section-container.entry.js +2 -2
  887. package/dist/esm/ic-section-container.entry.js.map +1 -1
  888. package/dist/esm/ic-select.entry.js +360 -177
  889. package/dist/esm/ic-select.entry.js.map +1 -1
  890. package/dist/esm/ic-side-navigation.entry.js +116 -87
  891. package/dist/esm/ic-side-navigation.entry.js.map +1 -1
  892. package/dist/esm/ic-skeleton.entry.js +4 -4
  893. package/dist/esm/ic-skeleton.entry.js.map +1 -1
  894. package/dist/esm/ic-status-tag.entry.js +6 -6
  895. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  896. package/dist/esm/ic-step.entry.js +10 -10
  897. package/dist/esm/ic-step.entry.js.map +1 -1
  898. package/dist/esm/ic-stepper.entry.js +15 -15
  899. package/dist/esm/ic-stepper.entry.js.map +1 -1
  900. package/dist/esm/ic-switch.entry.js +21 -19
  901. package/dist/esm/ic-switch.entry.js.map +1 -1
  902. package/dist/esm/ic-tab-context.entry.js +68 -32
  903. package/dist/esm/ic-tab-context.entry.js.map +1 -1
  904. package/dist/esm/ic-tab-group.entry.js +10 -118
  905. package/dist/esm/ic-tab-group.entry.js.map +1 -1
  906. package/dist/esm/ic-tab-panel.entry.js +15 -4
  907. package/dist/esm/ic-tab-panel.entry.js.map +1 -1
  908. package/dist/esm/ic-tab.entry.js +32 -7
  909. package/dist/esm/ic-tab.entry.js.map +1 -1
  910. package/dist/esm/ic-text-field.entry.js +102 -72
  911. package/dist/esm/ic-text-field.entry.js.map +1 -1
  912. package/dist/esm/ic-theme.entry.js +2 -2
  913. package/dist/esm/ic-theme.entry.js.map +1 -1
  914. package/dist/esm/ic-toast-region.entry.js +44 -0
  915. package/dist/esm/ic-toast-region.entry.js.map +1 -0
  916. package/dist/esm/ic-toast.entry.js +165 -0
  917. package/dist/esm/ic-toast.entry.js.map +1 -0
  918. package/dist/esm/ic-top-navigation.entry.js +52 -48
  919. package/dist/esm/ic-top-navigation.entry.js.map +1 -1
  920. package/dist/esm/ic-typography.entry.js +97 -5
  921. package/dist/esm/ic-typography.entry.js.map +1 -1
  922. package/dist/esm/{index-1500de1f.js → index-fd30b77e.js} +271 -45
  923. package/dist/esm/index-fd30b77e.js.map +1 -0
  924. package/dist/esm/loader.js +4 -3
  925. package/dist/esm/loader.js.map +1 -1
  926. package/dist/esm/polyfills/css-shim.js +1 -1
  927. package/dist/{components/popper.js → esm/popper-15e448b4.js} +10 -17
  928. package/dist/esm/popper-15e448b4.js.map +1 -0
  929. package/dist/esm/types-dd515332.js.map +1 -1
  930. package/dist/types/components/ic-alert/ic-alert.d.ts +13 -13
  931. package/dist/types/components/ic-back-to-top/ic-back-to-top.d.ts +8 -8
  932. package/dist/types/components/ic-breadcrumb/ic-breadcrumb.d.ts +6 -6
  933. package/dist/types/components/ic-breadcrumb/ic-breadcrumb.types.d.ts +1 -1
  934. package/dist/types/components/ic-breadcrumb-group/ic-breadcrumb-group.d.ts +16 -9
  935. package/dist/types/components/ic-button/ic-button.d.ts +62 -32
  936. package/dist/types/components/ic-button/ic-button.types.d.ts +4 -4
  937. package/dist/types/components/ic-card/ic-card.d.ts +32 -32
  938. package/dist/types/components/ic-checkbox/ic-checkbox.d.ts +29 -23
  939. package/dist/types/components/ic-checkbox-group/ic-checkbox-group.d.ts +14 -15
  940. package/dist/types/components/ic-checkbox-group/ic-checkbox-group.types.d.ts +5 -0
  941. package/dist/types/components/ic-chip/ic-chip.d.ts +16 -15
  942. package/dist/types/components/ic-chip/ic-chip.types.d.ts +2 -2
  943. package/dist/types/components/ic-classification-banner/ic-classification-banner.types.d.ts +1 -1
  944. package/dist/types/components/ic-data-row/ic-data-row.d.ts +17 -11
  945. package/dist/types/components/ic-dialog/ic-dialog.d.ts +123 -0
  946. package/dist/types/components/ic-footer/ic-footer.d.ts +20 -20
  947. package/dist/types/components/ic-footer/ic-footer.types.d.ts +1 -1
  948. package/dist/types/components/ic-footer-link/ic-footer-link.d.ts +26 -6
  949. package/dist/types/components/ic-footer-link-group/ic-footer-link-group.d.ts +8 -8
  950. package/dist/types/components/ic-hero/ic-hero.d.ts +24 -24
  951. package/dist/types/components/ic-hero/ic-hero.types.d.ts +1 -1
  952. package/dist/types/components/ic-horizontal-scroll/ic-horizontal-scroll.d.ts +40 -0
  953. package/dist/types/components/ic-input-component-container/ic-input-component-container.d.ts +15 -15
  954. package/dist/types/components/ic-input-label/ic-input-label.d.ts +14 -14
  955. package/dist/types/components/ic-input-validation/ic-input-validation.d.ts +8 -8
  956. package/dist/types/components/ic-input-validation/ic-input-validation.types.d.ts +1 -1
  957. package/dist/types/components/ic-link/ic-link.d.ts +9 -9
  958. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.d.ts +38 -37
  959. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.types.d.ts +2 -2
  960. package/dist/types/components/ic-menu/ic-menu.d.ts +89 -50
  961. package/dist/types/components/ic-menu-group/ic-menu-group.d.ts +8 -0
  962. package/dist/types/components/ic-menu-item/ic-menu-item.d.ts +74 -0
  963. package/dist/types/components/ic-menu-item/ic-menu-item.types.d.ts +1 -0
  964. package/dist/types/components/ic-navigation-button/ic-navigation-button.d.ts +21 -21
  965. package/dist/types/components/ic-navigation-button/ic-navigation-button.types.d.ts +1 -1
  966. package/dist/types/components/ic-navigation-group/ic-navigation-group.d.ts +21 -18
  967. package/dist/types/components/ic-navigation-item/ic-navigation-item.d.ts +47 -27
  968. package/dist/types/components/ic-navigation-menu/ic-navigation-menu.d.ts +14 -14
  969. package/dist/types/components/ic-page-header/ic-page-header.d.ts +19 -19
  970. package/dist/types/components/ic-pagination/ic-pagination.d.ts +82 -0
  971. package/dist/types/components/ic-pagination/ic-pagination.types.d.ts +4 -0
  972. package/dist/types/components/ic-pagination-item/ic-pagination-item.d.ts +47 -0
  973. package/dist/types/components/ic-pagination-item/ic-pagination-item.types.d.ts +1 -0
  974. package/dist/types/components/ic-popover-menu/ic-popover-menu.d.ts +59 -0
  975. package/dist/types/components/ic-radio-group/ic-radio-group.d.ts +22 -23
  976. package/dist/types/components/ic-radio-group/ic-radio-group.types.d.ts +7 -0
  977. package/dist/types/components/ic-radio-option/ic-radio-option.d.ts +32 -29
  978. package/dist/types/components/ic-search-bar/ic-search-bar.d.ts +120 -86
  979. package/dist/types/components/ic-search-bar/ic-search-bar.types.d.ts +2 -1
  980. package/dist/types/components/ic-select/ic-select.d.ts +117 -73
  981. package/dist/types/components/ic-side-navigation/ic-side-navigation.d.ts +30 -24
  982. package/dist/types/components/ic-side-navigation/{ic-side-navigation-test-examples.d.ts → test/basic/ic-side-navigation-test-examples.d.ts} +1 -0
  983. package/dist/types/components/ic-skeleton/ic-skeleton.d.ts +8 -8
  984. package/dist/types/components/ic-skeleton/ic-skeleton.types.d.ts +1 -1
  985. package/dist/types/components/ic-status-tag/ic-status-tag.d.ts +8 -8
  986. package/dist/types/components/ic-status-tag/ic-status-tag.types.d.ts +2 -2
  987. package/dist/types/components/ic-step/ic-step.d.ts +24 -24
  988. package/dist/types/components/ic-step/ic-step.types.d.ts +3 -3
  989. package/dist/types/components/ic-stepper/ic-stepper.d.ts +17 -17
  990. package/dist/types/components/ic-stepper/ic-stepper.types.d.ts +1 -1
  991. package/dist/types/components/ic-switch/ic-switch.d.ts +23 -23
  992. package/dist/types/components/ic-tab/ic-tab.d.ts +25 -8
  993. package/dist/types/components/ic-tab-context/ic-tab-context.d.ts +29 -20
  994. package/dist/types/components/ic-tab-group/ic-tab-group.d.ts +6 -33
  995. package/dist/types/components/ic-tab-panel/ic-tab-panel.d.ts +27 -7
  996. package/dist/types/components/ic-text-field/ic-text-field.d.ts +110 -91
  997. package/dist/types/components/ic-text-field/ic-text-field.types.d.ts +3 -3
  998. package/dist/types/components/ic-text-field/test/a11y/ic-text-field.test.a11y.d.ts +1 -0
  999. package/dist/types/components/ic-theme/ic-theme.d.ts +1 -1
  1000. package/dist/types/components/ic-toast/ic-toast.d.ts +66 -0
  1001. package/dist/types/components/ic-toast/ic-toast.types.d.ts +1 -0
  1002. package/dist/types/components/ic-toast/test/a11y/ic-toast.test.a11y.d.ts +1 -0
  1003. package/dist/types/components/ic-toast-region/ic-toast-region.d.ts +12 -0
  1004. package/dist/types/components/ic-tooltip/ic-tooltip.d.ts +22 -15
  1005. package/dist/types/components/ic-tooltip/ic-tooltip.types.d.ts +1 -1
  1006. package/dist/types/components/ic-tooltip/test/a11y/ic-tooltip.test.a11y.d.ts +1 -0
  1007. package/dist/types/components/ic-top-navigation/ic-top-navigation.d.ts +36 -32
  1008. package/dist/types/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.d.ts +1 -0
  1009. package/dist/types/components/ic-typography/ic-typography.d.ts +31 -4
  1010. package/dist/types/components/ic-typography/test/a11y/ic-typography.test.a11y.d.ts +1 -0
  1011. package/dist/types/components.d.ts +954 -37
  1012. package/dist/types/interface.d.ts +0 -1
  1013. package/dist/types/stencil-public-runtime.d.ts +74 -15
  1014. package/dist/types/testspec.setup.d.ts +11 -0
  1015. package/dist/types/utils/constants.d.ts +22 -0
  1016. package/dist/types/utils/helpers.d.ts +2 -0
  1017. package/dist/types/utils/types.d.ts +25 -20
  1018. package/hydrate/index.d.ts +17 -16
  1019. package/hydrate/index.js +4258 -2050
  1020. package/loader/index.d.ts +9 -0
  1021. package/package.json +9 -7
  1022. package/dist/cjs/chevron-icon-2645d6b0.js +0 -10
  1023. package/dist/cjs/chevron-icon-2645d6b0.js.map +0 -1
  1024. package/dist/cjs/error-icon-9af90abc.js +0 -20
  1025. package/dist/cjs/error-icon-9af90abc.js.map +0 -1
  1026. package/dist/cjs/helpers-5f391578.js.map +0 -1
  1027. package/dist/cjs/index-3ef30d9d.js.map +0 -1
  1028. package/dist/cjs/popper-11d5f714.js.map +0 -1
  1029. package/dist/cjs/success-icon-c8fec63d.js +0 -12
  1030. package/dist/cjs/success-icon-c8fec63d.js.map +0 -1
  1031. package/dist/collection/components/ic-alert/ic-alert.test.a11y.js.map +0 -1
  1032. package/dist/collection/components/ic-alert/ic-alert.types.js +0 -2
  1033. package/dist/collection/components/ic-alert/ic-alert.types.js.map +0 -1
  1034. package/dist/collection/components/ic-back-to-top/ic-back-to-top.test.a11y.js.map +0 -1
  1035. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group-test-examples.js.map +0 -1
  1036. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.test.a11y.js.map +0 -1
  1037. package/dist/collection/components/ic-button/ic-button.test.a11y.js.map +0 -1
  1038. package/dist/collection/components/ic-card/ic-card.test.a11y.js.map +0 -1
  1039. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.test.a11y.js.map +0 -1
  1040. package/dist/collection/components/ic-chip/ic-chip.test.a11y.js.map +0 -1
  1041. package/dist/collection/components/ic-classification-banner/ic-classification-banner.test.a11y.js.map +0 -1
  1042. package/dist/collection/components/ic-data-entity/ic-data-entity.test.a11y.js.map +0 -1
  1043. package/dist/collection/components/ic-data-row/ic-data-row.test.a11y.js.map +0 -1
  1044. package/dist/collection/components/ic-footer/ic-footer.test.a11y.js.map +0 -1
  1045. package/dist/collection/components/ic-footer-link/ic-footer-link.test.a11y.js.map +0 -1
  1046. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.test.a11y.js.map +0 -1
  1047. package/dist/collection/components/ic-hero/ic-hero.test.a11y.js.map +0 -1
  1048. package/dist/collection/components/ic-link/ic-link.test.a11y.js.map +0 -1
  1049. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.test.a11y.js.map +0 -1
  1050. package/dist/collection/components/ic-navigation-group/ic-navigation-group.test.a11y.js.map +0 -1
  1051. package/dist/collection/components/ic-navigation-item/ic-navigation-item.test.a11y.js.map +0 -1
  1052. package/dist/collection/components/ic-page-header/ic-page-header.test.a11y.js.map +0 -1
  1053. package/dist/collection/components/ic-radio-group/ic-radio-group.test.a11y.js.map +0 -1
  1054. package/dist/collection/components/ic-search-bar/ic-search-bar.test.a11y.js.map +0 -1
  1055. package/dist/collection/components/ic-select/ic-select.test.a11y.js.map +0 -1
  1056. package/dist/collection/components/ic-side-navigation/ic-side-navigation-test-examples.js.map +0 -1
  1057. package/dist/collection/components/ic-side-navigation/ic-side-navigation.test.a11y.js.map +0 -1
  1058. package/dist/collection/components/ic-skeleton/ic-skeleton.test.a11y.js.map +0 -1
  1059. package/dist/collection/components/ic-status-tag/ic-status-tag.test.a11y.js.map +0 -1
  1060. package/dist/collection/components/ic-stepper/ic-stepper-test-examples.js.map +0 -1
  1061. package/dist/collection/components/ic-stepper/ic-stepper.test.a11y.js.map +0 -1
  1062. package/dist/collection/components/ic-switch/ic-switch.test.a11y.js.map +0 -1
  1063. package/dist/collection/components/ic-tab-context/ic-tab-context.test.a11y.js.map +0 -1
  1064. package/dist/collection/components/ic-tab-group/assets/left-arrow.svg +0 -3
  1065. package/dist/collection/components/ic-tab-group/assets/right-arrow.svg +0 -3
  1066. package/dist/collection/components/ic-text-field/ic-text-field.test.a11y.js.map +0 -1
  1067. package/dist/collection/components/ic-tooltip/ic-tooltip.test.a11y.js.map +0 -1
  1068. package/dist/collection/components/ic-top-navigation/ic-top-navigation.test.a11y.js.map +0 -1
  1069. package/dist/collection/components/ic-typography/ic-typography.test.a11y.js.map +0 -1
  1070. package/dist/components/error-icon.js +0 -17
  1071. package/dist/components/error-icon.js.map +0 -1
  1072. package/dist/components/popper.js.map +0 -1
  1073. package/dist/components/success-icon.js +0 -10
  1074. package/dist/components/success-icon.js.map +0 -1
  1075. package/dist/core/p-01ebd24d.entry.js +0 -2
  1076. package/dist/core/p-01ebd24d.entry.js.map +0 -1
  1077. package/dist/core/p-02a6562c.entry.js +0 -2
  1078. package/dist/core/p-02a6562c.entry.js.map +0 -1
  1079. package/dist/core/p-03a4d9dc.entry.js +0 -2
  1080. package/dist/core/p-03a4d9dc.entry.js.map +0 -1
  1081. package/dist/core/p-04cf6fab.entry.js +0 -2
  1082. package/dist/core/p-04cf6fab.entry.js.map +0 -1
  1083. package/dist/core/p-0672c783.entry.js.map +0 -1
  1084. package/dist/core/p-0f773f37.entry.js.map +0 -1
  1085. package/dist/core/p-0fc9d5c8.entry.js +0 -2
  1086. package/dist/core/p-0fc9d5c8.entry.js.map +0 -1
  1087. package/dist/core/p-10a672d4.entry.js +0 -2
  1088. package/dist/core/p-10a672d4.entry.js.map +0 -1
  1089. package/dist/core/p-24240e11.js.map +0 -1
  1090. package/dist/core/p-26fd7d7c.entry.js +0 -2
  1091. package/dist/core/p-26fd7d7c.entry.js.map +0 -1
  1092. package/dist/core/p-2961c45f.entry.js +0 -2
  1093. package/dist/core/p-2961c45f.entry.js.map +0 -1
  1094. package/dist/core/p-2a40f189.entry.js +0 -2
  1095. package/dist/core/p-2a40f189.entry.js.map +0 -1
  1096. package/dist/core/p-2e318c95.entry.js +0 -2
  1097. package/dist/core/p-2e318c95.entry.js.map +0 -1
  1098. package/dist/core/p-2ed06031.entry.js +0 -2
  1099. package/dist/core/p-2ed06031.entry.js.map +0 -1
  1100. package/dist/core/p-30ff49be.entry.js +0 -2
  1101. package/dist/core/p-30ff49be.entry.js.map +0 -1
  1102. package/dist/core/p-3c75ed36.js +0 -2
  1103. package/dist/core/p-3c75ed36.js.map +0 -1
  1104. package/dist/core/p-3f0232f6.entry.js +0 -2
  1105. package/dist/core/p-3f0232f6.entry.js.map +0 -1
  1106. package/dist/core/p-3f0ac826.entry.js +0 -2
  1107. package/dist/core/p-3f0ac826.entry.js.map +0 -1
  1108. package/dist/core/p-454a7f3d.entry.js +0 -2
  1109. package/dist/core/p-454a7f3d.entry.js.map +0 -1
  1110. package/dist/core/p-48f99591.entry.js +0 -2
  1111. package/dist/core/p-48f99591.entry.js.map +0 -1
  1112. package/dist/core/p-4a8c0c58.entry.js +0 -2
  1113. package/dist/core/p-4a8c0c58.entry.js.map +0 -1
  1114. package/dist/core/p-5368bcff.entry.js +0 -2
  1115. package/dist/core/p-5368bcff.entry.js.map +0 -1
  1116. package/dist/core/p-662d5b43.entry.js +0 -2
  1117. package/dist/core/p-662d5b43.entry.js.map +0 -1
  1118. package/dist/core/p-69512d85.entry.js +0 -2
  1119. package/dist/core/p-69512d85.entry.js.map +0 -1
  1120. package/dist/core/p-6bbc0cf5.entry.js +0 -2
  1121. package/dist/core/p-6bbc0cf5.entry.js.map +0 -1
  1122. package/dist/core/p-6be5e06b.entry.js.map +0 -1
  1123. package/dist/core/p-6d0eaaeb.entry.js +0 -2
  1124. package/dist/core/p-6d0eaaeb.entry.js.map +0 -1
  1125. package/dist/core/p-86098b7e.entry.js +0 -2
  1126. package/dist/core/p-86098b7e.entry.js.map +0 -1
  1127. package/dist/core/p-8b383c23.entry.js +0 -2
  1128. package/dist/core/p-8b383c23.entry.js.map +0 -1
  1129. package/dist/core/p-97d4b6cd.entry.js.map +0 -1
  1130. package/dist/core/p-9e684c58.entry.js +0 -2
  1131. package/dist/core/p-9e684c58.entry.js.map +0 -1
  1132. package/dist/core/p-a2d3e955.entry.js.map +0 -1
  1133. package/dist/core/p-a472db51.entry.js +0 -2
  1134. package/dist/core/p-a472db51.entry.js.map +0 -1
  1135. package/dist/core/p-a6a77e5c.js +0 -2
  1136. package/dist/core/p-a6a77e5c.js.map +0 -1
  1137. package/dist/core/p-add01f10.entry.js +0 -2
  1138. package/dist/core/p-add01f10.entry.js.map +0 -1
  1139. package/dist/core/p-b29f210b.entry.js +0 -2
  1140. package/dist/core/p-b29f210b.entry.js.map +0 -1
  1141. package/dist/core/p-c2710b13.entry.js.map +0 -1
  1142. package/dist/core/p-c6764827.entry.js +0 -2
  1143. package/dist/core/p-c6764827.entry.js.map +0 -1
  1144. package/dist/core/p-ccd078a6.entry.js.map +0 -1
  1145. package/dist/core/p-d4f7a3e4.entry.js +0 -2
  1146. package/dist/core/p-d4f7a3e4.entry.js.map +0 -1
  1147. package/dist/core/p-d5e0c02a.js +0 -2
  1148. package/dist/core/p-d5e0c02a.js.map +0 -1
  1149. package/dist/core/p-d77f57d9.entry.js +0 -2
  1150. package/dist/core/p-d77f57d9.entry.js.map +0 -1
  1151. package/dist/core/p-dd194ba9.entry.js.map +0 -1
  1152. package/dist/core/p-de19fed4.entry.js +0 -2
  1153. package/dist/core/p-de19fed4.entry.js.map +0 -1
  1154. package/dist/core/p-e5e885b1.entry.js +0 -2
  1155. package/dist/core/p-e5e885b1.entry.js.map +0 -1
  1156. package/dist/core/p-e94dfa43.entry.js +0 -2
  1157. package/dist/core/p-e94dfa43.entry.js.map +0 -1
  1158. package/dist/core/p-eaf714a3.entry.js.map +0 -1
  1159. package/dist/core/p-ec26fc38.js +0 -2
  1160. package/dist/core/p-ec26fc38.js.map +0 -1
  1161. package/dist/core/p-f51f4d34.entry.js +0 -2
  1162. package/dist/core/p-f51f4d34.entry.js.map +0 -1
  1163. package/dist/core/p-f9370be6.js +0 -3
  1164. package/dist/core/p-f9370be6.js.map +0 -1
  1165. package/dist/esm/chevron-icon-98c98242.js +0 -8
  1166. package/dist/esm/chevron-icon-98c98242.js.map +0 -1
  1167. package/dist/esm/error-icon-1dc70ca0.js +0 -17
  1168. package/dist/esm/error-icon-1dc70ca0.js.map +0 -1
  1169. package/dist/esm/helpers-3aa2f5a5.js.map +0 -1
  1170. package/dist/esm/index-1500de1f.js.map +0 -1
  1171. package/dist/esm/popper-f860750c.js +0 -1801
  1172. package/dist/esm/popper-f860750c.js.map +0 -1
  1173. package/dist/esm/success-icon-75b04341.js +0 -10
  1174. package/dist/esm/success-icon-75b04341.js.map +0 -1
  1175. package/dist/types/components/ic-alert/ic-alert.types.d.ts +0 -1
  1176. /package/dist/collection/{components/ic-link/assets → assets}/OpenInNew.svg +0 -0
  1177. /package/dist/collection/components/ic-back-to-top/{ic-back-to-top.test.a11y.js → test/a11y/ic-back-to-top.test.a11y.js} +0 -0
  1178. /package/dist/collection/components/ic-breadcrumb-group/{ic-breadcrumb-group-test-examples.js → test/basic/ic-breadcrumb-group-test-examples.js} +0 -0
  1179. /package/dist/collection/components/ic-stepper/{ic-stepper-test-examples.js → test/basic/ic-stepper-test-examples.js} +0 -0
  1180. /package/dist/collection/components/ic-tab-context/{ic-tab-context.test.a11y.js → test/a11y/ic-tab-context.test.a11y.js} +0 -0
  1181. /package/dist/collection/components/ic-text-field/{ic-text-field.test.a11y.js → test/a11y/ic-text-field.test.a11y.js} +0 -0
  1182. /package/dist/types/components/ic-alert/{ic-alert.test.a11y.d.ts → test/a11y/ic-alert.test.a11y.d.ts} +0 -0
  1183. /package/dist/types/components/ic-back-to-top/{ic-back-to-top.test.a11y.d.ts → test/a11y/ic-back-to-top.test.a11y.d.ts} +0 -0
  1184. /package/dist/types/components/ic-breadcrumb-group/{ic-breadcrumb-group.test.a11y.d.ts → test/a11y/ic-breadcrumb-group.test.a11y.d.ts} +0 -0
  1185. /package/dist/types/components/ic-breadcrumb-group/{ic-breadcrumb-group-test-examples.d.ts → test/basic/ic-breadcrumb-group-test-examples.d.ts} +0 -0
  1186. /package/dist/types/components/ic-button/{ic-button.test.a11y.d.ts → test/a11y/ic-button.test.a11y.d.ts} +0 -0
  1187. /package/dist/types/components/ic-card/{ic-card.test.a11y.d.ts → test/a11y/ic-card.test.a11y.d.ts} +0 -0
  1188. /package/dist/types/components/ic-checkbox-group/{ic-checkbox-group.test.a11y.d.ts → test/a11y/ic-checkbox-group.test.a11y.d.ts} +0 -0
  1189. /package/dist/types/components/ic-chip/{ic-chip.test.a11y.d.ts → test/a11y/ic-chip.test.a11y.d.ts} +0 -0
  1190. /package/dist/types/components/ic-classification-banner/{ic-classification-banner.test.a11y.d.ts → test/a11y/ic-classification-banner.test.a11y.d.ts} +0 -0
  1191. /package/dist/types/components/ic-data-entity/{ic-data-entity.test.a11y.d.ts → test/a11y/ic-data-entity.test.a11y.d.ts} +0 -0
  1192. /package/dist/types/components/ic-data-row/{ic-data-row.test.a11y.d.ts → test/a11y/ic-data-row.test.a11y.d.ts} +0 -0
  1193. /package/dist/types/components/{ic-footer-link-group/ic-footer-link-group.test.a11y.d.ts → ic-dialog/test/a11y/ic-dialog.test.a11y.d.ts} +0 -0
  1194. /package/dist/types/components/{ic-hero/ic-hero.test.a11y.d.ts → ic-footer/test/a11y/ic-footer.test.a11y.d.ts} +0 -0
  1195. /package/dist/types/components/{ic-footer/ic-footer.test.a11y.d.ts → ic-footer-link/test/a11y/ic-footer-link.test.a11y.d.ts} +0 -0
  1196. /package/dist/types/components/{ic-footer-link/ic-footer-link.test.a11y.d.ts → ic-footer-link-group/test/a11y/ic-footer-link-group.test.a11y.d.ts} +0 -0
  1197. /package/dist/types/components/{ic-link/ic-link.test.a11y.d.ts → ic-hero/test/a11y/ic-hero.test.a11y.d.ts} +0 -0
  1198. /package/dist/types/components/{ic-loading-indicator/ic-loading-indicator.test.a11y.d.ts → ic-horizontal-scroll/test/a11y/ic-horizontal-scroll.test.a11y.d.ts} +0 -0
  1199. /package/dist/types/components/{ic-navigation-group/ic-navigation-group.test.a11y.d.ts → ic-link/test/a11y/ic-link.test.a11y.d.ts} +0 -0
  1200. /package/dist/types/components/{ic-navigation-item/ic-navigation-item.test.a11y.d.ts → ic-loading-indicator/test/a11y/ic-loading-indicator.test.a11y.d.ts} +0 -0
  1201. /package/dist/types/components/{ic-page-header/ic-page-header.test.a11y.d.ts → ic-navigation-group/test/a11y/ic-navigation-group.test.a11y.d.ts} +0 -0
  1202. /package/dist/types/components/{ic-radio-group/ic-radio-group.test.a11y.d.ts → ic-navigation-item/test/a11y/ic-navigation-item.test.a11y.d.ts} +0 -0
  1203. /package/dist/types/components/{ic-search-bar/ic-search-bar.test.a11y.d.ts → ic-page-header/test/a11y/ic-page-header.test.a11y.d.ts} +0 -0
  1204. /package/dist/types/components/{ic-select/ic-select.test.a11y.d.ts → ic-pagination/test/a11y/ic-pagination.test.a11y.d.ts} +0 -0
  1205. /package/dist/types/components/{ic-side-navigation/ic-side-navigation.test.a11y.d.ts → ic-popover-menu/test/a11y/ic-popover-menu.test.a11y.d.ts} +0 -0
  1206. /package/dist/types/components/{ic-skeleton/ic-skeleton.test.a11y.d.ts → ic-radio-group/test/a11y/ic-radio-group.test.a11y.d.ts} +0 -0
  1207. /package/dist/types/components/{ic-status-tag/ic-status-tag.test.a11y.d.ts → ic-search-bar/test/a11y/ic-search-bar.test.a11y.d.ts} +0 -0
  1208. /package/dist/types/components/{ic-stepper/ic-stepper.test.a11y.d.ts → ic-select/test/a11y/ic-select.test.a11y.d.ts} +0 -0
  1209. /package/dist/types/components/{ic-switch/ic-switch.test.a11y.d.ts → ic-side-navigation/test/a11y/ic-side-navigation.test.a11y.d.ts} +0 -0
  1210. /package/dist/types/components/{ic-tab-context/ic-tab-context.test.a11y.d.ts → ic-skeleton/test/a11y/ic-skeleton.test.a11y.d.ts} +0 -0
  1211. /package/dist/types/components/{ic-text-field/ic-text-field.test.a11y.d.ts → ic-status-tag/test/a11y/ic-status-tag.test.a11y.d.ts} +0 -0
  1212. /package/dist/types/components/{ic-tooltip/ic-tooltip.test.a11y.d.ts → ic-stepper/test/a11y/ic-stepper.test.a11y.d.ts} +0 -0
  1213. /package/dist/types/components/ic-stepper/{ic-stepper-test-examples.d.ts → test/basic/ic-stepper-test-examples.d.ts} +0 -0
  1214. /package/dist/types/components/{ic-top-navigation/ic-top-navigation.test.a11y.d.ts → ic-switch/test/a11y/ic-switch.test.a11y.d.ts} +0 -0
  1215. /package/dist/types/components/{ic-typography/ic-typography.test.a11y.d.ts → ic-tab-context/test/a11y/ic-tab-context.test.a11y.d.ts} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icSelectCss","inputIds","Select","this","hasSetDefaultValue","inheritedAttributes","initialOptionsEmpty","inputId","menuId","searchableMenuItemSelected","ungroupedOptions","handleRetry","ev","detail","keyPressed","_a","searchableSelectElement","focus","blurredBecauseButtonPressed","retryButtonClick","icRetryLoad","emit","value","hiddenInputValue","emitIcChange","searchable","clearTimeout","debounceIcChange","window","setTimeout","icChange","currDebounce","emitImmediateIcChange","setOptionsValuesFromLabels","options","length","map","option","label","setUngroupedOptions","event","setTextColor","nativeSelectElement","selectedIndex","className","setMenuChange","open","getLabelFromValue","getFilteredChildMenuOptions","children","getFilteredMenuOptions","includeDescriptionsInSearch","searchableSelectInputValue","searchMatchPosition","pressedCharacters","newOption","Object","assign","handleNativeSelectChange","icOptionSelect","handleCustomSelectChange","emptyOptionListText","currValue","inputValueToFilter","getValueFromLabel","ariaActiveDescendant","optionId","handleMenuChange","handleFocusIndicatorDisplay","handleMenuKeyPress","cancelBubble","handleCharacterKeyDown","key","handleMenuValueChange","focusIndicator","host","shadowRoot","querySelector","classList","add","remove","handleMouseDown","preventDefault","isExternalFiltering","disableFilter","handleClick","menu","filteredOptions","hasTimedOut","loading","noOptions","handleClickOpen","handleExpandIconMouseDown","disabled","handleClear","stopPropagation","timeoutTimer","icClear","customSelectElement","characterKeyPressTimer","handleFilter","handleNativeSelectKeyDown","handleKeyDown","isArrowKey","handleKeyboardOpen","handleClearButtonFocus","clearButtonFocused","handleClearButtonBlur","retryButton","relatedTarget","isGrouped","newFilteredOptions","menuOptionsFiltered","includeGroupTitlesInSearch","indexOf","push","noChildOptionsWhenFiltered","triggerLoading","loadingLabel","timeout","loadingErrorLabel","timedOut","find","handleSearchableSelectInput","target","icInput","debounceAriaLiveUpdate","updateSearchableSelectResultAriaLive","searchableSelectResultsStatusEl","innerText","getDefaultValue","onFocus","icFocus","onBlur","tagName","includes","isSearchableAndNoFocusedInternalElements","Array","from","querySelectorAll","clearButton","icBlur","onTimeoutBlur","handleFormReset","initialValue","debounce","loadingHandler","newValue","watchOptionsHandler","setDefaultValue","debounceChangedHandler","updateOnChangeDebounce","valueChangedHandler","disconnectedCallback","removeFormResetListener","componentWillLoad","inheritAttributes","IC_INHERITED_ARIA","removeDisabledFalse","addFormResetListener","componentDidLoad","onComponentRequiredPropUndefined","prop","propName","componentDidRender","async","debounceAria","render","small","fullWidth","helperText","hideLabel","name","placeholder","readonly","required","showClearButton","validationStatus","validationText","noOptionSelect","inputValue","renderHiddenInput","invalid","IcInformationStatus","Error","describedBy","getInputDescribedByText","hasValidationStatus","trim","h","Host","class","for","ref","el","anchorEl","isMobileOrTablet","onChange","id","onKeyDown","selected","role","autocomplete","onInput","onClick","innerHTML","Clear","size","variant","appearance","IcThemeForegroundEnum","Light","Dark","onMouseDown","Expand","undefined","inputEl","inputLabel","onMenuStateChange","onMenuOptionSelect","onMenuKeyPress","onMenuValueChange","onUngroupedOptionsSet","onRetryButtonClicked","parentEl","activationType","ariaLiveMode","status","message"],"sources":["./src/components/ic-select/ic-select.css?tag=ic-select&encapsulation=shadow","./src/components/ic-select/ic-select.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n/**\n * @prop --input-width: Width of the input field\n * @prop --ic-z-index-menu: z-index of select menu\n */\n\n:host {\n position: relative;\n}\n\n:host(.full-width) {\n width: 100%;\n}\n\nic-input-component-container:hover {\n --border-color: var(--ic-action-dark-hover);\n}\n\nic-input-component-container:active {\n --border-color: var(--ic-action-dark-active);\n\n color: var(--ic-action-dark-active);\n}\n\nic-input-component-container.menu-open {\n --border-color: var(--ic-architectural-400);\n\n color: var(--ic-action-dark);\n}\n\nic-input-validation .status-icon,\nic-input-validation .statustext {\n visibility: visible;\n}\n\nic-input-validation.menu-open .status-icon,\nic-input-validation.menu-open .statustext {\n visibility: hidden;\n transition: visibility 0s;\n}\n\nic-input-label {\n margin-bottom: var(--ic-space-xs) !important;\n}\n\nselect {\n border: 0;\n border-radius: var(--ic-border-radius);\n background-color: var(--ic-architectural-white);\n color: var(--ic-color-primary-text);\n line-height: 1.5rem;\n letter-spacing: 0.005rem;\n width: 100%;\n height: 100%;\n padding-left: 0.375rem;\n appearance: none;\n background-repeat: no-repeat;\n background-position: right 0.375rem center;\n background-image: url(\"data:image/svg+xml;utf8,<svg fill='black' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/><path d='M0 0h24v24H0z' fill='none'/></svg>\");\n}\n\nselect option,\n.select-option-selected {\n color: var(--ic-color-primary-text);\n}\n\nselect:disabled {\n color: var(--ic-architectural-200);\n background-image: url(\"data:image/svg+xml;utf8,<svg fill='grey' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/><path d='M0 0h24v24H0z' fill='none'/></svg>\");\n}\n\nselect:focus {\n border: 0;\n outline: 0;\n}\n\nselect:not([disabled]) {\n cursor: pointer;\n}\n\n.select-container {\n width: 100%;\n display: flex;\n align-items: center;\n position: relative;\n}\n\n.select-input {\n width: 100%;\n height: 100%;\n padding: 0 0.375rem;\n display: flex;\n cursor: pointer;\n align-items: center;\n justify-content: space-between;\n background: none;\n border: none;\n}\n\n.select-input:focus {\n outline: var(--ic-hc-focus-outline);\n}\n\n:host(:not(.disabled)) ic-input-component-container:hover .select-input {\n background-color: var(--ic-architectural-white);\n}\n\n.select-input[disabled] {\n pointer-events: none;\n}\n\n:host(.searchable) .select-input {\n cursor: auto;\n}\n\n.searchable-select-container {\n align-items: center;\n display: flex;\n width: 100%;\n position: relative;\n}\n\n.expand-icon {\n height: var(--ic-space-lg);\n padding-left: var(--ic-space-xs);\n color: var(--ic-action-dark);\n}\n\n.expand-icon > svg {\n display: inline-block;\n width: var(--ic-space-lg);\n height: var(--ic-space-lg);\n}\n\n:host(.disabled) .expand-icon,\n:host(.disabled) .expand-icon > svg > path {\n color: var(--ic-architectural-200);\n}\n\n:host(.searchable) .expand-icon {\n padding-left: var(--ic-space-xxs);\n height: 2.25rem;\n}\n\n:host(.searchable) .expand-icon > svg {\n height: 2.25rem;\n padding: 0 0.375rem;\n}\n\n:host(.searchable:not(.disabled)) .expand-icon > svg {\n cursor: pointer;\n}\n\n.expand-icon-open {\n color: var(--ic-action-dark);\n}\n\n.expand-icon-filled {\n color: var(--ic-action-dark);\n}\n\n.expand-icon-open,\n:host(.searchable) .expand-icon-open {\n transform: rotateX(180deg);\n}\n\n:host(.disabled) .value-text,\n.placeholder {\n color: var(--ic-color-tertiary-text);\n}\n\n.select-input-end {\n display: flex;\n align-items: center;\n}\n\n.clear-button-container {\n display: flex;\n gap: var(--ic-space-xxs);\n padding-left: 2.375rem;\n}\n\n:host(.small) .clear-button-container {\n padding-left: 1.875rem;\n}\n\n.divider {\n width: var(--ic-space-1px);\n background-color: var(--ic-architectural-400);\n margin: var(--ic-space-xxs) 0;\n border-radius: var(--ic-space-1px);\n height: var(--ic-space-lg);\n}\n\n:host(.small) .divider {\n height: var(--ic-space-md);\n}\n\n.clear-button {\n position: absolute;\n right: 2.75rem;\n border-radius: var(--ic-border-radius);\n transition: box-shadow var(--ic-easing-transition),\n border-radius var(--ic-easing-transition);\n}\n\n.clear-button:focus {\n background-color: var(--ic-focus-blue);\n box-shadow: inset 0 0 0 0.125rem var(--ic-focus-glow);\n border-radius: 0.25rem;\n}\n\n.clear-button:focus * {\n fill: white;\n}\n\n.searchable-select-results-status {\n border: 0;\n clip: rect(0, 0, 0, 0, 0);\n height: var(--ic-space-1px);\n overflow: hidden;\n padding: 0;\n position: absolute;\n white-space: nowrap;\n width: var(--ic-space-1px);\n}\n","import {\n Component,\n Element,\n Event,\n EventEmitter,\n Host,\n Method,\n Prop,\n h,\n State,\n Watch,\n} from \"@stencil/core\";\n\nimport {\n getInputDescribedByText,\n getLabelFromValue,\n hasValidationStatus,\n inheritAttributes,\n onComponentRequiredPropUndefined,\n renderHiddenInput,\n isMobileOrTablet,\n getFilteredMenuOptions,\n addFormResetListener,\n removeFormResetListener,\n removeDisabledFalse,\n} from \"../../utils/helpers\";\nimport { IC_INHERITED_ARIA } from \"../../utils/constants\";\nimport {\n IcInformationStatus,\n IcInformationStatusOrEmpty,\n IcThemeForegroundEnum,\n IcMenuOption,\n IcSearchMatchPositions,\n IcValueEventDetail,\n} from \"../../utils/types\";\nimport Expand from \"./assets/Expand.svg\";\nimport Clear from \"./assets/Clear.svg\";\nimport { IcOptionSelectEventDetail } from \"../ic-menu/ic-menu.types\";\n\nlet inputIds = 0;\n\n@Component({\n tag: \"ic-select\",\n styleUrl: \"ic-select.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport class Select {\n private anchorEl: HTMLElement;\n private blurredBecauseButtonPressed: boolean;\n private characterKeyPressTimer: number;\n private clearButton: HTMLIcButtonElement;\n private customSelectElement: HTMLButtonElement;\n private debounceAria: number;\n private hasSetDefaultValue = false;\n private hasTimedOut: boolean;\n private inheritedAttributes: { [k: string]: unknown } = {};\n private initialOptionsEmpty = false;\n private inputId = `ic-select-input-${inputIds++}`;\n private menu: HTMLIcMenuElement;\n private menuId = `${this.inputId}-menu`;\n private nativeSelectElement: HTMLSelectElement;\n private retryButtonClick: boolean;\n private searchableMenuItemSelected: boolean = false;\n private searchableSelectElement: HTMLInputElement;\n private timeoutTimer: number;\n private ungroupedOptions: IcMenuOption[] = [];\n\n @Element() host!: HTMLIcSelectElement;\n\n @State() ariaActiveDescendant: string;\n @State() clearButtonFocused: boolean = false;\n @State() debounceIcChange: number;\n @State() hiddenInputValue: string;\n @State() noOptions: IcMenuOption[] = null;\n @State() open: boolean = false;\n @State() pressedCharacters: string = \"\";\n @State() searchableSelectInputValue: string = null;\n\n /**\n * @deprecated This prop should not be used anymore.\n */\n @Prop() charactersUntilSuggestions?: number = 0;\n\n /**\n * If `true`, the disabled state will be set.\n */\n @Prop({ reflect: true }) disabled?: boolean = false;\n\n /**\n * If `true`, the built in filtering will be disabled for a searchable variant. For example, if options will already be filtered from external source.\n */\n @Prop() disableFilter?: boolean = false;\n\n /**\n * The text displayed when there are no options in the option list.\n */\n @Prop() emptyOptionListText = \"No results found\";\n\n /**\n * If `true`, the select element will fill the width of the container.\n */\n @Prop() fullWidth: boolean = false;\n\n /**\n * The helper text that will be displayed for additional field guidance.\n */\n @Prop() helperText?: string = \"\";\n\n /**\n * If `true`, the label will be hidden and the required label value will be applied as an aria-label.\n */\n @Prop() hideLabel?: boolean = false;\n\n /**\n * If `true`, descriptions of options will be included when filtering options in a searchable select. Only applies to built in filtering.\n */\n @Prop() includeDescriptionsInSearch?: boolean = false;\n\n /**\n * If `true`, group titles of grouped options will be included when filtering options in a searchable select. Only applies to built in filtering.\n */\n @Prop() includeGroupTitlesInSearch?: boolean = false;\n\n /**\n * The label for the select.\n */\n @Prop() label!: string;\n\n /**\n * The message displayed when external loading times out.\n */\n @Prop() loadingErrorLabel?: string = \"Loading Error\";\n\n /**\n * The message displayed whilst the options are being loaded externally.\n */\n @Prop() loadingLabel?: string = \"Loading...\";\n\n /**\n * The name of the control, which is submitted with the form data.\n */\n @Prop() name?: string = this.inputId;\n\n /**\n * The placeholder value to be displayed.\n */\n @Prop() placeholder?: string = \"Select an option\";\n\n /**\n * If `true`, the readonly state will be set.\n */\n @Prop() readonly?: boolean = false;\n\n /**\n * If `true`, the select will require a value.\n */\n @Prop() required?: boolean = false;\n\n /**\n * If `true`, a searchable variant of the select will be displayed which can be typed in to filter options.\n */\n @Prop() searchable?: boolean = false;\n\n /**\n * Whether the search string of the searchable select should match the start of or anywhere in the options. Only applies to built in filtering.\n */\n @Prop() searchMatchPosition?: IcSearchMatchPositions = \"anywhere\";\n\n /**\n * If `true`, a button which clears the select input when clicked will be displayed. The button will always appear on the searchable select.\n */\n @Prop() showClearButton?: boolean = false;\n\n /**\n * If `true`, the small styling will be applied to the select.\n */\n @Prop() small?: boolean = false;\n\n /**\n * If using external filtering, set a timeout for when loading takes too long.\n */\n @Prop() timeout?: number;\n\n /**\n * The validation status - e.g. 'error' | 'warning' | 'success'.\n */\n @Prop() validationStatus?: IcInformationStatusOrEmpty = \"\";\n\n /**\n * The text to display as the validation message.\n */\n @Prop() validationText?: string = \"\";\n\n /**\n * If `true`, the loading state will be triggered when fetching options asyncronously.\n */\n @Prop({ mutable: true }) loading?: boolean = false;\n\n @Watch(\"loading\")\n loadingHandler(newValue: boolean): void {\n newValue && this.triggerLoading();\n }\n\n /**\n * The possible selection options.\n */\n @Prop() options?: IcMenuOption[] = [];\n @State() filteredOptions: IcMenuOption[] = this.options;\n\n @Watch(\"options\")\n watchOptionsHandler(): void {\n if (!this.hasTimedOut) {\n this.loading = false;\n clearTimeout(this.timeoutTimer);\n if (this.isExternalFiltering()) {\n if (this.options.length > 0) {\n this.setOptionsValuesFromLabels();\n this.noOptions = null;\n this.filteredOptions = this.options;\n } else {\n this.noOptions = [{ label: this.emptyOptionListText, value: \"\" }];\n this.filteredOptions = this.noOptions;\n }\n this.updateSearchableSelectResultAriaLive();\n this.setDefaultValue();\n } else {\n this.setOptionsValuesFromLabels();\n this.filteredOptions = this.options;\n\n if (this.initialOptionsEmpty) {\n this.setDefaultValue();\n this.initialOptionsEmpty = false;\n }\n }\n } else {\n if (!this.searchable) this.options = this.noOptions;\n }\n }\n\n /**\n * The amount of time, in milliseconds, to wait to trigger the `icChange` event after each keystroke.\n */\n @Prop() debounce?: number = 0;\n @State() currDebounce = this.debounce;\n\n @Watch(\"debounce\")\n debounceChangedHandler(newValue: number): void {\n this.updateOnChangeDebounce(newValue);\n }\n\n /**\n * The value of the select, reflected by the value of the currently selected option. For the searchable variant, the value is also reflected by the user input.\n */\n @Prop({ mutable: true }) value?: string;\n @State() initialValue = this.value;\n @State() inputValueToFilter = this.value;\n @State() currValue = this.value;\n\n @Watch(\"value\")\n valueChangedHandler(): void {\n if (this.value !== this.currValue) {\n this.currValue = this.value;\n }\n\n if (this.searchable) {\n this.searchableSelectInputValue =\n this.getLabelFromValue(this.currValue) || this.currValue;\n }\n }\n\n /**\n * Emitted when the select loses focus.\n */\n @Event() icBlur!: EventEmitter<void>;\n\n /**\n * Emitted when the value changes.\n */\n @Event() icChange!: EventEmitter<IcValueEventDetail>;\n\n /**\n * Emitted when the clear button is clicked.\n */\n @Event() icClear!: EventEmitter<void>;\n\n /**\n * Emitted when the select gains focus.\n */\n @Event() icFocus!: EventEmitter<void>;\n\n /**\n * Emitted when a keyboard input occurred.\n */\n @Event() icInput: EventEmitter<IcValueEventDetail>;\n\n /**\n * Emitted when an option is highlighted within the menu.\n * Highlighting a menu item will also trigger an `icChange/onIcChange` due to the value being updated.\n */\n @Event() icOptionSelect: EventEmitter<IcOptionSelectEventDetail>;\n\n /**\n * Emitted when the 'retry loading' button is clicked for a searchable variant.\n */\n @Event() icRetryLoad: EventEmitter<IcValueEventDetail>;\n\n disconnectedCallback(): void {\n removeFormResetListener(this.host, this.handleFormReset);\n }\n\n componentWillLoad(): void {\n this.inheritedAttributes = inheritAttributes(this.host, [\n ...IC_INHERITED_ARIA,\n \"tabindex\",\n \"title\",\n ]);\n\n removeDisabledFalse(this.disabled, this.host);\n\n this.setOptionsValuesFromLabels();\n\n addFormResetListener(this.host, this.handleFormReset);\n\n if (!this.options.length) {\n this.initialOptionsEmpty = true;\n } else {\n this.setDefaultValue();\n }\n }\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.label, propName: \"label\" }],\n \"Select\"\n );\n\n if (this.loading) this.triggerLoading();\n\n this.hiddenInputValue = this.searchable && this.currValue;\n }\n\n componentDidRender(): void {\n if (this.nativeSelectElement && !this.disabled) {\n this.setTextColor();\n }\n }\n\n /**\n * Sets focus on the input box.\n */\n @Method()\n async setFocus(): Promise<void> {\n if (this.nativeSelectElement) {\n this.nativeSelectElement.focus();\n } else if (this.customSelectElement) {\n this.customSelectElement.focus();\n } else if (this.searchableSelectElement) {\n this.searchableSelectElement.focus();\n }\n }\n\n private handleRetry = (ev: CustomEvent<IcValueEventDetail>) => {\n if (ev.detail.keyPressed) this.searchableSelectElement?.focus();\n this.blurredBecauseButtonPressed = true;\n this.retryButtonClick = true;\n this.hasSetDefaultValue = true;\n this.icRetryLoad.emit({ value: this.hiddenInputValue });\n };\n\n private updateOnChangeDebounce(newValue: number) {\n if (this.currDebounce !== newValue) {\n this.currDebounce = newValue;\n }\n }\n\n private emitIcChange = (value: string) => {\n if (!this.searchable) {\n this.value = value;\n }\n\n clearTimeout(this.debounceIcChange);\n this.debounceIcChange = window.setTimeout(() => {\n this.icChange.emit({ value: value });\n }, this.currDebounce);\n };\n\n private emitImmediateIcChange = (value: string) => {\n this.value = value;\n clearTimeout(this.debounceIcChange);\n this.icChange.emit({ value: value });\n };\n\n private setOptionsValuesFromLabels = (): void => {\n if (this.options.length > 0 && this.options.map) {\n this.options.map((option) => {\n if (!option.value) {\n option.value = option.label;\n }\n });\n }\n };\n\n private setUngroupedOptions = (event: CustomEvent): void => {\n this.ungroupedOptions = event.detail.options;\n };\n\n private setTextColor = (): void => {\n if (this.nativeSelectElement.selectedIndex === 0) {\n this.nativeSelectElement.className = \"placeholder\";\n } else {\n this.nativeSelectElement.className = \"select-option-selected\";\n }\n };\n\n private setMenuChange = (open: boolean) => {\n if (this.open !== open) {\n this.open = open;\n }\n };\n\n private getLabelFromValue = (value: string): string | undefined => {\n return getLabelFromValue(value, this.options);\n };\n\n private getFilteredChildMenuOptions = (option: IcMenuOption) => {\n let children = option.children;\n\n if (this.searchable) {\n children = getFilteredMenuOptions(\n option.children,\n this.includeDescriptionsInSearch,\n this.searchableSelectInputValue,\n this.searchMatchPosition\n );\n } else {\n children = getFilteredMenuOptions(\n option.children,\n false,\n this.pressedCharacters,\n \"start\"\n );\n }\n\n const newOption = { ...option };\n newOption.children = children;\n return newOption;\n };\n\n private handleNativeSelectChange = (): void => {\n this.icOptionSelect.emit({ value: this.nativeSelectElement.value });\n this.emitImmediateIcChange(this.nativeSelectElement.value);\n this.setTextColor();\n };\n\n private handleCustomSelectChange = (event: CustomEvent): void => {\n if (this.searchable && event.detail.label === this.emptyOptionListText) {\n this.searchableSelectElement.focus();\n return;\n }\n\n if (this.searchable) {\n this.value = event.detail.value;\n this.searchableMenuItemSelected = true;\n\n // After editing the input, if selecting the same option as before, set the input value to label again\n if (this.value === this.currValue) {\n this.searchableSelectInputValue = this.getLabelFromValue(this.value);\n }\n\n this.inputValueToFilter = null;\n this.hiddenInputValue = this.getValueFromLabel(\n this.searchableSelectInputValue\n );\n }\n\n this.ariaActiveDescendant = event.detail.optionId;\n this.icOptionSelect.emit({ value: event.detail.value });\n this.emitIcChange(event.detail.value);\n };\n\n private handleMenuChange = (event: CustomEvent): void => {\n this.open = event.detail.open;\n this.pressedCharacters = \"\";\n\n this.searchable && this.handleFocusIndicatorDisplay();\n };\n\n // clears the debounce delay when navigating the menu with arrow keys etc\n // to prevent delay in change event, which should only occur when typing in input\n private handleMenuKeyPress = (ev: CustomEvent): void => {\n ev.cancelBubble = true;\n this.handleCharacterKeyDown(ev.detail.key);\n };\n\n private handleMenuValueChange = (ev: CustomEvent): void => {\n this.value = ev.detail.value;\n };\n\n private handleFocusIndicatorDisplay = () => {\n const focusIndicator =\n this.host.shadowRoot.querySelector(\".focus-indicator\");\n\n if (this.open) {\n focusIndicator.classList.add(\"focus-indicator-enabled\");\n } else {\n focusIndicator.classList.remove(\"focus-indicator-enabled\");\n }\n };\n\n private handleMouseDown = (event: Event): void => {\n if (!this.open) {\n event.preventDefault();\n }\n };\n\n private isExternalFiltering = (): boolean =>\n this.searchable && this.disableFilter;\n\n private handleClick = (event: MouseEvent): void => {\n if (!this.open) {\n if (this.isExternalFiltering()) {\n this.menu.options = this.filteredOptions;\n } else if (\n !this.hasTimedOut &&\n !this.loading &&\n (!this.searchable || this.searchableMenuItemSelected)\n ) {\n this.noOptions = null;\n this.menu.options = this.options;\n }\n }\n\n if (event.detail !== 0) {\n this.menu.handleClickOpen();\n }\n };\n\n private handleExpandIconMouseDown = (event: MouseEvent) => {\n if (!this.disabled) {\n event.preventDefault();\n this.searchableSelectElement.focus();\n this.handleClick(event);\n }\n };\n\n private handleClear = (event: Event): void => {\n event.stopPropagation();\n this.hasTimedOut = false;\n clearTimeout(this.timeoutTimer);\n this.noOptions = null;\n this.emitImmediateIcChange(null);\n this.icClear.emit();\n\n if (this.searchable) {\n this.searchableSelectElement.value = null;\n this.searchableSelectInputValue = null;\n this.filteredOptions = this.options;\n this.hiddenInputValue = null;\n this.searchableSelectElement.focus();\n } else {\n this.customSelectElement.focus();\n }\n };\n\n private handleCharacterKeyDown = (key: string) => {\n // Only close menu when space is pressed if not being used alongside character keys to quickly select options\n if (\n this.open &&\n key === \" \" &&\n this.pressedCharacters.length === 0 &&\n !this.hasTimedOut &&\n !this.loading\n ) {\n this.setMenuChange(false);\n }\n\n if (key.length === 1 && !this.searchable) {\n window.clearTimeout(this.characterKeyPressTimer);\n this.characterKeyPressTimer = window.setTimeout(\n () => (this.pressedCharacters = \"\"),\n 1000\n );\n\n this.pressedCharacters += key;\n this.handleFilter();\n\n if (!this.noOptions) {\n this.emitImmediateIcChange(this.filteredOptions[0].value);\n }\n } else {\n this.pressedCharacters = \"\";\n }\n };\n\n private handleNativeSelectKeyDown = (event: KeyboardEvent) => {\n if ((event.key !== \"Escape\" && event.key !== \"Tab\") || this.open) {\n event.cancelBubble = true;\n }\n this.handleCharacterKeyDown(event.key);\n };\n\n private handleKeyDown = (event: KeyboardEvent): void => {\n if ((event.key !== \"Escape\" && event.key !== \"Tab\") || this.open) {\n event.cancelBubble = true;\n }\n const isArrowKey = event.key === \"ArrowDown\" || event.key === \"ArrowUp\";\n\n if (!this.open) {\n if (this.isExternalFiltering() && (event.key === \"Enter\" || isArrowKey)) {\n this.menu.options = this.filteredOptions;\n } else {\n if (!this.hasTimedOut) {\n this.noOptions = null;\n this.menu.options = this.options;\n }\n }\n }\n\n if (this.open && event.key === \"Enter\") {\n this.setMenuChange(false);\n } else {\n if (!(isArrowKey && this.noOptions !== null)) {\n if (!(event.key === \" \" && this.pressedCharacters.length > 0)) {\n // Keyboard events get passed onto ic-menu\n this.menu.handleKeyboardOpen(event);\n }\n this.handleCharacterKeyDown(event.key);\n }\n }\n };\n\n private handleClearButtonFocus = (): void => {\n this.clearButtonFocused = true;\n };\n\n private handleClearButtonBlur = (ev: FocusEvent): void => {\n const retryButton = this.menu?.querySelector(\"#retry-button\");\n if (\n !(\n this.searchableSelectElement &&\n ev.relatedTarget === this.searchableSelectElement\n ) &&\n !(retryButton && ev.relatedTarget === retryButton)\n ) {\n this.setMenuChange(false);\n this.handleFocusIndicatorDisplay();\n }\n this.clearButtonFocused = false;\n };\n\n private handleFilter = (): void => {\n const options = this.searchable ? [...this.options] : this.ungroupedOptions;\n\n let isGrouped = false;\n let newFilteredOptions: IcMenuOption[] = [];\n\n options.map((option) => {\n if (option.children) isGrouped = true;\n });\n\n let menuOptionsFiltered: IcMenuOption[];\n\n if (this.searchable) {\n menuOptionsFiltered = getFilteredMenuOptions(\n options,\n this.includeDescriptionsInSearch,\n this.inputValueToFilter,\n this.searchMatchPosition\n );\n this.searchableMenuItemSelected = false;\n } else {\n menuOptionsFiltered = getFilteredMenuOptions(\n options,\n false,\n this.pressedCharacters,\n \"start\"\n );\n }\n\n if (!isGrouped) {\n newFilteredOptions = menuOptionsFiltered;\n } else {\n options.map((option) => {\n if (this.includeGroupTitlesInSearch) {\n if (menuOptionsFiltered.indexOf(option) !== -1) {\n newFilteredOptions.push(option);\n } else {\n newFilteredOptions.push(this.getFilteredChildMenuOptions(option));\n }\n } else {\n newFilteredOptions.push(this.getFilteredChildMenuOptions(option));\n }\n });\n }\n\n let noChildOptionsWhenFiltered = false;\n\n if (isGrouped) {\n noChildOptionsWhenFiltered = true;\n newFilteredOptions.map((option) => {\n if (option.children.length > 0) {\n noChildOptionsWhenFiltered = false;\n }\n });\n }\n\n const noOptions = [{ label: this.emptyOptionListText, value: \"\" }];\n\n if (newFilteredOptions.length > 0 && !noChildOptionsWhenFiltered) {\n this.noOptions = null;\n this.filteredOptions = newFilteredOptions;\n } else {\n this.noOptions = noOptions;\n this.filteredOptions = this.noOptions;\n }\n };\n\n private triggerLoading = () => {\n this.hasTimedOut = false;\n this.noOptions = [{ label: this.loadingLabel, value: \"\", loading: true }];\n if (this.filteredOptions !== this.noOptions && this.searchable)\n this.filteredOptions = this.noOptions;\n else if (!this.searchable && this.options !== this.noOptions)\n this.options = this.noOptions;\n if (this.timeout) {\n this.timeoutTimer = window.setTimeout(() => {\n this.loading = false;\n this.hasTimedOut = true;\n this.noOptions = [\n { label: this.loadingErrorLabel, value: \"\", timedOut: true },\n ];\n this.filteredOptions = this.noOptions;\n if (!this.searchable) this.options = this.noOptions;\n }, this.timeout);\n }\n };\n\n private getValueFromLabel = (label: string): string | undefined => {\n return this.options.find((option) => option.label === label)?.value;\n };\n\n private handleSearchableSelectInput = (event: Event): void => {\n this.searchableSelectInputValue = (event.target as HTMLInputElement).value;\n this.icInput.emit({ value: this.searchableSelectInputValue });\n this.emitIcChange(this.searchableSelectInputValue);\n\n this.hiddenInputValue = this.searchableSelectInputValue;\n this.inputValueToFilter = this.searchableSelectInputValue;\n this.setMenuChange(true);\n\n if (!this.disableFilter) {\n this.handleFilter();\n this.debounceAriaLiveUpdate();\n }\n };\n\n private updateSearchableSelectResultAriaLive = (): void => {\n const searchableSelectResultsStatusEl = this.host.shadowRoot.querySelector(\n \".searchable-select-results-status\"\n ) as HTMLDivElement;\n\n if (searchableSelectResultsStatusEl) {\n if (this.noOptions !== null) {\n searchableSelectResultsStatusEl.innerText = this.emptyOptionListText;\n } else {\n searchableSelectResultsStatusEl.innerText = \"\";\n }\n }\n };\n\n private debounceAriaLiveUpdate() {\n clearTimeout(this.debounceAria);\n\n window.setTimeout(() => {\n this.updateSearchableSelectResultAriaLive();\n }, 800);\n }\n\n private getDefaultValue = (value: string): string | null =>\n this.getLabelFromValue(value) || value || null;\n\n private setDefaultValue() {\n if (!this.hasSetDefaultValue && this.currValue) {\n this.searchableSelectInputValue = this.getDefaultValue(this.currValue);\n this.initialValue = this.currValue;\n this.hasSetDefaultValue = true;\n }\n }\n\n private onFocus = (): void => {\n this.icFocus.emit();\n };\n\n private onBlur = (event: FocusEvent): void => {\n const target = event.relatedTarget as HTMLElement;\n if (\n target !== null &&\n target.tagName === \"UL\" &&\n target.className.includes(\"menu\")\n ) {\n return;\n }\n\n const retryButton = this.menu?.querySelector(\"#retry-button\");\n const isSearchableAndNoFocusedInternalElements =\n this.searchable &&\n event.relatedTarget !== this.menu &&\n !Array.from(this.menu.querySelectorAll(\"[role='option']\")).includes(\n event.relatedTarget as Element\n ) &&\n !(this.clearButton && event.relatedTarget === this.clearButton) &&\n !(retryButton && event.relatedTarget === retryButton);\n\n if (isSearchableAndNoFocusedInternalElements) {\n if (!this.retryButtonClick) {\n this.setMenuChange(false);\n }\n this.handleFocusIndicatorDisplay();\n }\n\n this.retryButtonClick = false;\n this.icBlur.emit();\n };\n\n private onTimeoutBlur = (ev: CustomEvent) => {\n if (\n (ev.detail.ev as FocusEvent).relatedTarget !==\n this.searchableSelectElement &&\n !this.blurredBecauseButtonPressed\n ) {\n this.setMenuChange(false);\n this.handleFocusIndicatorDisplay();\n this.icBlur.emit();\n }\n this.blurredBecauseButtonPressed = false;\n };\n\n private handleFormReset = (): void => {\n this.value = this.initialValue;\n if (this.searchable) {\n this.searchableSelectInputValue = this.getDefaultValue(this.value);\n this.hiddenInputValue = this.value;\n }\n };\n\n render() {\n const {\n small,\n disabled,\n fullWidth,\n helperText,\n hideLabel,\n label,\n menuId,\n name,\n options,\n placeholder,\n readonly,\n required,\n searchable,\n showClearButton,\n validationStatus,\n validationText,\n currValue,\n } = this;\n\n const noOptionSelect =\n searchable &&\n (this.loading ||\n this.hasTimedOut ||\n (this.noOptions !== null &&\n this.noOptions[0] &&\n this.noOptions[0].label === this.emptyOptionListText));\n const inputValue = this.searchable ? this.hiddenInputValue : currValue;\n\n renderHiddenInput(true, this.host, name, inputValue, disabled);\n\n const invalid =\n validationStatus === IcInformationStatus.Error ? \"true\" : \"false\";\n\n const describedBy = getInputDescribedByText(\n this.inputId,\n helperText !== \"\",\n hasValidationStatus(this.validationStatus, this.disabled)\n ).trim();\n\n return (\n <Host\n class={{\n disabled: disabled,\n searchable: searchable,\n small: small,\n \"full-width\": fullWidth,\n }}\n onBlur={this.onBlur}\n >\n <ic-input-container readonly={readonly}>\n {!hideLabel && (\n <ic-input-label\n for={this.inputId}\n label={label}\n helperText={helperText}\n required={required}\n disabled={disabled}\n readonly={readonly}\n ></ic-input-label>\n )}\n <ic-input-component-container\n ref={(el) => (this.anchorEl = el)}\n class={{ \"menu-open\": this.open }}\n small={small}\n fullWidth={fullWidth}\n disabled={disabled}\n readonly={readonly}\n validationStatus={validationStatus}\n >\n {readonly ? (\n <ic-typography>\n <p>{this.getLabelFromValue(currValue)}</p>\n </ic-typography>\n ) : isMobileOrTablet() ? (\n <select\n ref={(el) => (this.nativeSelectElement = el)}\n disabled={disabled}\n onChange={this.handleNativeSelectChange}\n required={required}\n id={this.inputId}\n aria-label={label}\n aria-describedby={describedBy}\n aria-invalid={invalid}\n onBlur={this.onBlur}\n onFocus={this.onFocus}\n onKeyDown={this.handleNativeSelectKeyDown}\n {...this.inheritedAttributes}\n >\n <option value=\"\" selected disabled={!showClearButton}>\n {placeholder}\n </option>\n {options.map((option) => {\n if (option.children) {\n return (\n <optgroup label={option.label}>\n {option.children.map((option) => (\n <option\n value={option.value}\n disabled={option.disabled}\n selected={option.value === currValue}\n >\n {option.label}\n </option>\n ))}\n </optgroup>\n );\n } else {\n return (\n <option\n value={option.value}\n disabled={option.disabled}\n selected={option.value === currValue}\n >\n {option.label}\n </option>\n );\n }\n })}\n </select>\n ) : searchable ? (\n <div class=\"searchable-select-container\">\n <input\n class=\"select-input\"\n role=\"combobox\"\n autocomplete=\"off\"\n aria-label={label}\n aria-describedby={describedBy}\n aria-activedescendant={this.ariaActiveDescendant}\n aria-autocomplete=\"list\"\n aria-expanded={this.open ? \"true\" : \"false\"}\n aria-invalid={invalid}\n aria-required={required ? \"true\" : \"false\"}\n aria-controls={menuId}\n ref={(el) => (this.searchableSelectElement = el)}\n id={this.inputId}\n value={this.searchableSelectInputValue}\n placeholder={placeholder}\n disabled={disabled}\n onInput={this.handleSearchableSelectInput}\n onClick={this.handleClick}\n onKeyDown={this.handleKeyDown}\n onFocus={this.onFocus}\n onBlur={this.onBlur}\n ></input>\n {this.searchableSelectInputValue &&\n (showClearButton || searchable) && (\n <div class=\"clear-button-container\">\n <ic-button\n id=\"clear-button\"\n ref={(el) => (this.clearButton = el)}\n aria-label={\n this.searchableSelectInputValue && currValue === null\n ? \"Clear input\"\n : \"Clear selection\"\n }\n class=\"clear-button\"\n innerHTML={Clear}\n onClick={this.handleClear}\n onFocus={this.handleClearButtonFocus}\n onBlur={this.handleClearButtonBlur}\n size={small ? \"small\" : \"default\"}\n variant=\"icon\"\n appearance={\n this.clearButtonFocused\n ? IcThemeForegroundEnum.Light\n : IcThemeForegroundEnum.Dark\n }\n ></ic-button>\n <div class=\"divider\"></div>\n </div>\n )}\n <span\n onMouseDown={this.handleExpandIconMouseDown}\n class={{\n \"expand-icon\": true,\n \"expand-icon-open\": this.open,\n \"expand-icon-filled\": !(\n currValue == null || currValue === \"\"\n ),\n }}\n innerHTML={Expand}\n aria-hidden=\"true\"\n />\n <div\n aria-live=\"polite\"\n role=\"status\"\n class=\"searchable-select-results-status\"\n ></div>\n </div>\n ) : (\n <div class=\"select-container\">\n <button\n class=\"select-input\"\n ref={(el) => (this.customSelectElement = el)}\n id={this.inputId}\n aria-label={`${label}, ${\n this.getLabelFromValue(currValue) || placeholder\n }${required ? \", required\" : \"\"}`}\n aria-describedby={describedBy}\n aria-invalid={invalid}\n aria-haspopup=\"listbox\"\n aria-expanded={this.open ? \"true\" : \"false\"}\n aria-owns={menuId}\n aria-controls={menuId}\n disabled={disabled}\n onBlur={this.onBlur}\n onFocus={this.onFocus}\n onClick={this.handleClick}\n onMouseDown={this.handleMouseDown}\n onKeyDown={this.handleKeyDown}\n >\n <ic-typography\n variant=\"body\"\n class={{\n \"value-text\": true,\n placeholder:\n this.getLabelFromValue(currValue) === undefined,\n }}\n >\n <p>{this.getLabelFromValue(currValue) || placeholder}</p>\n </ic-typography>\n <div class=\"select-input-end\">\n {currValue && showClearButton && (\n <div class=\"divider\"></div>\n )}\n <span\n class={{\n \"expand-icon\": true,\n \"expand-icon-open\": this.open,\n \"expand-icon-filled\": !(\n currValue == null || currValue === \"\"\n ),\n }}\n innerHTML={Expand}\n aria-hidden=\"true\"\n />\n </div>\n </button>\n {currValue && showClearButton && (\n <ic-button\n id=\"clear-button\"\n aria-label=\"Clear selection\"\n class=\"clear-button\"\n innerHTML={Clear}\n onClick={this.handleClear}\n onFocus={this.handleClearButtonFocus}\n onBlur={this.handleClearButtonBlur}\n size={small ? \"small\" : \"default\"}\n variant=\"icon\"\n appearance={\n this.clearButtonFocused\n ? IcThemeForegroundEnum.Light\n : IcThemeForegroundEnum.Dark\n }\n ></ic-button>\n )}\n </div>\n )}\n </ic-input-component-container>\n {!isMobileOrTablet() && (\n <ic-menu\n class={{\n \"no-results\": noOptionSelect,\n }}\n ref={(el) => (this.menu = el)}\n inputEl={\n searchable\n ? this.searchableSelectElement\n : this.customSelectElement\n }\n inputLabel={label}\n anchorEl={this.anchorEl}\n small={small}\n menuId={menuId}\n open={this.open}\n options={searchable ? this.filteredOptions : options}\n value={currValue}\n fullWidth={fullWidth}\n onMenuStateChange={this.handleMenuChange}\n onMenuOptionSelect={this.handleCustomSelectChange}\n onMenuKeyPress={this.handleMenuKeyPress}\n onMenuValueChange={this.handleMenuValueChange}\n onUngroupedOptionsSet={this.setUngroupedOptions}\n onRetryButtonClicked={this.handleRetry}\n parentEl={this.host}\n onTimeoutBlur={this.onTimeoutBlur}\n activationType={this.searchable ? \"manual\" : \"automatic\"}\n ></ic-menu>\n )}\n {hasValidationStatus(this.validationStatus, this.disabled) && (\n <ic-input-validation\n class={{ \"menu-open\": this.open }}\n ariaLiveMode=\"polite\"\n status={validationStatus}\n message={validationText}\n for={this.inputId}\n ></ic-input-validation>\n )}\n </ic-input-container>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{r as e,h as t,H as i,g as o}from"./p-69920d86.js";import{u as n}from"./p-5dd0b02e.js";import{c as s}from"./p-7c0dcd00.js";import"./p-6f57b13c.js";const r='/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0;}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px;}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font-style:inherit;vertical-align:baseline}@media (prefers-reduced-motion: no-preference){:host .opening-from-parent{animation:slide-in var(--ic-transition-duration-slow) ease-in-out}:host .opening-from-child{animation:slide-out var(--ic-transition-duration-slow) ease-in-out}}:host{border-radius:var(--ic-border-radius);color:var(--ic-color-primary-text);background-color:var(--ic-architectural-white);position:relative;z-index:var(--ic-z-index-popover);box-sizing:border-box;box-shadow:var(--ic-elevation-overlay);display:none}.menu{border:var(--ic-border-default);border-radius:var(--ic-border-radius);background-color:var(--ic-architectural-white);visibility:hidden;height:0}.button{text-decoration:none;list-style-type:none}:host(:focus-within){box-shadow:var(--ic-border-focus)}.menu:focus-visible{outline:none}:host(.open){display:block;min-width:calc(20rem - var(--ic-space-xl));width:var(--popover-width, 20rem);max-width:calc(100vw - var(--ic-space-xl))}:host(.open) .menu{visibility:visible;height:-moz-fit-content;height:fit-content;max-height:var(--max-height, -moz-fit-content);max-height:var(--max-height, fit-content);overflow-y:auto;overflow-x:hidden}.parent-label{color:var(--ic-color-tertiary-text);margin:var(--ic-space-xs) var(--ic-space-xs) 0}@keyframes slide-in{from{opacity:0;transform:translateX(10rem)}to{opacity:1;transform:translateX(0)}}@keyframes slide-out{from{opacity:0;transform:translateX(-10rem)}to{opacity:1;transform:translateX(0)}}';const a=class{constructor(t){e(this,t);this.ARIA_LABEL="aria-label";this.popoverMenuEls=[];this.setButtonFocus=()=>{var e;(e=this.popoverMenuEls[this.currentFocus])===null||e===void 0?void 0:e.focus()};this.findAnchorEl=e=>{let t=null;if(e===null||e===undefined){this.submenuId===undefined&&console.error("No anchor specified for popover component")}else{t=document.querySelector(e.indexOf("#")===0?e:"#"+e);if(t===null){console.error(`Popover anchor element '${e}' not found`)}}return t};this.isNotPopoverMenuEl=e=>{const t=e.target;return t.id!==this.anchor&&t.tagName!=="IC-MENU-ITEM"&&t.tagName!=="IC-MENU-GROUP"&&t.tagName!=="IC-POPOVER-MENU"};this.closeMenu=()=>{var e;this.open=false;(e=this.anchorEl)===null||e===void 0?void 0:e.focus()};this.getNextItemToSelect=(e,t)=>{const i=this.popoverMenuEls.length-1;if(e<1){e=0}let o=t?e+1:e-1;if(o<0){o=i}else if(o>i){o=0}return o};this.addMenuItems=e=>{for(let t=0;t<e.length;t++){const i=e[t];if(i.tagName==="IC-MENU-ITEM"){this.popoverMenuEls.push(i)}else if(i.tagName==="IC-MENU-GROUP"){const e=i.shadowRoot.querySelector("ul");const t=n(e);this.addMenuItems(t)}}};this.getMenuAriaLabel=()=>{const e=this.host.getAttribute(this.ARIA_LABEL);if(this.submenuId!==undefined){return`${e}, within nested level ${this.submenuLevel} ${this.parentLabel} submenu,`}else{return e}};this.handleBackButtonClick=()=>{this.parentPopover.openFromChild();this.open=false};this.openingFromChild=false;this.openingFromParent=false;this.anchor=undefined;this.parentLabel=undefined;this.parentPopover=undefined;this.submenuId=undefined;this.submenuLevel=1;this.open=undefined}watchOpenHandler(){if(this.open){if(this.parentPopover!==undefined&&!this.popoverMenuEls.some((e=>e.id))){this.popoverMenuEls.unshift(this.backButton)}this.currentFocus=this.submenuId!==undefined?1:0;setTimeout(this.setButtonFocus,50)}}componentDidLoad(){const e=this.host.shadowRoot.querySelector("ul.button");const t=n(e);if(t!==null){this.addMenuItems(t)}if(this.submenuId===undefined&&this.host.getAttribute(this.ARIA_LABEL)===null){console.error(`No aria-label specified for popover menu component - aria-label required`)}}componentWillRender(){this.anchorEl=this.findAnchorEl(this.anchor)}componentDidRender(){if(this.open){s(this.anchorEl,this.host,{placement:"bottom-start",modifiers:[{name:"offset",options:{offset:[0,4]}}]})}}handleMenuItemClick(e){if(!e.detail.hasSubMenu&&e.detail.label!=="Back"){this.closeMenu()}}handleSubmenuChange(e){const t=e.target;this.open=false;const i=document.querySelector(`ic-popover-menu[submenu-id=${t.submenuTriggerFor}]`);i.parentPopover=this.host;i.anchor=this.anchor;i.ariaLabel=this.host.getAttribute(this.ARIA_LABEL);i.openFromParent();i.submenuLevel=this.submenuLevel+1;i.parentLabel=t.label}handleClick(e){if(this.open&&this.isNotPopoverMenuEl(e)){this.closeMenu()}}handleKeyDown(e){switch(e.key){case"ArrowDown":e.preventDefault();this.currentFocus=this.getNextItemToSelect(this.currentFocus,true);this.setButtonFocus();break;case"ArrowUp":e.preventDefault();this.currentFocus=this.getNextItemToSelect(this.currentFocus,false);this.setButtonFocus();break;case"Home":this.currentFocus=0;this.setButtonFocus();break;case"End":this.currentFocus=this.popoverMenuEls.length-1;this.setButtonFocus();break;case"Escape":case"Tab":if(this.open){this.closeMenu();this.host.blur()}break}}async openFromChild(){this.open=true;this.openingFromChild=true;setTimeout((()=>this.openingFromChild=false),1e3)}async openFromParent(){this.open=true;this.openingFromParent=true;setTimeout((()=>this.openingFromParent=false),1e3)}render(){return t(i,{class:{open:this.open}},t("div",{id:this.parentPopover===undefined?`ic-popover-submenu-${this.submenuId}`:"",class:{menu:true},tabindex:open?"0":"-1"},t("div",{class:{"opening-from-parent":this.openingFromParent,"opening-from-child":this.openingFromChild}},this.submenuId!==undefined&&t("div",null,t("ic-menu-item",{class:"ic-popover-submenu-back-button",ref:e=>this.backButton=e,label:"Back",onClick:this.handleBackButtonClick,id:`ic-popover-submenu-back-button-${this.submenuLevel}`},t("svg",{slot:"icon",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg",class:"submenu-back-icon"},t("path",{d:"M20 11H7.83L13.42 5.41L12 4L4 12L12 20L13.41 18.59L7.83 13H20V11Z",fill:"currentColor"}))),t("ic-typography",{variant:"subtitle-small",class:"parent-label"},this.parentLabel)),t("ul",{class:"button","aria-label":this.getMenuAriaLabel(),role:"menu","aria-owns":this.submenuId!==undefined?`ic-popover-submenu-back-button-${this.submenuLevel}`:false,"aria-controls":this.submenuId!==undefined?`ic-popover-submenu-back-button-${this.submenuLevel}`:false},t("slot",null)))))}static get delegatesFocus(){return true}get host(){return o(this)}static get watchers(){return{open:["watchOpenHandler"]}}};a.style=r;export{a as ic_popover_menu};
2
+ //# sourceMappingURL=p-03d1a4a1.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icPopoverMenuCss","PopoverMenu","this","ARIA_LABEL","popoverMenuEls","setButtonFocus","_a","currentFocus","focus","findAnchorEl","anchor","anchorElement","undefined","submenuId","console","error","document","querySelector","indexOf","isNotPopoverMenuEl","ev","target","id","tagName","closeMenu","open","anchorEl","getNextItemToSelect","currentItem","movingDown","numButtons","length","nextItem","addMenuItems","elements","i","el","push","groupSlotWrapper","shadowRoot","menuGroupElements","getSlotElements","getMenuAriaLabel","ariaLabel","host","getAttribute","submenuLevel","parentLabel","handleBackButtonClick","parentPopover","openFromChild","watchOpenHandler","some","menuItem","unshift","backButton","setTimeout","componentDidLoad","slotWrapper","popoverMenuElements","componentWillRender","componentDidRender","createPopper","placement","modifiers","name","options","offset","handleMenuItemClick","detail","hasSubMenu","label","handleSubmenuChange","childEl","submenuTriggerFor","openFromParent","handleClick","handleKeyDown","key","preventDefault","blur","async","openingFromChild","openingFromParent","render","h","Host","class","menu","tabindex","ref","onClick","slot","viewBox","fill","xmlns","d","variant","role"],"sources":["./src/components/ic-popover-menu/ic-popover-menu.css?tag=ic-popover-menu&encapsulation=shadow","./src/components/ic-popover-menu/ic-popover-menu.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n/**\n* @prop --ic-z-index-popover: z-index of popover menu. \n* @prop --max-height: Maximum height of the popover menu.\n* @prop --popover-width: Default width of the popover menu.\n*/\n\n@media (prefers-reduced-motion: no-preference) {\n :host .opening-from-parent {\n animation: slide-in var(--ic-transition-duration-slow) ease-in-out;\n }\n\n :host .opening-from-child {\n animation: slide-out var(--ic-transition-duration-slow) ease-in-out;\n }\n}\n\n:host {\n border-radius: var(--ic-border-radius);\n color: var(--ic-color-primary-text);\n background-color: var(--ic-architectural-white);\n position: relative;\n z-index: var(--ic-z-index-popover);\n box-sizing: border-box;\n box-shadow: var(--ic-elevation-overlay);\n display: none;\n}\n\n.menu {\n border: var(--ic-border-default);\n border-radius: var(--ic-border-radius);\n background-color: var(--ic-architectural-white);\n visibility: hidden;\n height: 0;\n}\n\n.button {\n text-decoration: none;\n list-style-type: none;\n}\n\n:host(:focus-within) {\n box-shadow: var(--ic-border-focus);\n}\n\n.menu:focus-visible {\n outline: none;\n}\n\n:host(.open) {\n display: block;\n min-width: calc(20rem - var(--ic-space-xl));\n width: var(--popover-width, 20rem);\n max-width: calc(100vw - var(--ic-space-xl));\n}\n\n:host(.open) .menu {\n visibility: visible;\n height: fit-content;\n max-height: var(--max-height, fit-content);\n overflow-y: auto;\n overflow-x: hidden;\n}\n\n.parent-label {\n color: var(--ic-color-tertiary-text);\n margin: var(--ic-space-xs) var(--ic-space-xs) 0;\n}\n\n@keyframes slide-in {\n from {\n opacity: 0;\n transform: translateX(10rem);\n }\n\n to {\n opacity: 1;\n transform: translateX(0);\n }\n}\n\n@keyframes slide-out {\n from {\n opacity: 0;\n transform: translateX(-10rem);\n }\n\n to {\n opacity: 1;\n transform: translateX(0);\n }\n}\n","import {\n Component,\n Element,\n Host,\n h,\n Prop,\n Listen,\n Watch,\n State,\n Method,\n} from \"@stencil/core\";\nimport { getSlotElements } from \"../../utils/helpers\";\nimport { createPopper } from \"@popperjs/core\";\n\n@Component({\n tag: \"ic-popover-menu\",\n styleUrl: \"ic-popover-menu.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class PopoverMenu {\n private anchorEl: HTMLElement;\n private ARIA_LABEL: string = \"aria-label\";\n private backButton: HTMLIcMenuItemElement;\n private currentFocus: number;\n private popoverMenuEls: HTMLIcMenuItemElement[] = [];\n\n @Element() host: HTMLIcPopoverMenuElement;\n\n @State() openingFromChild: boolean = false;\n @State() openingFromParent: boolean = false;\n\n /**\n * The ID of the element the popover menu will anchor itself to. This is required unless the popover is a submenu.\n */\n @Prop() anchor: string;\n\n /**\n * @internal The parent popover menu of a child popover menu.\n */\n @Prop() parentLabel?: string;\n\n /**\n * @internal The parent popover menu of a child popover menu.\n */\n @Prop() parentPopover?: HTMLIcPopoverMenuElement;\n\n /**\n * The unique identifier for a popover submenu.\n */\n @Prop() submenuId?: string;\n\n /**\n * @internal The level of menu being displayed.\n */\n @Prop() submenuLevel: number = 1;\n\n /**\n * If `true`, the popover menu will be displayed.\n */\n @Prop({ reflect: true, mutable: true }) open: boolean = undefined;\n\n @Watch(\"open\")\n watchOpenHandler(): void {\n if (this.open) {\n if (\n this.parentPopover !== undefined &&\n !this.popoverMenuEls.some((menuItem) => menuItem.id)\n ) {\n this.popoverMenuEls.unshift(this.backButton);\n }\n\n this.currentFocus = this.submenuId !== undefined ? 1 : 0;\n // Needed so that anchorEl isn't always focused\n setTimeout(this.setButtonFocus, 50);\n }\n }\n\n componentDidLoad(): void {\n const slotWrapper = this.host.shadowRoot.querySelector(\"ul.button\");\n const popoverMenuElements = getSlotElements(slotWrapper);\n\n if (popoverMenuElements !== null) {\n this.addMenuItems(popoverMenuElements);\n }\n\n if (\n this.submenuId === undefined &&\n this.host.getAttribute(this.ARIA_LABEL) === null\n ) {\n console.error(\n `No aria-label specified for popover menu component - aria-label required`\n );\n }\n }\n\n componentWillRender(): void {\n this.anchorEl = this.findAnchorEl(this.anchor);\n }\n\n componentDidRender(): void {\n if (this.open) {\n createPopper(this.anchorEl, this.host, {\n placement: \"bottom-start\",\n modifiers: [\n {\n name: \"offset\",\n options: {\n offset: [0, 4],\n },\n },\n ],\n });\n }\n }\n\n @Listen(\"handleMenuItemClick\")\n handleMenuItemClick(ev: CustomEvent): void {\n if (!ev.detail.hasSubMenu && ev.detail.label !== \"Back\") {\n this.closeMenu();\n }\n }\n\n // This is listening for the event emitted when a menu item is acting as a trigger button\n @Listen(\"triggerPopoverMenuInstance\", { capture: true })\n handleSubmenuChange(ev: Event): void {\n // Finds the trigger menu item that has emitted the event\n const target = ev.target as HTMLIcMenuItemElement;\n this.open = false;\n\n // Find the popover menu that the menu item triggers (i.e. submenu-trigger-for === submenu-id).\n const childEl = document.querySelector(\n `ic-popover-menu[submenu-id=${target.submenuTriggerFor}]`\n ) as HTMLIcPopoverMenuElement;\n // Set the parent popover menu of the submenu and open the submenu\n childEl.parentPopover = this.host;\n childEl.anchor = this.anchor;\n childEl.ariaLabel = this.host.getAttribute(this.ARIA_LABEL);\n childEl.openFromParent();\n childEl.submenuLevel = this.submenuLevel + 1;\n // Set the label in the submenu using the label of the menu item that has emitted the event\n childEl.parentLabel = target.label;\n }\n\n @Listen(\"click\", { target: \"document\" })\n handleClick(ev: Event): void {\n if (this.open && this.isNotPopoverMenuEl(ev)) {\n // If menu is open and the next click on the document is not a popover El, close the popover\n this.closeMenu();\n }\n }\n\n // Manages the keyboard navigation in the popover menu\n @Listen(\"keydown\", { target: \"document\" })\n handleKeyDown(ev: KeyboardEvent): void {\n switch (ev.key) {\n case \"ArrowDown\":\n ev.preventDefault();\n this.currentFocus = this.getNextItemToSelect(this.currentFocus, true);\n this.setButtonFocus();\n break;\n case \"ArrowUp\":\n ev.preventDefault();\n this.currentFocus = this.getNextItemToSelect(this.currentFocus, false);\n this.setButtonFocus();\n break;\n case \"Home\":\n //Sets home focus as first element, or back button\n this.currentFocus = 0;\n this.setButtonFocus();\n break;\n case \"End\":\n //Sets end focus as last element\n this.currentFocus = this.popoverMenuEls.length - 1;\n this.setButtonFocus();\n break;\n case \"Escape\":\n case \"Tab\":\n if (this.open) {\n this.closeMenu();\n this.host.blur();\n }\n break;\n }\n }\n\n /**\n * @internal Opens the menu from the child menu.\n */\n @Method()\n async openFromChild(): Promise<void> {\n this.open = true;\n this.openingFromChild = true;\n\n setTimeout(() => (this.openingFromChild = false), 1000);\n }\n\n /**\n * @internal Opens the menu from the parent menu.\n */\n @Method()\n async openFromParent(): Promise<void> {\n this.open = true;\n this.openingFromParent = true;\n\n setTimeout(() => (this.openingFromParent = false), 1000);\n }\n\n private setButtonFocus = () => {\n this.popoverMenuEls[this.currentFocus]?.focus();\n };\n\n // Checks that the popover menu has an anchor\n private findAnchorEl = (anchor: string): HTMLElement => {\n let anchorElement: HTMLElement = null;\n if (anchor === null || anchor === undefined) {\n this.submenuId === undefined &&\n console.error(\"No anchor specified for popover component\");\n } else {\n anchorElement = document.querySelector(\n anchor.indexOf(\"#\") === 0 ? anchor : \"#\" + anchor\n );\n if (anchorElement === null) {\n console.error(`Popover anchor element '${anchor}' not found`);\n }\n }\n return anchorElement;\n };\n\n private isNotPopoverMenuEl = (ev: Event) => {\n const target = ev.target as HTMLElement;\n return (\n target.id !== this.anchor &&\n target.tagName !== \"IC-MENU-ITEM\" &&\n target.tagName !== \"IC-MENU-GROUP\" &&\n target.tagName !== \"IC-POPOVER-MENU\"\n );\n };\n\n private closeMenu = () => {\n this.open = false;\n this.anchorEl?.focus();\n };\n\n private getNextItemToSelect = (\n currentItem: number,\n movingDown: boolean\n ): number => {\n const numButtons = this.popoverMenuEls.length - 1;\n\n if (currentItem < 1) {\n currentItem = 0;\n }\n\n let nextItem = movingDown ? currentItem + 1 : currentItem - 1;\n\n // Check if wrap around necessary\n if (nextItem < 0) {\n nextItem = numButtons;\n } else if (nextItem > numButtons) {\n nextItem = 0;\n }\n\n return nextItem;\n };\n\n private addMenuItems = (elements: Element[] | NodeListOf<ChildNode>) => {\n for (let i = 0; i < elements.length; i++) {\n const el = elements[i] as HTMLIcMenuItemElement;\n if (el.tagName === \"IC-MENU-ITEM\") {\n this.popoverMenuEls.push(el);\n } else if (el.tagName === \"IC-MENU-GROUP\") {\n const groupSlotWrapper = el.shadowRoot.querySelector(\"ul\");\n const menuGroupElements = getSlotElements(groupSlotWrapper);\n\n this.addMenuItems(menuGroupElements);\n }\n }\n };\n\n private getMenuAriaLabel = (): string => {\n const ariaLabel = this.host.getAttribute(this.ARIA_LABEL);\n\n if (this.submenuId !== undefined) {\n return `${ariaLabel}, within nested level ${this.submenuLevel} ${this.parentLabel} submenu,`;\n } else {\n return ariaLabel;\n }\n };\n\n private handleBackButtonClick = (): void => {\n this.parentPopover.openFromChild();\n this.open = false;\n };\n\n render() {\n return (\n <Host class={{ open: this.open }}>\n <div\n id={\n this.parentPopover === undefined\n ? `ic-popover-submenu-${this.submenuId}`\n : \"\"\n }\n class={{\n menu: true,\n }}\n tabindex={open ? \"0\" : \"-1\"}\n >\n <div\n class={{\n \"opening-from-parent\": this.openingFromParent,\n \"opening-from-child\": this.openingFromChild,\n }}\n >\n {this.submenuId !== undefined && (\n <div>\n <ic-menu-item\n class=\"ic-popover-submenu-back-button\"\n ref={(el) => (this.backButton = el)}\n label=\"Back\"\n onClick={this.handleBackButtonClick}\n id={`ic-popover-submenu-back-button-${this.submenuLevel}`}\n >\n <svg\n slot=\"icon\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n class=\"submenu-back-icon\"\n >\n <path\n d=\"M20 11H7.83L13.42 5.41L12 4L4 12L12 20L13.41 18.59L7.83 13H20V11Z\"\n fill=\"currentColor\"\n />\n </svg>\n </ic-menu-item>\n <ic-typography variant=\"subtitle-small\" class=\"parent-label\">\n {this.parentLabel}\n </ic-typography>\n </div>\n )}\n <ul\n class=\"button\"\n aria-label={this.getMenuAriaLabel()}\n role=\"menu\"\n aria-owns={\n this.submenuId !== undefined\n ? `ic-popover-submenu-back-button-${this.submenuLevel}`\n : false\n }\n aria-controls={\n this.submenuId !== undefined\n ? `ic-popover-submenu-back-button-${this.submenuLevel}`\n : false\n }\n >\n <slot></slot>\n </ul>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{r as t,c as s,h as i,g as h}from"./p-69920d86.js";import{I as e}from"./p-6f57b13c.js";const a=class{constructor(i){t(this,i);this.icTabSelect=s(this,"icTabSelect",3);this.tabSelect=s(this,"tabSelect",3);this.newTabPanels=[];this.newTabs=[];this.linkTabs=()=>{this.tabs.forEach(((t,s)=>{const i=`ic-tab-${s}-context-${this.contextId}`;const h=`ic-tab-panel-${s}-context-${this.contextId}`;const a=`ic-tab--${s}-context-${this.contextId}`;const c="context-id";t.setAttribute("id",i);t.tabId=a;t.tabPosition=s;t.setAttribute("aria-controls",h);t.setAttribute(c,this.contextId);this.tabGroup.setAttribute(c,this.contextId);this.tabPanels[s].setAttribute("id",h);this.tabPanels[s].panelId=a;this.tabPanels[s].tabPosition=s;this.tabPanels[s].setAttribute("aria-labelledby",i);this.tabPanels[s].setAttribute(c,this.contextId);if(this.appearance===e.Light){t.appearance=this.appearance;this.tabPanels[s].appearance=this.appearance}}));if(this.appearance===e.Light){this.tabGroup.appearance=this.appearance}};this.getChildren=()=>{this.tabGroup=this.host.querySelector("ic-tab-group");this.tabs=Array.from(this.tabGroup.querySelectorAll("ic-tab"));this.tabPanels=Array.from(this.host.children).filter((t=>t.tagName==="IC-TAB-PANEL"));this.enabledTabs=this.getEnabledTabs()};this.keydownHandler=t=>{if(this.activationType==="automatic"){this.handleKeyBoardNavAutomatic(t)}else{this.handleKeyBoardNavManual(t)}};this.attatchEventListeners=()=>{this.tabGroup.addEventListener("keydown",this.keydownHandler)};this.setControlledMode=()=>{if(this.selectedTabIndex!==undefined){this.controlledMode=true;this.selectedTab=this.selectedTabIndex}};this.setInitialTab=()=>{if(this.controlledMode){this.selectedTab=this.selectedTabIndex;this.focusedTabIndex=this.selectedTabIndex}else{const t=this.tabs.findIndex((t=>t.tabId===this.enabledTabs[0].tabId));this.selectedTab=t;this.focusedTabIndex=t}};this.configureTabs=()=>{this.enabledTabs.forEach((t=>{t.selected=t.tabPosition===this.selectedTab}));this.tabPanels.forEach((t=>{t.selectedTab=this.tabs[this.selectedTab].tabId}))};this.getEnabledTabs=()=>Array.from(this.tabs).filter((t=>!t.disabled));this.getIndexOfEnabledTab=t=>this.enabledTabs.findIndex((s=>s.tabId===this.tabs[t].tabId));this.keyboardSelectTab=t=>{const s=this.tabs.findIndex((s=>s.tabId===this.enabledTabs[t].tabId));this.enabledTabs[t].focus();if(!this.controlledMode){this.selectedTab=s}else{this.icTabSelect.emit({tabIndex:s});this.tabSelect.emit({tabIndex:s})}};this.keyboardFocusTab=t=>{const s=this.tabs.findIndex((s=>s.tabId===this.enabledTabs[t].tabId));this.enabledTabs[t].focus();this.focusedTabIndex=s};this.handleKeyBoardNavAutomatic=t=>{const s=t.key;const i=this.getIndexOfEnabledTab(this.selectedTab);let h=true;switch(s){case"Home":this.keyboardSelectTab(0);break;case"End":this.keyboardSelectTab(this.enabledTabs.length-1);break;case"ArrowRight":if(i<this.enabledTabs.length-1){this.keyboardSelectTab(i+1)}else{this.keyboardSelectTab(0)}break;case"ArrowLeft":if(i>0){this.keyboardSelectTab(i-1)}else{this.keyboardSelectTab(this.enabledTabs.length-1)}break;default:h=false}if(h)t.preventDefault()};this.handleKeyBoardNavManual=t=>{const s=t.key;const i=this.getIndexOfEnabledTab(this.focusedTabIndex);let h=true;switch(s){case"Home":this.keyboardFocusTab(0);break;case"End":this.keyboardFocusTab(this.enabledTabs.length-1);break;case"ArrowRight":if(i<this.enabledTabs.length-1){this.keyboardFocusTab(i+1)}else{this.keyboardFocusTab(0)}break;case"ArrowLeft":if(i>0){this.keyboardFocusTab(i-1)}else{this.keyboardFocusTab(this.enabledTabs.length-1)}break;case"Enter":this.keyboardSelectTab(this.focusedTabIndex);break;case" ":this.keyboardSelectTab(this.focusedTabIndex);break;default:h=false}if(h)t.preventDefault()};this.selectedTab=undefined;this.activationType="automatic";this.appearance="dark";this.contextId="default";this.selectedTabIndex=undefined}updateSelectedTab(t){this.selectedTab=t}componentDidLoad(){this.setControlledMode();this.getChildren();this.linkTabs();this.attatchEventListeners();this.setInitialTab();this.configureTabs()}componentWillUpdate(){this.configureTabs()}disconnectedCallback(){this.tabGroup.removeEventListener("keydown",this.keydownHandler)}tabClickHandler(t){if(this.selectedTabIndex===undefined&&t.detail.contextId===this.contextId){this.selectedTab=t.detail.position}this.icTabSelect.emit({tabIndex:t.detail.position});this.tabSelect.emit({tabIndex:t.detail.position});t.stopImmediatePropagation()}tabCreatedHandler(t){if(this.tabs&&this.tabPanels){(t.detail.setFocus?this.newTabs:this.newTabPanels).push(t.detail);if(this.newTabs.length===this.newTabPanels.length){this.tabs.push(...this.newTabs);this.tabPanels.push(...this.newTabPanels);this.enabledTabs=this.getEnabledTabs();this.linkTabs();this.newTabs=[];this.newTabPanels=[]}}}tabEnabledHandler(){this.enabledTabs=this.getEnabledTabs()}async tabRemovedHandler(t){this.getChildren();this.enabledTabs=this.getEnabledTabs();this.linkTabs();if(this.tabs[this.selectedTab]&&this.tabPanels[this.selectedTab]){this.tabs[this.selectedTab].selected=true;this.tabPanels[this.selectedTab].selectedTab=this.tabs[this.selectedTab].tabId}else{this.setInitialTab()}if(t){this.tabs[this.selectedTab].setFocus()}}render(){return i("slot",null)}get host(){return h(this)}static get watchers(){return{selectedTabIndex:["updateSelectedTab"]}}};export{a as ic_tab_context};
2
+ //# sourceMappingURL=p-041604fc.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["TabContext","this","newTabPanels","newTabs","linkTabs","tabs","forEach","tab","index","tabId","contextId","tabPanelId","shared","contextIdAttr","setAttribute","tabPosition","tabGroup","tabPanels","panelId","appearance","IcThemeForegroundEnum","Light","getChildren","host","querySelector","Array","from","querySelectorAll","children","filter","child","tagName","enabledTabs","getEnabledTabs","keydownHandler","event","activationType","handleKeyBoardNavAutomatic","handleKeyBoardNavManual","attatchEventListeners","addEventListener","setControlledMode","selectedTabIndex","undefined","controlledMode","selectedTab","setInitialTab","focusedTabIndex","firstEnabledTabIndex","findIndex","configureTabs","selected","tabPanel","disabled","getIndexOfEnabledTab","allTabsIndex","keyboardSelectTab","enabledTabIndex","newIndex","focus","icTabSelect","emit","tabIndex","tabSelect","keyboardFocusTab","key","preventDefault","length","updateSelectedTab","newValue","componentDidLoad","componentWillUpdate","disconnectedCallback","removeEventListener","tabClickHandler","detail","position","stopImmediatePropagation","tabCreatedHandler","ev","setFocus","push","tabEnabledHandler","async","hadFocus","render","h"],"sources":["./src/components/ic-tab-context/ic-tab-context.tsx"],"sourcesContent":["import {\n Component,\n Element,\n Event,\n EventEmitter,\n Listen,\n Prop,\n State,\n h,\n Watch,\n Method,\n} from \"@stencil/core\";\nimport {\n IcActivationTypes,\n IcThemeForegroundNoDefault,\n IcThemeForegroundEnum,\n} from \"../../utils/types\";\n\nimport {\n IcTabClickEventDetail,\n IcTabSelectEventDetail,\n} from \"../ic-tab/ic-tab.types\";\n\n@Component({\n tag: \"ic-tab-context\",\n})\nexport class TabContext {\n private controlledMode: boolean;\n private enabledTabs: HTMLIcTabElement[];\n private focusedTabIndex: number;\n private newTabPanels: HTMLIcTabPanelElement[] = [];\n private newTabs: HTMLIcTabElement[] = [];\n private tabs: HTMLIcTabElement[];\n private tabGroup: HTMLIcTabGroupElement;\n private tabPanels: HTMLIcTabPanelElement[];\n\n @Element() host: HTMLIcTabContextElement;\n\n @State() selectedTab: number | null;\n\n /**\n * Determines whether tabs have to be manually activated (by pressing 'Enter' or 'Space') when they receive focus using keyboard navigation.\n */\n @Prop() activationType?: IcActivationTypes = \"automatic\";\n\n /**\n * The appearance of the tab context, e.g dark, or light.\n */\n @Prop() appearance?: IcThemeForegroundNoDefault = \"dark\";\n\n /**\n * The unique context needed if using multiple tabs inside one another i.e. rendering another set of tabs inside a tab panel.\n */\n @Prop({ reflect: true }) contextId?: string = \"default\";\n\n /**\n * The selected tab to be controlled by the user. Must be used alongside the icTabSelect event to manage tab selection.\n */\n @Prop() selectedTabIndex?: number;\n\n @Watch(\"selectedTabIndex\")\n updateSelectedTab(newValue: number): void {\n this.selectedTab = newValue;\n }\n\n /**\n * Emitted when a user selects a tab.\n */\n @Event({ bubbles: false }) icTabSelect: EventEmitter<IcTabSelectEventDetail>;\n\n /**\n * @deprecated This event should not be used anymore. Use icTabSelect instead.\n */\n @Event({ bubbles: false }) tabSelect: EventEmitter<IcTabSelectEventDetail>;\n\n componentDidLoad(): void {\n this.setControlledMode();\n this.getChildren();\n this.linkTabs();\n this.attatchEventListeners();\n this.setInitialTab();\n this.configureTabs();\n }\n\n componentWillUpdate(): void {\n this.configureTabs();\n }\n\n disconnectedCallback(): void {\n this.tabGroup.removeEventListener(\"keydown\", this.keydownHandler);\n }\n\n @Listen(\"tabClick\")\n tabClickHandler(event: CustomEvent<IcTabClickEventDetail>): void {\n if (\n this.selectedTabIndex === undefined &&\n event.detail.contextId === this.contextId\n ) {\n this.selectedTab = event.detail.position;\n }\n this.icTabSelect.emit({\n tabIndex: event.detail.position,\n });\n this.tabSelect.emit({\n tabIndex: event.detail.position,\n });\n event.stopImmediatePropagation();\n }\n\n @Listen(\"tabCreated\")\n @Listen(\"tabPanelCreated\")\n tabCreatedHandler(ev: CustomEvent): void {\n if (this.tabs && this.tabPanels) {\n (ev.detail.setFocus ? this.newTabs : this.newTabPanels).push(ev.detail);\n if (this.newTabs.length === this.newTabPanels.length) {\n this.tabs.push(...this.newTabs);\n this.tabPanels.push(...this.newTabPanels);\n this.enabledTabs = this.getEnabledTabs();\n this.linkTabs();\n this.newTabs = [];\n this.newTabPanels = [];\n }\n }\n }\n\n @Listen(\"tabEnabled\")\n tabEnabledHandler(): void {\n this.enabledTabs = this.getEnabledTabs();\n }\n\n /**\n * @internal Used to set tab/tab panel IDs when a tab/tab panel has been removed\n */\n @Method()\n async tabRemovedHandler(hadFocus?: boolean): Promise<void> {\n this.getChildren();\n this.enabledTabs = this.getEnabledTabs();\n this.linkTabs();\n if (this.tabs[this.selectedTab] && this.tabPanels[this.selectedTab]) {\n this.tabs[this.selectedTab].selected = true;\n this.tabPanels[this.selectedTab].selectedTab =\n this.tabs[this.selectedTab].tabId;\n } else {\n this.setInitialTab();\n }\n\n if (hadFocus) {\n this.tabs[this.selectedTab].setFocus();\n }\n }\n\n // Sets attributes to link tab-group, tabs and tab-panels\n private linkTabs = () => {\n this.tabs.forEach((tab, index) => {\n const tabId = `ic-tab-${index}-context-${this.contextId}`;\n const tabPanelId = `ic-tab-panel-${index}-context-${this.contextId}`;\n const shared = `ic-tab--${index}-context-${this.contextId}`;\n const contextIdAttr = \"context-id\";\n tab.setAttribute(\"id\", tabId);\n tab.tabId = shared;\n tab.tabPosition = index;\n tab.setAttribute(\"aria-controls\", tabPanelId);\n tab.setAttribute(contextIdAttr, this.contextId);\n this.tabGroup.setAttribute(contextIdAttr, this.contextId);\n this.tabPanels[index].setAttribute(\"id\", tabPanelId);\n this.tabPanels[index].panelId = shared;\n this.tabPanels[index].tabPosition = index;\n this.tabPanels[index].setAttribute(\"aria-labelledby\", tabId);\n this.tabPanels[index].setAttribute(contextIdAttr, this.contextId);\n\n if (this.appearance === IcThemeForegroundEnum.Light) {\n tab.appearance = this.appearance;\n this.tabPanels[index].appearance = this.appearance;\n }\n });\n\n if (this.appearance === IcThemeForegroundEnum.Light) {\n this.tabGroup.appearance = this.appearance;\n }\n };\n\n // Gets tabs and tabpanels with the same context ID\n // Using querySelector to selector the children in relation to the host\n private getChildren = (): void => {\n this.tabGroup = this.host.querySelector(\"ic-tab-group\");\n this.tabs = Array.from(this.tabGroup.querySelectorAll(\"ic-tab\"));\n this.tabPanels = Array.from(this.host.children).filter(\n (child) => child.tagName === \"IC-TAB-PANEL\"\n ) as HTMLIcTabPanelElement[];\n this.enabledTabs = this.getEnabledTabs();\n };\n\n private keydownHandler = (event: KeyboardEvent) => {\n if (this.activationType === \"automatic\") {\n this.handleKeyBoardNavAutomatic(event);\n } else {\n this.handleKeyBoardNavManual(event);\n }\n };\n\n // Determines how keyboard navigation is to be handled based on the activation type\n private attatchEventListeners = (): void => {\n this.tabGroup.addEventListener(\"keydown\", this.keydownHandler);\n };\n\n // Determines whether the selected tab is being controlled within the component\n // or by the user (via selectedTabIndex and onIcTabSelect)\n private setControlledMode = (): void => {\n if (this.selectedTabIndex !== undefined) {\n this.controlledMode = true;\n this.selectedTab = this.selectedTabIndex;\n }\n };\n\n // Sets the tab that is selected on initial render\n private setInitialTab = (): void => {\n if (this.controlledMode) {\n this.selectedTab = this.selectedTabIndex;\n this.focusedTabIndex = this.selectedTabIndex;\n } else {\n const firstEnabledTabIndex = this.tabs.findIndex(\n (tab) => tab.tabId === this.enabledTabs[0].tabId\n );\n this.selectedTab = firstEnabledTabIndex;\n this.focusedTabIndex = firstEnabledTabIndex;\n }\n };\n\n // Passes the selected tab to the tab and tab panel components\n private configureTabs = () => {\n this.enabledTabs.forEach((tab) => {\n tab.selected = tab.tabPosition === this.selectedTab;\n });\n this.tabPanels.forEach((tabPanel) => {\n tabPanel.selectedTab = this.tabs[this.selectedTab].tabId;\n });\n };\n\n private getEnabledTabs = () => {\n return Array.from(this.tabs).filter((child) => !child.disabled);\n };\n\n private getIndexOfEnabledTab = (allTabsIndex: number) => {\n return this.enabledTabs.findIndex(\n (tab) => tab.tabId === this.tabs[allTabsIndex].tabId\n );\n };\n\n // Sets focus on tab and selects it\n private keyboardSelectTab = (enabledTabIndex: number) => {\n const newIndex = this.tabs.findIndex(\n (tab) => tab.tabId === this.enabledTabs[enabledTabIndex].tabId\n );\n this.enabledTabs[enabledTabIndex].focus();\n if (!this.controlledMode) {\n this.selectedTab = newIndex;\n } else {\n this.icTabSelect.emit({ tabIndex: newIndex });\n this.tabSelect.emit({ tabIndex: newIndex });\n }\n };\n\n // Sets focus on tab without selecting it (for manual activation)\n private keyboardFocusTab = (enabledTabIndex: number) => {\n const newIndex = this.tabs.findIndex(\n (tab) => tab.tabId === this.enabledTabs[enabledTabIndex].tabId\n );\n this.enabledTabs[enabledTabIndex].focus();\n this.focusedTabIndex = newIndex;\n };\n\n private handleKeyBoardNavAutomatic = (event: KeyboardEvent) => {\n const key = event.key;\n const enabledTabIndex = this.getIndexOfEnabledTab(this.selectedTab);\n let preventDefault = true;\n switch (key) {\n case \"Home\":\n this.keyboardSelectTab(0);\n break;\n case \"End\":\n this.keyboardSelectTab(this.enabledTabs.length - 1);\n break;\n case \"ArrowRight\":\n if (enabledTabIndex < this.enabledTabs.length - 1) {\n this.keyboardSelectTab(enabledTabIndex + 1);\n } else {\n this.keyboardSelectTab(0);\n }\n break;\n case \"ArrowLeft\":\n if (enabledTabIndex > 0) {\n this.keyboardSelectTab(enabledTabIndex - 1);\n } else {\n this.keyboardSelectTab(this.enabledTabs.length - 1);\n }\n break;\n default:\n preventDefault = false;\n }\n if (preventDefault) event.preventDefault();\n };\n\n private handleKeyBoardNavManual = (event: KeyboardEvent) => {\n const key = event.key;\n const enabledTabIndex = this.getIndexOfEnabledTab(this.focusedTabIndex);\n let preventDefault = true;\n switch (key) {\n case \"Home\":\n this.keyboardFocusTab(0);\n break;\n case \"End\":\n this.keyboardFocusTab(this.enabledTabs.length - 1);\n break;\n case \"ArrowRight\":\n if (enabledTabIndex < this.enabledTabs.length - 1) {\n this.keyboardFocusTab(enabledTabIndex + 1);\n } else {\n this.keyboardFocusTab(0);\n }\n break;\n case \"ArrowLeft\":\n if (enabledTabIndex > 0) {\n this.keyboardFocusTab(enabledTabIndex - 1);\n } else {\n this.keyboardFocusTab(this.enabledTabs.length - 1);\n }\n break;\n case \"Enter\":\n this.keyboardSelectTab(this.focusedTabIndex);\n break;\n case \" \":\n this.keyboardSelectTab(this.focusedTabIndex);\n break;\n default:\n preventDefault = false;\n }\n if (preventDefault) event.preventDefault();\n };\n\n render() {\n return <slot></slot>;\n }\n}\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- const n=`<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">\n<path d="M9.70687 6L8.29688 7.41L12.8769 12L8.29688 16.59L9.70687 18L15.7069 12L9.70687 6Z" fill="currentColor"/>\n</svg>\n`;export{n as c};
2
- //# sourceMappingURL=p-24240e11.js.map
1
+ const n=`<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">\n<path d="M9.70687 6L8.29688 7.41L12.8769 12L8.29688 16.59L9.70687 18L15.7069 12L9.70687 6Z" fill="currentColor"/>\n</svg>\n`;export{n as C};
2
+ //# sourceMappingURL=p-06321d19.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sources":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ import{r as t,c as e,h as i,H as o,g as s}from"./p-69920d86.js";import{r as n,a,i as r,K as c}from"./p-5dd0b02e.js";import{C as l}from"./p-8c7f4343.js";import{C as u}from"./p-06321d19.js";import"./p-6f57b13c.js";const d='/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0;}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px;}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font-style:inherit;vertical-align:baseline}li{list-style:none;padding:0}:host::part(button){color:var(--ic-color-primary-text);padding:calc(var(--ic-space-xxxs) / 2);display:flex;align-items:flex-start;gap:var(--ic-space-xs);border-radius:0;min-height:2.5rem;height:auto}.focus-border{display:flex;align-items:flex-start;gap:var(--ic-space-xs);border-radius:var(--ic-border-radius);margin:calc(var(--ic-space-xxxs) / 2);padding:var(--ic-space-xxs);border:var(--ic-space-xxxs) dashed transparent;--icon-height:auto}:host(.disabled)::part(button){color:var(--ic-architectural-200) !important;pointer-events:none}:host(.disabled) .menu-item-label,:host(.disabled) .shortcut,:host(.disabled) .menu-item-description{color:var(--ic-architectural-200) !important}:host([variant="destructive"])::part(button){color:var(--ic-action-destructive)}:host::part(button):hover{background-color:var(--ic-action-dark-bg-hover)}:host::part(button):focus-visible,:host::part(button):focus{color:var(--ic-color-white-text);background-color:var(--ic-focus-blue);box-shadow:none}:host(.disabled)::part(button):focus-visible,:host(.disabled)::part(button):focus{color:var(--ic-theme-lighten-40) !important}:host([variant="destructive"])::part(button):focus-visible,:host([variant="destructive"])::part(button):focus{background-color:var(--ic-action-destructive)}ic-button:focus-within .menu-item-label,ic-button:focus-within .shortcut,ic-button:focus-within .menu-item-description{color:var(--ic-color-white-text)}:host(.disabled) ic-button:focus-within .focus-border{border-color:var(--ic-architectural-white)}:host(.disabled) ic-button:focus-within .menu-item-label,:host(.disabled) ic-button:focus-within .shortcut,:host(.disabled) ic-button:focus-within .menu-item-description{color:var(--ic-theme-lighten-40) !important}:host::part(button):active{background-color:var(--ic-action-dark-bg-active);color:var(--ic-color-primary-text) !important}:host([variant="destructive"])::part(button):active{background-color:var(--ic-action-dark-bg-active);color:var(--ic-action-destructive) !important}.menu-item-info{display:flex;flex-direction:column;flex:1;align-items:baseline;white-space:pre-line;text-align:left}.menu-labels{display:flex;align-items:baseline;gap:var(--ic-space-xs)}.menu-item-description{color:var(--ic-color-secondary-text)}.shortcut{color:var(--ic-color-tertiary-text);display:flex;flex:min-content}:host([variant="destructive"]) .menu-item-label{text-transform:uppercase;font-weight:600;letter-spacing:0.025em}ic-button:active .menu-item-label{color:var(--ic-color-primary-text)}ic-button:active .menu-item-description{color:var(--ic-color-secondary-text)}ic-button:active .shortcut{color:var(--ic-color-tertiary-text)}:host([variant="destructive"]) ic-button:active .menu-item-label{color:var(--ic-action-destructive) !important}.icon,.check-icon,.submenu-icon,.icon ::slotted(svg),.check-icon svg,.submenu-icon svg{width:var(--ic-space-lg);height:var(--ic-space-lg)}.check-icon.hide{visibility:hidden}@media (forced-colors: active){:host::part(button){border:canvas}:host::part(button):focus-visible{outline:var(--ic-space-xxxs) solid transparent}.focus-border{border-color:canvas}:host(.disabled) ic-button:focus-within .focus-border{border-color:GrayText}:host(.disabled) .menu-item-info,:host(.disabled) .menu-item-label,:host(.disabled) .shortcut,:host(.disabled) .menu-item-description,:host(.disabled) ic-button:focus-within .menu-item-info,:host(.disabled) ic-button:focus-within .menu-item-label,:host(.disabled) ic-button:focus-within .shortcut,:host(.disabled) ic-button:focus-within .menu-item-description{color:GrayText !important}:host(.disabled)::part(button):focus-visible,:host(.disabled)::part(button):focus{outline-color:GrayText !important}}';const h=class{constructor(i){t(this,i);this.childBlur=e(this,"childBlur",7);this.handleMenuItemClick=e(this,"handleMenuItemClick",7);this.triggerPopoverMenuInstance=e(this,"triggerPopoverMenuInstance",7);this.handleClick=t=>{if(this.submenuTriggerFor!==undefined){this.triggerPopoverMenuInstance.emit()}else if(this.variant==="toggle"){t.preventDefault();this.toggleChecked?this.toggleChecked=false:this.toggleChecked=true}this.handleMenuItemClick.emit({label:this.label,hasSubMenu:!!this.el.submenuTriggerFor})};this.getMenuItemAriaLabel=()=>{let t=this.label;if(this.description!==undefined){t=`${t}, ${this.description}`}if(this.keyboardShortcut!==undefined){t=`${t}, ${this.keyboardShortcut}`}if(this.variant==="destructive"){t=`${t}, destructive`}if(this.submenuTriggerFor!==undefined){t=`${t}, triggers submenu`}if(this.el.classList.contains("ic-popover-submenu-back-button")){t="Go back to parent menu"}const e=c(this.el);if(e.tagName==="IC-MENU-GROUP"&&e.label){return`${t}, ${e.label} menu group`}else{return t}};this.toggleChecked=false;this.description=undefined;this.disabled=false;this.href=undefined;this.hreflang=undefined;this.keyboardShortcut=undefined;this.label=undefined;this.referrerpolicy=undefined;this.rel=undefined;this.submenuTriggerFor=undefined;this.target=undefined;this.variant="default"}componentWillLoad(){if(this.submenuTriggerFor!==undefined&&this.variant!=="default"){this.variant="default"}n(this.disabled,this.el)}componentDidLoad(){a([{prop:this.label,propName:"label"}],"Menu Item")}handleHostClick(t){if(this.disabled){t.stopImmediatePropagation()}}render(){const t=t=>t!==undefined?t:null;const e=()=>i("div",{class:"menu-item-info"},i("div",{class:"menu-labels"},i("ic-typography",{class:"menu-item-label"},this.label),this.keyboardShortcut&&i("ic-typography",{variant:"caption",class:"shortcut"},this.keyboardShortcut)),this.description&&i("ic-typography",{class:"menu-item-description",variant:"caption"},this.description));return i(o,{class:{["disabled"]:this.disabled}},i("li",{role:this.variant==="toggle"?"menuitemcheckbox":"menuitem","aria-disabled":`${this.disabled}`,"aria-checked":this.variant==="toggle"&&this.toggleChecked===true?true:this.variant==="toggle"&&this.toggleChecked===false?false:undefined},i("ic-button",{disableTooltip:true,fullWidth:true,variant:"tertiary",onClick:this.handleClick,href:t(this.href),hreflang:t(this.hreflang),target:t(this.target),rel:t(this.rel),referrerpolicy:this.referrerpolicy!==undefined?this.referrerpolicy:null,"aria-disabled":`${this.disabled}`,"aria-label":this.getMenuItemAriaLabel(),"aria-controls":this.submenuTriggerFor!==undefined?`ic-popover-submenu-${this.submenuTriggerFor}`:false,"aria-haspopup":this.submenuTriggerFor!==undefined||this.el.classList.contains("ic-popover-submenu-back-button")?"menu":false,"aria-owns":this.submenuTriggerFor!==undefined?`ic-popover-submenu-${this.submenuTriggerFor}`:false},i("div",{class:"focus-border"},r(this.el,"icon")&&i("span",{class:"icon"},i("slot",{name:"icon"})),i(e,null),this.variant==="toggle"&&i("span",{class:{["check-icon"]:true,["hide"]:!this.toggleChecked},"aria-hidden":"true",innerHTML:l}),this.submenuTriggerFor!==undefined&&i("span",{class:{["submenu-icon"]:true},"aria-hidden":"true",innerHTML:u})))))}static get delegatesFocus(){return true}get el(){return s(this)}};h.style=d;export{h as ic_menu_item};
2
+ //# sourceMappingURL=p-1959ec8d.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icMenuItemCss","MenuItem","this","handleClick","e","submenuTriggerFor","undefined","triggerPopoverMenuInstance","emit","variant","preventDefault","toggleChecked","handleMenuItemClick","label","hasSubMenu","el","getMenuItemAriaLabel","ariaLabel","description","keyboardShortcut","classList","contains","parentEl","getParentElement","tagName","componentWillLoad","removeDisabledFalse","disabled","componentDidLoad","onComponentRequiredPropUndefined","prop","propName","handleHostClick","stopImmediatePropagation","render","isPropDefined","MenuItemInformation","h","class","Host","role","disableTooltip","fullWidth","onClick","href","hreflang","target","rel","referrerpolicy","isSlotUsed","name","innerHTML","Check","Chevron"],"sources":["./src/components/ic-menu-item/ic-menu-item.css?tag=ic-menu-item&encapsulation=shadow","./src/components/ic-menu-item/ic-menu-item.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\nli {\n list-style: none;\n padding: 0;\n}\n\n:host::part(button) {\n color: var(--ic-color-primary-text);\n padding: calc(var(--ic-space-xxxs) / 2);\n display: flex;\n align-items: flex-start;\n gap: var(--ic-space-xs);\n border-radius: 0;\n min-height: 2.5rem;\n height: auto;\n}\n\n.focus-border {\n display: flex;\n align-items: flex-start;\n gap: var(--ic-space-xs);\n border-radius: var(--ic-border-radius);\n margin: calc(var(--ic-space-xxxs) / 2);\n padding: var(--ic-space-xxs);\n border: var(--ic-space-xxxs) dashed transparent;\n\n --icon-height: auto;\n}\n\n:host(.disabled)::part(button) {\n color: var(--ic-architectural-200) !important;\n pointer-events: none;\n}\n\n:host(.disabled) .menu-item-label,\n:host(.disabled) .shortcut,\n:host(.disabled) .menu-item-description {\n color: var(--ic-architectural-200) !important;\n}\n\n:host([variant=\"destructive\"])::part(button) {\n color: var(--ic-action-destructive);\n}\n\n:host::part(button):hover {\n background-color: var(--ic-action-dark-bg-hover);\n}\n\n:host::part(button):focus-visible,\n:host::part(button):focus {\n color: var(--ic-color-white-text);\n background-color: var(--ic-focus-blue);\n box-shadow: none;\n}\n\n:host(.disabled)::part(button):focus-visible,\n:host(.disabled)::part(button):focus {\n color: var(--ic-theme-lighten-40) !important;\n}\n\n:host([variant=\"destructive\"])::part(button):focus-visible,\n:host([variant=\"destructive\"])::part(button):focus {\n background-color: var(--ic-action-destructive);\n}\n\nic-button:focus-within .menu-item-label,\nic-button:focus-within .shortcut,\nic-button:focus-within .menu-item-description {\n color: var(--ic-color-white-text);\n}\n\n:host(.disabled) ic-button:focus-within .focus-border {\n border-color: var(--ic-architectural-white);\n}\n\n:host(.disabled) ic-button:focus-within .menu-item-label,\n:host(.disabled) ic-button:focus-within .shortcut,\n:host(.disabled) ic-button:focus-within .menu-item-description {\n color: var(--ic-theme-lighten-40) !important;\n}\n\n:host::part(button):active {\n background-color: var(--ic-action-dark-bg-active);\n color: var(--ic-color-primary-text) !important;\n}\n\n:host([variant=\"destructive\"])::part(button):active {\n background-color: var(--ic-action-dark-bg-active);\n color: var(--ic-action-destructive) !important;\n}\n\n.menu-item-info {\n display: flex;\n flex-direction: column;\n flex: 1;\n align-items: baseline;\n white-space: pre-line;\n text-align: left;\n}\n\n.menu-labels {\n display: flex;\n align-items: baseline;\n gap: var(--ic-space-xs);\n}\n\n.menu-item-description {\n color: var(--ic-color-secondary-text);\n}\n\n.shortcut {\n color: var(--ic-color-tertiary-text);\n display: flex;\n flex: min-content;\n}\n\n:host([variant=\"destructive\"]) .menu-item-label {\n text-transform: uppercase;\n font-weight: 600;\n letter-spacing: 0.025em;\n}\n\nic-button:active .menu-item-label {\n color: var(--ic-color-primary-text);\n}\n\nic-button:active .menu-item-description {\n color: var(--ic-color-secondary-text);\n}\n\nic-button:active .shortcut {\n color: var(--ic-color-tertiary-text);\n}\n\n:host([variant=\"destructive\"]) ic-button:active .menu-item-label {\n color: var(--ic-action-destructive) !important;\n}\n\n.icon,\n.check-icon,\n.submenu-icon,\n.icon ::slotted(svg),\n.check-icon svg,\n.submenu-icon svg {\n width: var(--ic-space-lg);\n height: var(--ic-space-lg);\n}\n\n.check-icon.hide {\n visibility: hidden;\n}\n\n/** High Contrast **/\n@media (forced-colors: active) {\n :host::part(button) {\n border: canvas;\n }\n\n :host::part(button):focus-visible {\n outline: var(--ic-space-xxxs) solid transparent;\n }\n\n .focus-border {\n border-color: canvas;\n }\n\n :host(.disabled) ic-button:focus-within .focus-border {\n border-color: GrayText;\n }\n\n :host(.disabled) .menu-item-info,\n :host(.disabled) .menu-item-label,\n :host(.disabled) .shortcut,\n :host(.disabled) .menu-item-description,\n :host(.disabled) ic-button:focus-within .menu-item-info,\n :host(.disabled) ic-button:focus-within .menu-item-label,\n :host(.disabled) ic-button:focus-within .shortcut,\n :host(.disabled) ic-button:focus-within .menu-item-description {\n color: GrayText !important;\n }\n\n :host(.disabled)::part(button):focus-visible,\n :host(.disabled)::part(button):focus {\n outline-color: GrayText !important;\n }\n}\n","import {\n Component,\n Element,\n Host,\n Prop,\n h,\n State,\n Event,\n EventEmitter,\n Listen,\n} from \"@stencil/core\";\nimport {\n getParentElement,\n isSlotUsed,\n onComponentRequiredPropUndefined,\n removeDisabledFalse,\n} from \"../../utils/helpers\";\nimport { IcMenuItemVariants } from \"./ic-menu-item.types\";\nimport Check from \"../../assets/check-icon.svg\";\nimport Chevron from \"../../assets/chevron-icon.svg\";\n\n/**\n * @slot icon - Content will be placed to the left of the menu item label.\n */\n\n@Component({\n tag: \"ic-menu-item\",\n styleUrl: \"ic-menu-item.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class MenuItem {\n @Element() el: HTMLIcMenuItemElement;\n\n @State() toggleChecked: boolean = false;\n\n /**\n * The description displayed in the menu item, below the label.\n */\n @Prop() description?: string;\n\n /**\n * If `true`, the menu item will be in disabled state.\n */\n @Prop() disabled?: boolean = false;\n\n /**\n * The URL that the link points to. This will render the menu item as an \"a\" tag.\n */\n @Prop() href?: string;\n\n /**\n * The human language of the linked URL.\n */\n @Prop() hreflang?: string;\n\n /**\n * The label describing the keyboard shortcut for a menu item's action.\n */\n @Prop() keyboardShortcut?: string;\n\n /**\n * The label to display in the menu item.\n */\n @Prop() label!: string;\n\n /**\n * How much of the referrer to send when following the link.\n */\n @Prop() referrerpolicy?: ReferrerPolicy;\n\n /**\n * The relationship of the linked URL as space-separated link types.\n */\n @Prop() rel?: string;\n\n /**\n * This references the popover menu instance that the menu item is a trigger for. If this prop is set, then the variant will always be default.\n */\n @Prop() submenuTriggerFor?: string;\n\n /**\n * The place to display the linked URL, as the name for a browsing context (a tab, window, or iframe).\n */\n @Prop() target?: string;\n\n /**\n * The variant of the menu item.\n */\n @Prop({ mutable: true, reflect: true }) variant: IcMenuItemVariants =\n \"default\";\n\n /**\n * @internal Emitted when item loses focus.\n */\n @Event() childBlur: EventEmitter<void>;\n\n /**\n * @internal Emitted when the user clicks a menu item.\n */\n @Event() handleMenuItemClick: EventEmitter<{\n label: string;\n hasSubMenu: boolean;\n }>;\n\n /**\n * @internal Emitted when the user clicks a menu item that triggers a popover menu instance.\n */\n @Event() triggerPopoverMenuInstance: EventEmitter<void>;\n\n componentWillLoad(): void {\n // This ensures that trigger menu items are always set to the default variant\n if (this.submenuTriggerFor !== undefined && this.variant !== \"default\") {\n this.variant = \"default\";\n }\n removeDisabledFalse(this.disabled, this.el);\n }\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.label, propName: \"label\" }],\n \"Menu Item\"\n );\n }\n\n @Listen(\"click\", { capture: true })\n handleHostClick(e: Event): void {\n if (this.disabled) {\n e.stopImmediatePropagation();\n }\n }\n\n private handleClick = (e: Event): void => {\n if (this.submenuTriggerFor !== undefined) {\n this.triggerPopoverMenuInstance.emit();\n } else if (this.variant === \"toggle\") {\n e.preventDefault();\n this.toggleChecked\n ? (this.toggleChecked = false)\n : (this.toggleChecked = true);\n }\n this.handleMenuItemClick.emit({\n label: this.label,\n hasSubMenu: !!this.el.submenuTriggerFor,\n });\n };\n\n private getMenuItemAriaLabel = (): string => {\n let ariaLabel = this.label;\n\n if (this.description !== undefined) {\n ariaLabel = `${ariaLabel}, ${this.description}`;\n }\n\n if (this.keyboardShortcut !== undefined) {\n ariaLabel = `${ariaLabel}, ${this.keyboardShortcut}`;\n }\n\n if (this.variant === \"destructive\") {\n ariaLabel = `${ariaLabel}, destructive`;\n }\n\n if (this.submenuTriggerFor !== undefined) {\n ariaLabel = `${ariaLabel}, triggers submenu`;\n }\n\n if (this.el.classList.contains(\"ic-popover-submenu-back-button\")) {\n ariaLabel = \"Go back to parent menu\";\n }\n const parentEl = getParentElement(this.el);\n\n if (\n parentEl.tagName === \"IC-MENU-GROUP\" &&\n (parentEl as HTMLIcMenuGroupElement).label\n ) {\n return `${ariaLabel}, ${\n (parentEl as HTMLIcMenuGroupElement).label\n } menu group`;\n } else {\n return ariaLabel;\n }\n };\n\n render() {\n // A helper function that checks if a prop has been defined\n const isPropDefined = (prop: string) => {\n return prop !== undefined ? prop : null;\n };\n\n // A sub-component to layout the menu information correctly in ic-button\n const MenuItemInformation = () => {\n return (\n <div class=\"menu-item-info\">\n <div class=\"menu-labels\">\n <ic-typography class=\"menu-item-label\">{this.label}</ic-typography>\n {this.keyboardShortcut && (\n <ic-typography variant=\"caption\" class=\"shortcut\">\n {this.keyboardShortcut}\n </ic-typography>\n )}\n </div>\n {this.description && (\n <ic-typography class=\"menu-item-description\" variant=\"caption\">\n {this.description}\n </ic-typography>\n )}\n </div>\n );\n };\n\n return (\n <Host\n class={{\n [\"disabled\"]: this.disabled,\n }}\n >\n <li\n role={this.variant === \"toggle\" ? \"menuitemcheckbox\" : \"menuitem\"}\n aria-disabled={`${this.disabled}`}\n aria-checked={\n this.variant === \"toggle\" && this.toggleChecked === true\n ? true\n : this.variant === \"toggle\" && this.toggleChecked === false\n ? false\n : undefined\n }\n >\n <ic-button\n disableTooltip\n fullWidth\n variant=\"tertiary\"\n onClick={this.handleClick}\n href={isPropDefined(this.href)}\n hreflang={isPropDefined(this.hreflang)}\n target={isPropDefined(this.target)}\n rel={isPropDefined(this.rel)}\n referrerpolicy={\n this.referrerpolicy !== undefined ? this.referrerpolicy : null\n }\n aria-disabled={`${this.disabled}`}\n aria-label={this.getMenuItemAriaLabel()}\n aria-controls={\n this.submenuTriggerFor !== undefined\n ? `ic-popover-submenu-${this.submenuTriggerFor}`\n : false\n }\n aria-haspopup={\n this.submenuTriggerFor !== undefined ||\n this.el.classList.contains(\"ic-popover-submenu-back-button\")\n ? \"menu\"\n : false\n }\n aria-owns={\n this.submenuTriggerFor !== undefined\n ? `ic-popover-submenu-${this.submenuTriggerFor}`\n : false\n }\n >\n <div class=\"focus-border\">\n {isSlotUsed(this.el, \"icon\") && (\n <span class=\"icon\">\n <slot name=\"icon\"></slot>\n </span>\n )}\n <MenuItemInformation />\n {this.variant === \"toggle\" && (\n <span\n class={{\n [\"check-icon\"]: true,\n [\"hide\"]: !this.toggleChecked,\n }}\n aria-hidden=\"true\"\n innerHTML={Check}\n />\n )}\n {this.submenuTriggerFor !== undefined && (\n <span\n class={{ [\"submenu-icon\"]: true }}\n aria-hidden=\"true\"\n innerHTML={Chevron}\n />\n )}\n </div>\n </ic-button>\n </li>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{r as t,c as e,h as i,H as o,g as a}from"./p-69920d86.js";import{I as s}from"./p-6f57b13c.js";import{r}from"./p-5dd0b02e.js";const n='/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0;}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px;}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font-style:inherit;vertical-align:baseline}:host{--indicator-initial-color:rgba(23 89 188 / 0%);--indicator-color:var(--ic-action-default);--focus-indicator:var(--ic-border-focus);--label-color:var(--ic-color-primary-text);--background-color-hover:var(--ic-action-default-bg-hover);--background-color-active:var(--ic-action-default-bg-active);display:flex;align-items:center;border-radius:0;color:var(--label-color);height:2.5rem;padding:0 var(--ic-space-md);cursor:pointer;position:relative;border-bottom:var(--ic-space-xxs) solid var(--indicator-initial-color);gap:var(--ic-space-xs);transition:all var(--ic-easing-transition-fast)}:host(:focus){box-shadow:var(--focus-indicator);border-radius:var(--ic-border-radius)}:host(:focus-visible){outline:var(--ic-hc-focus-outline)}:host(:hover){background-color:var(--background-color-hover)}:host(:active){background-color:var(--background-color-active)}:host(.ic-tab-light){--indicator-initial-color:rgb(255 255 255 / 0%);--indicator-color:rgb(255 255 255 / 100%);--focus-indicator:var(--ic-border-focus);--label-color:white;--background-color-hover:var(--ic-action-dark-bg-hover);--background-color-active:var(--ic-action-dark-bg-active)}:host(.selected){border-bottom:var(--ic-space-xxs) solid var(--indicator-color)}:host(.disabled){pointer-events:none;color:var(--ic-architectural-300)}:host(.selected.with-transition){transition:all var(--ic-easing-transition-slow),\n border-color var(--ic-transition-duration-slow)}.ic-tab-label{pointer-events:none}::slotted(svg){fill:currentcolor}@media (forced-colors: active){:host{border-bottom:var(--ic-space-xxs) solid canvas}:host(.disabled){color:GrayText}}';const c=class{constructor(i){t(this,i);this.tabClick=e(this,"tabClick",7);this.tabCreated=e(this,"tabCreated",7);this.tabEnabled=e(this,"tabEnabled",7);this.tabFocus=e(this,"tabFocus",7);this.tabRemoved=e(this,"tabRemoved",7);this.focusFromClick=false;this.isInitialRender=true;this.handleClick=()=>{this.tabClick.emit({tabId:this.tabId,contextId:this.contextId,position:this.tabPosition});if(this.focusFromClick){this.tabFocus.emit({tabId:this.tabId,contextId:this.contextId,position:this.tabPosition});this.focusFromClick=false}};this.handleFocus=()=>{if(!this.focusFromClick){this.focusTabId=this.tabId;this.tabFocus.emit({tabId:this.tabId,contextId:this.contextId,position:this.tabPosition})}};this.handleMouseDown=()=>{this.focusFromClick=true};this.appearance="dark";this.contextId="default";this.disabled=false;this.selected=false;this.tabId=undefined;this.tabPosition=undefined}disabledWatchHandler(){this.tabEnabled.emit()}connectedCallback(){this.tabCreated.emit(this.host)}disconnectedCallback(){const t=document.querySelector(`ic-tab-context[context-id=${this.contextId}]`);if(t){t.tabRemovedHandler(!!this.focusTabId)}}componentWillLoad(){r(this.disabled,this.host)}componentDidUpdate(){this.isInitialRender=false}async setFocus(){if(this.host){this.host.focus()}}render(){const{disabled:t,selected:e,appearance:a}=this;return i(o,{class:{["with-transition"]:!this.isInitialRender,["ic-tab-light"]:a===s.Light,["selected"]:e,["disabled"]:t},role:"tab","aria-selected":e?"true":"false",onClick:this.handleClick,onFocus:this.handleFocus,onMouseDown:this.handleMouseDown,"aria-disabled":t?"true":"false",tabindex:this.selected?0:-1},this.host.querySelector('[slot="icon"]')&&i("slot",{name:"icon"}),i("ic-typography",{class:"ic-tab-label",variant:"label"},i("span",null,i("slot",null))))}get host(){return a(this)}static get watchers(){return{disabled:["disabledWatchHandler"]}}};c.style=n;export{c as ic_tab};
2
+ //# sourceMappingURL=p-1b9b8355.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icTabCss","Tab","this","focusFromClick","isInitialRender","handleClick","tabClick","emit","tabId","contextId","position","tabPosition","tabFocus","handleFocus","focusTabId","handleMouseDown","disabledWatchHandler","tabEnabled","connectedCallback","tabCreated","host","disconnectedCallback","tabContext","document","querySelector","tabRemovedHandler","componentWillLoad","removeDisabledFalse","disabled","componentDidUpdate","async","focus","render","selected","appearance","h","Host","class","IcThemeForegroundEnum","Light","role","onClick","onFocus","onMouseDown","tabindex","name","variant"],"sources":["./src/components/ic-tab/ic-tab.css?tag=ic-tab&encapsulation=shadow","./src/components/ic-tab/ic-tab.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n:host {\n --indicator-initial-color: rgba(23 89 188 / 0%);\n --indicator-color: var(--ic-action-default);\n --focus-indicator: var(--ic-border-focus);\n --label-color: var(--ic-color-primary-text);\n --background-color-hover: var(--ic-action-default-bg-hover);\n --background-color-active: var(--ic-action-default-bg-active);\n\n display: flex;\n align-items: center;\n border-radius: 0;\n color: var(--label-color);\n height: 2.5rem;\n padding: 0 var(--ic-space-md);\n cursor: pointer;\n position: relative;\n border-bottom: var(--ic-space-xxs) solid var(--indicator-initial-color);\n gap: var(--ic-space-xs);\n transition: all var(--ic-easing-transition-fast);\n}\n\n:host(:focus) {\n box-shadow: var(--focus-indicator);\n border-radius: var(--ic-border-radius);\n}\n\n:host(:focus-visible) {\n outline: var(--ic-hc-focus-outline);\n}\n\n:host(:hover) {\n background-color: var(--background-color-hover);\n}\n\n:host(:active) {\n background-color: var(--background-color-active);\n}\n\n:host(.ic-tab-light) {\n --indicator-initial-color: rgb(255 255 255 / 0%);\n --indicator-color: rgb(255 255 255 / 100%);\n --focus-indicator: var(--ic-border-focus);\n --label-color: white;\n --background-color-hover: var(--ic-action-dark-bg-hover);\n --background-color-active: var(--ic-action-dark-bg-active);\n}\n\n:host(.selected) {\n border-bottom: var(--ic-space-xxs) solid var(--indicator-color);\n}\n\n:host(.disabled) {\n pointer-events: none;\n color: var(--ic-architectural-300);\n}\n\n:host(.selected.with-transition) {\n transition: all var(--ic-easing-transition-slow),\n border-color var(--ic-transition-duration-slow);\n}\n\n.ic-tab-label {\n pointer-events: none;\n}\n\n::slotted(svg) {\n fill: currentcolor;\n}\n\n@media (forced-colors: active) {\n :host {\n border-bottom: var(--ic-space-xxs) solid canvas;\n }\n\n :host(.disabled) {\n color: GrayText;\n }\n}\n","import {\n Component,\n Element,\n Event,\n EventEmitter,\n Host,\n Prop,\n h,\n Method,\n Watch,\n} from \"@stencil/core\";\n\nimport { IcTabClickEventDetail } from \"./ic-tab.types\";\nimport {\n IcThemeForegroundNoDefault,\n IcThemeForegroundEnum,\n} from \"../../utils/types\";\nimport { removeDisabledFalse } from \"../../utils/helpers\";\n\n/**\n * @slot icon - Content will be rendered next to the tab label.\n */\n@Component({\n tag: \"ic-tab\",\n styleUrl: \"ic-tab.css\",\n shadow: true,\n})\nexport class Tab {\n private focusFromClick: boolean = false;\n private focusTabId: string;\n private isInitialRender: boolean = true;\n\n @Element() host: HTMLIcTabElement;\n\n /** @internal Determines whether the light or dark variant of the tabs should be displayed. */\n @Prop() appearance?: IcThemeForegroundNoDefault = \"dark\";\n\n /** @internal The unique context needed if using multiple tabs inside one another i.e. rendering another tabs inside a tab panel. */\n @Prop({ reflect: true }) contextId?: string = \"default\";\n\n /**\n * If `true`, the disabled state will be set.\n */\n @Prop() disabled?: boolean = false;\n\n /** @internal If `true`, the tab will display with a selected indicator and tabIndex will be set. */\n @Prop({ reflect: true }) selected?: boolean = false;\n\n /** @internal The shared ID between panel and tab. */\n @Prop({ reflect: true }) tabId?: string;\n\n /** @internal The position of the tab inside the tabs array in context. */\n @Prop() tabPosition?: number;\n\n @Watch(\"disabled\")\n disabledWatchHandler(): void {\n this.tabEnabled.emit();\n }\n\n /**\n * @internal Emitted when a tab is selected.\n */\n @Event() tabClick: EventEmitter<IcTabClickEventDetail>;\n\n /**\n * @internal Emitted when a tab is dynamically created.\n */\n @Event() tabCreated: EventEmitter<HTMLIcTabElement>;\n\n /**\n * @internal Emitted when a tab's disabled prop changes\n */\n @Event() tabEnabled: EventEmitter<void>;\n\n /**\n * @internal Emitted when a tab is focussed.\n */\n @Event() tabFocus: EventEmitter<IcTabClickEventDetail>;\n\n /**\n * @internal Emitted when a tab is unmounted.\n */\n @Event() tabRemoved: EventEmitter<void>;\n\n connectedCallback(): void {\n this.tabCreated.emit(this.host);\n }\n\n disconnectedCallback(): void {\n const tabContext = document.querySelector(\n `ic-tab-context[context-id=${this.contextId}]`\n ) as HTMLIcTabContextElement;\n if (tabContext) {\n tabContext.tabRemovedHandler(!!this.focusTabId);\n }\n }\n\n componentWillLoad(): void {\n removeDisabledFalse(this.disabled, this.host);\n }\n\n componentDidUpdate(): void {\n this.isInitialRender = false;\n }\n\n /**\n * Sets focus on the tab.\n */\n @Method()\n async setFocus(): Promise<void> {\n if (this.host) {\n this.host.focus();\n }\n }\n\n private handleClick = () => {\n this.tabClick.emit({\n tabId: this.tabId,\n contextId: this.contextId,\n position: this.tabPosition,\n });\n if (this.focusFromClick) {\n this.tabFocus.emit({\n tabId: this.tabId,\n contextId: this.contextId,\n position: this.tabPosition,\n });\n this.focusFromClick = false;\n }\n };\n\n private handleFocus = () => {\n if (!this.focusFromClick) {\n this.focusTabId = this.tabId;\n\n this.tabFocus.emit({\n tabId: this.tabId,\n contextId: this.contextId,\n position: this.tabPosition,\n });\n }\n };\n\n private handleMouseDown = () => {\n //set flag so that focus gets handled after click\n //there is a timing issue where a long click only causes focus to happen & not the click\n //the focus does need to be a seperate event though to handle focus from keyboard\n this.focusFromClick = true;\n };\n\n render() {\n const { disabled, selected, appearance } = this;\n return (\n <Host\n class={{\n [\"with-transition\"]: !this.isInitialRender,\n [\"ic-tab-light\"]: appearance === IcThemeForegroundEnum.Light,\n [\"selected\"]: selected,\n [\"disabled\"]: disabled,\n }}\n role=\"tab\"\n aria-selected={selected ? \"true\" : \"false\"}\n onClick={this.handleClick}\n onFocus={this.handleFocus}\n onMouseDown={this.handleMouseDown}\n aria-disabled={disabled ? \"true\" : \"false\"}\n tabindex={this.selected ? 0 : -1}\n >\n {this.host.querySelector('[slot=\"icon\"]') && <slot name=\"icon\"></slot>}\n <ic-typography class=\"ic-tab-label\" variant=\"label\">\n <span>\n <slot></slot>\n </span>\n </ic-typography>\n </Host>\n );\n }\n}\n"],"mappings":"mIAAA,MAAMA,EAAW,k7H,MC2BJC,EAAG,M,oNACNC,KAAAC,eAA0B,MAE1BD,KAAAE,gBAA2B,KAqF3BF,KAAAG,YAAc,KACpBH,KAAKI,SAASC,KAAK,CACjBC,MAAON,KAAKM,MACZC,UAAWP,KAAKO,UAChBC,SAAUR,KAAKS,cAEjB,GAAIT,KAAKC,eAAgB,CACvBD,KAAKU,SAASL,KAAK,CACjBC,MAAON,KAAKM,MACZC,UAAWP,KAAKO,UAChBC,SAAUR,KAAKS,cAEjBT,KAAKC,eAAiB,K,GAIlBD,KAAAW,YAAc,KACpB,IAAKX,KAAKC,eAAgB,CACxBD,KAAKY,WAAaZ,KAAKM,MAEvBN,KAAKU,SAASL,KAAK,CACjBC,MAAON,KAAKM,MACZC,UAAWP,KAAKO,UAChBC,SAAUR,KAAKS,a,GAKbT,KAAAa,gBAAkB,KAIxBb,KAAKC,eAAiB,IAAI,E,gBAhHsB,O,eAGJ,U,cAKjB,M,cAGiB,M,gDAS9Ca,uBACEd,KAAKe,WAAWV,M,CA4BlBW,oBACEhB,KAAKiB,WAAWZ,KAAKL,KAAKkB,K,CAG5BC,uBACE,MAAMC,EAAaC,SAASC,cAC1B,6BAA6BtB,KAAKO,cAEpC,GAAIa,EAAY,CACdA,EAAWG,oBAAoBvB,KAAKY,W,EAIxCY,oBACEC,EAAoBzB,KAAK0B,SAAU1B,KAAKkB,K,CAG1CS,qBACE3B,KAAKE,gBAAkB,K,CAOzB0B,iBACE,GAAI5B,KAAKkB,KAAM,CACblB,KAAKkB,KAAKW,O,EAuCdC,SACE,MAAMJ,SAAEA,EAAQK,SAAEA,EAAQC,WAAEA,GAAehC,KAC3C,OACEiC,EAACC,EAAI,CACHC,MAAO,CACL,CAAC,oBAAqBnC,KAAKE,gBAC3B,CAAC,gBAAiB8B,IAAeI,EAAsBC,MACvD,CAAC,YAAaN,EACd,CAAC,YAAaL,GAEhBY,KAAK,MAAK,gBACKP,EAAW,OAAS,QACnCQ,QAASvC,KAAKG,YACdqC,QAASxC,KAAKW,YACd8B,YAAazC,KAAKa,gBAAe,gBAClBa,EAAW,OAAS,QACnCgB,SAAU1C,KAAK+B,SAAW,GAAK,GAE9B/B,KAAKkB,KAAKI,cAAc,kBAAoBW,EAAA,QAAMU,KAAK,SACxDV,EAAA,iBAAeE,MAAM,eAAeS,QAAQ,SAC1CX,EAAA,YACEA,EAAA,e"}
@@ -0,0 +1,2 @@
1
+ import{r as i,c as t,h as e,H as a,g as o}from"./p-69920d86.js";import{D as n,l as s,t as r,g as d,q as c}from"./p-5dd0b02e.js";import{C as l}from"./p-06321d19.js";import{O as v}from"./p-8d4f7027.js";import"./p-6f57b13c.js";const h='/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0;}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px;}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font-style:inherit;vertical-align:baseline}:host{display:block}:host(:focus-within){z-index:var(--ic-z-index-navigation-item)}svg{width:var(--ic-space-xl);fill:var(--ic-theme-text)}.svg{margin-left:auto}:host(.expandable.navigation-item) .link,:host(.expandable.navigation-item) ::slotted(a){padding-right:0}:host(.navigation-item) .link,:host(.navigation-item) ::slotted(a){height:calc(100% - var(--ic-space-xxs));width:-moz-fit-content;width:fit-content;color:var(--ic-theme-text);display:flex;align-items:center;justify-content:center;padding:0 var(--ic-space-md) var(--ic-space-xxs);text-decoration:none;transition:var(--ic-easing-transition-fast);position:relative;white-space:nowrap}:host(.navigation-item) ::slotted(a){height:100%;font:var(--ic-font-label) !important;letter-spacing:var(--ic-font-letter-spacing-0pt025) !important;padding:0 var(--ic-space-md) !important}:host(.navigation-item-selected) .link::after,:host(.navigation-item-selected) ::slotted(a.active)::after,:host(.navigation-item-top-nav) ::slotted(a.active)::after{content:"";height:0.25rem;width:100%;position:absolute;bottom:0;background-color:var(--ic-theme-text)}:host(.navigation-item-selected.navigation-item-page-header) ::slotted(a.active)::after,:host(.navigation-item-selected.navigation-item-page-header) .link::after,:host(.navigation-item.navigation-item-page-header) ::slotted(a.active)::after,:host(.navigation-item-top-nav-child) ::slotted(a.active)::after{content:none}:host(.navigation-item-side-menu-selected) .link,:host(.navigation-item-side-menu) ::slotted(a.active),:host(.navigation-item-top-nav-child) ::slotted(a.active){box-shadow:none}:host(.navigation-item) .link:hover:not(:focus){background-color:var(--ic-theme-hover);cursor:pointer}:host(.navigation-item:not(.navigation-item-page-header,.navigation-item-side-menu)) ::slotted(a:hover:not(:focus)){background-color:var(--ic-theme-hover) !important}:host(.navigation-item:not(.navigation-item-top-nav-child,.navigation-item-side-menu,.navigation-item-top-nav-child-selected .navigation-item-side-menu-selected)) .focus-indicator:focus-within{box-shadow:var(--ic-border-focus);border-radius:var(--ic-border-radius)}:host(.navigation-item) .link:focus,:host(.navigation-item) ::slotted(a:focus){box-shadow:var(--ic-border-focus);border-radius:var(--ic-border-radius);outline:var(--ic-hc-focus-outline)}:host(.navigation-item-selected) .link:focus,:host(.navigation-item) ::slotted(a.active:focus){box-shadow:var(--ic-border-focus);border-radius:var(--ic-border-radius);outline:var(--ic-hc-focus-outline)}:host(.navigation-item-selected.dark) .link:focus,:host(.navigation-item.dark) ::slotted(a.active:focus){box-shadow:var(--ic-border-focus);border-radius:var(--ic-border-radius);outline:var(--ic-hc-focus-outline)}:host(.navigation-item) .link:active:not(:focus),:host(.navigation-item) ::slotted(a:active:not(:focus)){background-color:var(--ic-theme-active)}:host(.navigation-item-side-menu) .link,:host(.navigation-item-side-menu) ::slotted(a){height:2.5rem;width:100%;box-sizing:border-box;color:var(--ic-color-primary-text);display:flex;align-items:center;justify-content:flex-start;text-decoration:none;transition:box-shadow var(--ic-transition-duration-fast),\n border-radius var(--ic-transition-duration-fast)}:host(.navigation-item-side-menu) ::slotted(a){font:var(--ic-font-body) !important;letter-spacing:var(--ic-font-letter-spacing-0pt005) !important;transition:box-shadow var(--ic-easing-transition-fast),\n background-color var(--ic-easing-transition-fast)}:host(.navigation-item-side-menu) .link:hover:not(:focus){background-color:var(--ic-action-dark-bg-hover)}:host(.navigation-item-side-menu) ::slotted(a:hover:not(:focus)){background-color:var(--ic-action-dark-bg-hover) !important}:host(.navigation-item-side-menu) .focus-indicator:focus-within{box-shadow:none}:host(.navigation-item-side-menu) .link:focus,:host(.navigation-item-side-menu) ::slotted(a:focus){box-shadow:var(--ic-border-focus-inset) !important;padding-right:var(--ic-space-lg);width:auto;border-radius:var(--ic-border-radius-inset) !important}:host(.navigation-item-side-menu-selected) .link,:host(.navigation-item-side-menu-selected) ::slotted(a){transition:box-shadow var(--ic-easing-transition-slow),\n background-color var(--ic-easing-transition-slow)}:host(.navigation-item-side-menu-selected) .link:focus,:host(.navigation-item-side-menu) ::slotted(a.active:focus),:host(.navigation-item-top-nav-child) ::slotted(a.active:focus){margin-left:var(--ic-space-xs) !important;padding-left:var(--ic-space-xs) !important}:host(.navigation-item-top-nav-child) .link,:host(.navigation-item-top-nav-child) ::slotted(a){height:2.5rem;width:-moz-fit-content;width:fit-content;min-width:9.063rem;color:var(--ic-color-primary-text);display:flex;align-items:center;justify-content:flex-start;padding:0 var(--ic-space-md) !important;text-decoration:none;position:relative;transition:box-shadow var(--ic-transition-duration-fast),\n border-radius var(--ic-transition-duration-slow)}:host(.navigation-item-top-nav-child) ::slotted(a){font:var(--ic-font-body) !important;letter-spacing:var(--ic-font-letter-spacing-0pt005) !important}:host(.navigation-item-top-nav-child) .link:hover:not(:focus){background-color:var(--ic-action-dark-bg-hover) !important}:host(.navigation-item-top-nav-child) ::slotted(a:hover):not(:focus){background-color:var(--ic-action-dark-bg-hover) !important}:host(.navigation-item-top-nav-child) .link:focus,:host(.navigation-item-top-nav-child) ::slotted(a:focus){z-index:1;outline:var(--ic-hc-focus-outline);border-radius:var(--ic-border-radius-inset);box-shadow:var(--ic-border-focus-inset);transition:border-radius 0s, box-shadow var(--ic-transition-duration-fast)}:host(.navigation-item-top-nav-child) ::slotted(a.active:focus){box-shadow:var(--ic-border-focus-inset);border-radius:var(--ic-border-radius-inset)}:host(.navigation-item-side-menu) .link:active:not(:focus){background-color:var(--ic-action-dark-bg-active)}:host(.navigation-item-top-nav-child) .link:active:not(:focus),:host(.navigation-item-top-nav-child) ::slotted(a:active):not(:focus){outline:var(--ic-hc-focus-outline);background-color:var(--ic-action-dark-bg-active)}:host(.navigation-item-top-nav-child) ::slotted(a:active):not(:focus),:host(.navigation-item-side-menu) ::slotted(a:active):not(:focus){background-color:var(--ic-action-dark-bg-active) !important}:host(.navigation-item-side-menu-selected) *,:host(.navigation-item-top-nav-child-selected) *,:host(.navigation-item-side-menu) ::slotted(a.active),:host(.navigation-item-top-nav-child) ::slotted(a.active){font-weight:700 !important}:host(.navigation-item-top-nav-child) ::slotted(a.active)::before,:host(.navigation-item-top-nav-child-selected) .link::before,:host(.navigation-item-side-menu-selected) .link::before,:host(.navigation-item-side-menu) ::slotted(a.active)::before,:host(.navigation-item-side-menu-selected) .link:focus::before,:host(.navigation-item-side-menu) ::slotted(a.active:focus)::before{content:"";position:absolute;left:0;width:var(--ic-space-xs);height:2.5rem;margin-top:0.25rem;margin-right:0.313rem;background-color:var(--ic-action-default);transition:left 0s}:host(.navigation-item-top-nav-child-selected) .link:focus{margin-left:var(--ic-space-xs);margin-right:calc(-1 * var(--ic-space-xs));padding-left:var(--ic-space-xs) !important}:host(.navigation-item-top-nav-child-selected) .link:focus::before{left:calc(-1 * var(--ic-space-xs));z-index:1}:host(.navigation-item-side-menu-selected) .link::before,:host(.navigation-item-side-menu) ::slotted(a.active)::before,:host(.navigation-item-side-menu-selected) .link:focus::before,:host(.navigation-item-side-menu) ::slotted(a.active:focus)::before{z-index:1}:host(.navigation-item-side-menu-selected) .link:focus::before,:host(.navigation-item-side-menu) ::slotted(a.active:focus)::before,:host(.navigation-item-top-nav-child) ::slotted(a.active:focus)::before{left:calc(-1 * var(--ic-space-xs))}:host(.navigation-item-side-menu-selected) .link::after{display:none}:host(.navigation-item-side-nav-collapsed) .link{height:100%}:host(.navigation-item-side-nav-collapsed) ::slotted(svg),:host(.navigation-item-side-nav-collapsed-with-label) ::slotted(svg){margin:auto;pointer-events:none}:host(.navigation-item-side-nav-collapsed) .icon,:host(.navigation-item-side-nav-collapsed-with-label) .icon,:host(.navigation-item-side-nav-collapsed-with-label) ic-typography{align-items:center;padding:0;margin:auto 0;width:-moz-fit-content;width:fit-content;pointer-events:none}:host(.navigation-item-side-nav-collapsed-with-label) ic-typography{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;text-align:center}:host(.navigation-item-side-nav-collapsed-with-label) .link,:host(.navigation-item-side-nav-collapsed-with-label) ::slotted(a){display:flex;flex-direction:column;height:-moz-fit-content;height:fit-content;padding:var(--ic-space-xs) !important;gap:var(--ic-space-xxs)}:host(.navigation-item-side-nav.navigation-item-side-nav-collapsed-with-label) .link,:host(.navigation-item-side-nav.navigation-item-side-nav-collapsed-with-label) ::slotted(a){height:auto !important;gap:0}:host(.navigation-item-side-nav.navigation-item-side-nav-collapsed-with-label) ::slotted(a){display:block;text-align:center}:host(.navigation-item-side-nav.navigation-item-side-nav-collapsed-with-label) .link ic-typography{opacity:1}:host(.navigation-item-side-nav-collapsed) svg,:host(.navigation-item-side-nav-collapsed-with-label) svg{display:none}::slotted(svg){fill:var(--ic-theme-text);width:var(--ic-space-lg);margin-left:var(--ic-space-md)}.icon{height:var(--ic-space-lg);width:var(--ic-space-xxl);margin-left:calc(-1 * var(--ic-space-md));flex:0 1 0%}.icon>::slotted(*){margin-left:var(--ic-space-md) !important}:host(.navigation-item-side-nav-collapsed) .icon>::slotted(*){margin:auto !important}:host(.navigation-item-side-nav) .link,:host(.navigation-item-side-nav) ::slotted(a){height:var(--navigation-item-height);width:var(--navigation-item-width);justify-content:var(--navigation-item-justify-content);display:flex;gap:var(--ic-space-xs);box-sizing:border-box;color:var(--navigation-item-child-color) !important;text-decoration:none !important;white-space:nowrap;padding:0 var(--ic-space-md)}:host(.navigation-item-side-nav.navigation-item-top-nav-child) .link,:host(.navigation-item-side-nav.navigation-item-top-nav-child) ::slotted(a){height:var(--navigation-item-child-height);width:var(--navigation-group-width);color:var(--navigation-item-child-color) !important;display:flex;gap:0.625rem;box-sizing:border-box;min-width:0;transition:box-shadow var(--ic-easing-transition-fast);text-decoration:none !important;white-space:nowrap}:host(.navigation-item-side-nav.navigation-item-top-nav-child) .link:focus,:host(.navigation-item-side-nav.navigation-item-top-nav-child) ::slotted(a:focus){box-shadow:var(--ic-border-focus-dark)}:host(.navigation-item-side-nav.navigation-item-side-menu) .link:active{background-color:var(--navigation-item-child-active)}:host(.navigation-item-side-nav.navigation-item-top-nav-child) .link:active,:host(.navigation-item-side-nav.navigation-item-top-nav-child) ::slotted(a:active){background-color:var(--navigation-item-child-active)}:host(.navigation-item-side-nav) a.link ic-typography,:host(.navigation-item-side-nav.navigation-item-top-nav-child) a.link ic-typography,:host(.navigation-item-side-nav) div.link ic-typography,:host(.navigation-item-side-nav.navigation-item-top-nav-child) div.link ic-typography,.navigation-item-side-nav-slotted-text{opacity:var(--navigation-item-label-opacity);transition:opacity var(--ic-easing-transition-slow);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}:host(.navigation-item-side-nav.navigation-item-selected) .link,:host(.navigation-item-side-nav.navigation-item) ::slotted(a.active){box-shadow:inset 0.313rem 0 0 var(--ic-theme-text)}:host(.navigation-item-side-nav.navigation-item-selected) .link::before,:host(.navigation-item-side-nav) ::slotted(a.active)::before{content:"";display:block;position:absolute;inset:0 0 0 0.313rem;border-radius:0.688rem !important;transition:var(--ic-easing-transition-slow)}:host(.navigation-item-side-nav.navigation-item-selected) .link:focus::before,:host(.navigation-item-side-nav) ::slotted(a.active:focus)::before{box-shadow:var(--ic-border-focus-inset)}:host(:not(.navigation-item-side-nav-collapsed).navigation-item-side-nav.navigation-item-side-nav-collapsed-with-label) .link{opacity:var(--navigation-item-label-opacity);height:auto}:host(.navigation-item-top-nav-child.navigation-item-side-nav-collapsed-with-label) .link,:host(.navigation-item-top-nav-child.navigation-item-side-nav-collapsed-with-label) ::slotted(a){min-width:var(--navigation-group-item-min-width);padding:var(--ic-space-xs) !important;height:auto;gap:0}:host(.navigation-item-top-nav-child.navigation-item-side-nav-collapsed-with-label) ::slotted(a){display:block}:host(.navigation-item-side-nav.navigation-item-selected) .link::after,:host(.navigation-item-side-nav) ::slotted(a.active)::after{display:none}:host(.navigation-item-side-nav.navigation-item) .link:focus,:host(.navigation-item-side-nav.navigation-item) ::slotted(a:focus){box-shadow:var(--ic-border-focus-inset);border-radius:var(--ic-border-radius-inset);background-color:transparent}:host(.navigation-item-side-nav.navigation-item-selected) .link:focus,:host(.navigation-item-side-nav) ::slotted(a.active:focus){margin:0 auto;box-shadow:inset 0.313rem 0 0 var(--ic-theme-text);border-radius:0}:host(.navigation-item-side-nav.navigation-item) .link:hover:not(:focus){background-color:var(--ic-theme-hover) !important}:host(.navigation-item-page-header).link,:host(.navigation-item-page-header) a,:host(.navigation-item-page-header) ::slotted(a){height:2.5rem !important;color:var(--ic-color-primary-text) !important;transition:all var(--ic-easing-transition-fast) !important;box-shadow:rgba(23 89 188 / 0%) !important}:host(.navigation-item-page-header.navigation-item-selected) .link::after,:host(.navigation-item-page-header) ::slotted(a.active)::after{content:" " !important;position:absolute;bottom:0;left:0;right:0;height:var(--ic-space-xxs);background-color:var(--ic-action-default) !important}:host(.navigation-item-page-header) .link:hover,:host(.navigation-item-page-header) ::slotted(.link:hover),:host(.navigation-item-page-header) ::slotted(a:hover),:host(.navigation-item-page-header) .link:hover:not(:focus){background-color:var(--ic-action-default-bg-hover) !important;cursor:pointer}:host(.navigation-item-page-header) .link:focus,:host(.navigation-item-page-header) ::slotted(a:focus){box-shadow:var(--ic-border-focus)}:host(.navigation-item-page-header) .link:active,:host(.navigation-item-page-header) ::slotted(a:active){background-color:var(--ic-action-default-bg-active) !important}:host(.navigation-item-page-header.navigation-item-selected) .link:focus::after,:host(.navigation-item-page-header) ::slotted(a.active:focus)::after{border-bottom-left-radius:var(--ic-border-radius);border-bottom-right-radius:var(--ic-border-radius)}:host(.navigation-item-page-header.navigation-item-selected.with-transition) .link,:host(.navigation-item-page-header.navigation-item-selected.with-transition) ::slotted(a.active){transition:all var(--ic-easing-transition-fast),\n border-color var(--ic-transition-duration-fast)}:host(.navigation-item-page-header) ::slotted(a.active)::before,:host(.navigation-item-page-header) ::slotted(a.active:focus)::before,:host(.navigation-item-page-header.navigation-item-selected) .link:focus::before{display:none}.open-in-new-icon{flex:1}.open-in-new-icon svg{margin-top:var(--ic-space-xxs);padding-left:var(--ic-space-xxs)}:host(.navigation-item-side-nav) .open-in-new-icon{margin-left:calc(-1 * var(--ic-space-xs))}:host(.navigation-item-top-nav) .open-in-new-icon svg,:host(.navigation-item-page-header) .open-in-new-icon svg,:host(.navigation-item-side-nav) .open-in-new-icon svg{height:0.875rem;width:0.875rem}:host(.navigation-item-side-menu) .open-in-new-icon svg,:host(.navigation-item-top-nav-child) .open-in-new-icon svg{height:var(--ic-space-md);width:var(--ic-space-md)}:host(.navigation-item-page-header) .open-in-new-icon svg,:host(.navigation-item-top-nav-child) .open-in-new-icon svg,:host(.navigation-item-side-menu) .open-in-new-icon svg{fill:var(--ic-color-primary-text)}';const g=class{constructor(a){i(this,a);this.childBlur=t(this,"childBlur",7);this.navItemClicked=t(this,"navItemClicked",7);this.isInitialRender=true;this.displayDefaultNavigationItem=(i,t,a,o,n,s,r)=>{const d=this.isTopNavChild||this.inTopNavSideMenu?"body":"label";const c="ic-tooltip-navigation-item";const h=this.expandable&&e("div",{class:{svg:true},innerHTML:l});const g=this.el.querySelector('[slot="icon"]')&&e("div",{class:"icon"}," ",e("slot",{name:"icon"})," ");if(i!==""){return e("a",{href:i,target:a,rel:o,hreflang:t,referrerPolicy:n,download:s!==false?s:null,class:"link",ref:i=>this.itemEl=i,part:"link","aria-labelledby":c},g,e("ic-typography",{variant:d},r),h,a==="_blank"&&e("span",{class:"open-in-new-icon",innerHTML:v}))}return e("div",{tabindex:"0",class:"link",ref:i=>this.itemEl=i,"aria-labelledby":c},g,e("ic-typography",{variant:d},r),h)};this.topNavResizedHandler=i=>{const t=i.detail.size;if(t!==this.deviceSize){this.deviceSize=t;this.inTopNavSideMenu=t<=n.L}};this.sideNavExpandHandler=i=>{const{sideNavExpanded:t,sideNavMobile:e}=i.detail;this.sideNavExpanded=t;this.isSideNavMobile=e};this.handleBlur=i=>{if(i.relatedTarget!==null){const t=i.relatedTarget;if(t.tagName==="IC-NAVIGATION-ITEM"){return}}this.childBlur.emit()};this.handleClick=()=>{this.navItemClicked.emit()};this.deviceSize=n.XL;this.focusStyle=s();this.inTopNavSideMenu=false;this.isSideNavMobile=false;this.isTopNavChild=false;this.navigationType=undefined;this.parentEl=undefined;this.sideNavExpanded=false;this.collapsedIconLabel=false;this.displayNavigationTooltip=false;this.download=false;this.expandable=false;this.href="";this.hreflang=undefined;this.label=undefined;this.rel=undefined;this.referrerpolicy=undefined;this.selected=false;this.target=undefined}disconnectedCallback(){if(this.navigationType==="side"){this.parentEl.removeEventListener("sideNavExpanded",this.sideNavExpandHandler)}else if(this.navigationType==="top"){this.parentEl.removeEventListener("topNavResized",this.topNavResizedHandler)}}componentWillLoad(){const i=c(this.el);this.navigationType=i.navType;this.parentEl=i.parent;if(this.navigationType==="side"){this.parentEl.addEventListener("sideNavExpanded",this.sideNavExpandHandler)}else if(this.navigationType==="top"){this.parentEl.addEventListener("topNavResized",this.topNavResizedHandler)}if(r(this.el)==="IC-NAVIGATION-GROUP"&&this.navigationType==="top"){this.isTopNavChild=true}this.deviceSize=d();if(this.deviceSize<=n.L&&this.navigationType==="top"){this.inTopNavSideMenu=true}this.navigationSlot=this.el.querySelector('[slot="navigation-item"]');if(this.navigationSlot){this.navigationSlot.ariaLabel=this.navigationSlot.textContent.trim()}}componentDidUpdate(){this.isInitialRender=false}themeChangeHandler(i){const t=i.detail;this.focusStyle=t.mode}async setFocus(){if(this.itemEl){this.itemEl.focus()}}render(){const{href:i,hreflang:t,target:o,rel:n,referrerpolicy:s,download:r,label:d,inTopNavSideMenu:c,isTopNavChild:l,selected:v,navigationSlot:h}=this;return e(a,{class:{["navigation-item"]:true,["navigation-item-top-nav"]:!c&&this.navigationType==="top",["navigation-item-top-nav-child-selected"]:l&&!c&&v,[this.focusStyle]:!c&&!l||this.navigationType==="side"&&l,["navigation-item-selected"]:!l&&v,["navigation-item-side-menu"]:c,["navigation-item-side-menu-selected"]:c&&v,["navigation-item-top-nav-child"]:l&&!c,["navigation-item-page-header"]:this.navigationType==="page-header",["with-transition"]:!this.isInitialRender,["navigation-item-side-nav"]:this.navigationType==="side",["navigation-item-side-nav-collapsed"]:(!this.sideNavExpanded||this.displayNavigationTooltip)&&this.navigationType==="side",["navigation-item-side-nav-collapsed-with-label"]:!this.sideNavExpanded&&this.navigationType==="side"&&this.collapsedIconLabel&&!this.isSideNavMobile,["expandable"]:this.expandable},onBlur:l&&!c?this.handleBlur:null,onClick:this.handleClick,"aria-current":v?"page":null,role:"listitem"},e("ic-tooltip",{label:d||h.textContent,target:"navigation-item",placement:"right",class:{["tooltip-navigation-item"]:true,["tooltip-navigation-item-side-nav-collapsed"]:(!this.sideNavExpanded||this.displayNavigationTooltip)&&this.navigationType==="side",["tooltip-long-label-navigation-item-side-nav-expanded"]:this.el.hasAttribute("[display-navigation-tooltip = 'true']")}},h?e("slot",{name:"navigation-item"}):this.displayDefaultNavigationItem(i,t,o,n,s,r,d)))}static get delegatesFocus(){return true}get el(){return o(this)}};g.style=h;export{g as ic_navigation_item};
2
+ //# sourceMappingURL=p-26d5fd0f.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icNavigationItemCss","NavigationItem","this","isInitialRender","displayDefaultNavigationItem","href","hreflang","target","rel","referrerpolicy","download","label","variant","isTopNavChild","inTopNavSideMenu","tooltipId","ChevronIconComponent","expandable","h","class","svg","innerHTML","chevronIcon","IconComponent","el","querySelector","name","referrerPolicy","ref","itemEl","part","OpenInNew","tabindex","topNavResizedHandler","ev","newSize","detail","size","deviceSize","DEVICE_SIZES","L","sideNavExpandHandler","sideNavExpanded","sideNavMobile","isSideNavMobile","handleBlur","relatedTarget","tagName","childBlur","emit","handleClick","navItemClicked","XL","getThemeForegroundColor","disconnectedCallback","navigationType","parentEl","removeEventListener","componentWillLoad","navParentDetails","getNavItemParentDetails","navType","parent","addEventListener","getParentElementType","getCurrentDeviceSize","navigationSlot","ariaLabel","textContent","trim","componentDidUpdate","themeChangeHandler","theme","focusStyle","mode","async","focus","render","selected","Host","displayNavigationTooltip","collapsedIconLabel","onBlur","onClick","role","placement","hasAttribute"],"sources":["./src/components/ic-navigation-item/ic-navigation-item.css?tag=ic-navigation-item&encapsulation=shadow","./src/components/ic-navigation-item/ic-navigation-item.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n/**\n * @prop --ic-z-index-navigation-item: z-index of navigation item\n */\n\n:host {\n display: block;\n}\n\n:host(:focus-within) {\n z-index: var(--ic-z-index-navigation-item);\n}\n\n/* chevron */\nsvg {\n width: var(--ic-space-xl);\n fill: var(--ic-theme-text);\n}\n\n.svg {\n margin-left: auto;\n}\n\n:host(.expandable.navigation-item) .link,\n:host(.expandable.navigation-item) ::slotted(a) {\n padding-right: 0;\n}\n\n:host(.navigation-item) .link,\n:host(.navigation-item) ::slotted(a) {\n height: calc(100% - var(--ic-space-xxs));\n width: fit-content;\n color: var(--ic-theme-text);\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 0 var(--ic-space-md) var(--ic-space-xxs);\n text-decoration: none;\n transition: var(--ic-easing-transition-fast);\n position: relative;\n white-space: nowrap;\n}\n\n:host(.navigation-item) ::slotted(a) {\n height: 100%;\n font: var(--ic-font-label) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt025) !important;\n padding: 0 var(--ic-space-md) !important;\n}\n\n:host(.navigation-item-selected) .link::after,\n:host(.navigation-item-selected) ::slotted(a.active)::after,\n:host(.navigation-item-top-nav) ::slotted(a.active)::after {\n content: \"\";\n height: 0.25rem;\n width: 100%;\n position: absolute;\n bottom: 0;\n background-color: var(--ic-theme-text);\n}\n\n:host(.navigation-item-selected.navigation-item-page-header)\n ::slotted(a.active)::after,\n:host(.navigation-item-selected.navigation-item-page-header) .link::after,\n:host(.navigation-item.navigation-item-page-header) ::slotted(a.active)::after,\n:host(.navigation-item-top-nav-child) ::slotted(a.active)::after {\n content: none;\n}\n\n:host(.navigation-item-side-menu-selected) .link,\n:host(.navigation-item-side-menu) ::slotted(a.active),\n:host(.navigation-item-top-nav-child) ::slotted(a.active) {\n box-shadow: none;\n}\n\n:host(.navigation-item) .link:hover:not(:focus) {\n background-color: var(--ic-theme-hover);\n cursor: pointer;\n}\n\n:host(.navigation-item:not(.navigation-item-page-header, .navigation-item-side-menu))\n ::slotted(a:hover:not(:focus)) {\n background-color: var(--ic-theme-hover) !important;\n}\n\n:host(.navigation-item:not(.navigation-item-top-nav-child, .navigation-item-side-menu, .navigation-item-top-nav-child-selected\n .navigation-item-side-menu-selected))\n .focus-indicator:focus-within {\n box-shadow: var(--ic-border-focus);\n border-radius: var(--ic-border-radius);\n}\n\n:host(.navigation-item) .link:focus,\n:host(.navigation-item) ::slotted(a:focus) {\n box-shadow: var(--ic-border-focus);\n border-radius: var(--ic-border-radius);\n outline: var(--ic-hc-focus-outline);\n}\n\n:host(.navigation-item-selected) .link:focus,\n:host(.navigation-item) ::slotted(a.active:focus) {\n box-shadow: var(--ic-border-focus);\n border-radius: var(--ic-border-radius);\n outline: var(--ic-hc-focus-outline);\n}\n\n:host(.navigation-item-selected.dark) .link:focus,\n:host(.navigation-item.dark) ::slotted(a.active:focus) {\n box-shadow: var(--ic-border-focus);\n border-radius: var(--ic-border-radius);\n outline: var(--ic-hc-focus-outline);\n}\n\n:host(.navigation-item) .link:active:not(:focus),\n:host(.navigation-item) ::slotted(a:active:not(:focus)) {\n background-color: var(--ic-theme-active);\n}\n\n:host(.navigation-item-side-menu) .link,\n:host(.navigation-item-side-menu) ::slotted(a) {\n height: 2.5rem;\n width: 100%;\n box-sizing: border-box;\n color: var(--ic-color-primary-text);\n display: flex;\n align-items: center;\n justify-content: flex-start;\n text-decoration: none;\n transition: box-shadow var(--ic-transition-duration-fast),\n border-radius var(--ic-transition-duration-fast);\n}\n\n:host(.navigation-item-side-menu) ::slotted(a) {\n font: var(--ic-font-body) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt005) !important;\n transition: box-shadow var(--ic-easing-transition-fast),\n background-color var(--ic-easing-transition-fast);\n}\n\n:host(.navigation-item-side-menu) .link:hover:not(:focus) {\n background-color: var(--ic-action-dark-bg-hover);\n}\n\n:host(.navigation-item-side-menu) ::slotted(a:hover:not(:focus)) {\n background-color: var(--ic-action-dark-bg-hover) !important;\n}\n\n:host(.navigation-item-side-menu) .focus-indicator:focus-within {\n box-shadow: none;\n}\n\n:host(.navigation-item-side-menu) .link:focus,\n:host(.navigation-item-side-menu) ::slotted(a:focus) {\n box-shadow: var(--ic-border-focus-inset) !important;\n padding-right: var(--ic-space-lg);\n width: auto;\n border-radius: var(--ic-border-radius-inset) !important;\n}\n\n:host(.navigation-item-side-menu-selected) .link,\n:host(.navigation-item-side-menu-selected) ::slotted(a) {\n transition: box-shadow var(--ic-easing-transition-slow),\n background-color var(--ic-easing-transition-slow);\n}\n\n:host(.navigation-item-side-menu-selected) .link:focus,\n:host(.navigation-item-side-menu) ::slotted(a.active:focus),\n:host(.navigation-item-top-nav-child) ::slotted(a.active:focus) {\n margin-left: var(--ic-space-xs) !important;\n padding-left: var(--ic-space-xs) !important;\n}\n\n:host(.navigation-item-top-nav-child) .link,\n:host(.navigation-item-top-nav-child) ::slotted(a) {\n height: 2.5rem;\n width: fit-content;\n min-width: 9.063rem;\n color: var(--ic-color-primary-text);\n display: flex;\n align-items: center;\n justify-content: flex-start;\n padding: 0 var(--ic-space-md) !important;\n text-decoration: none;\n position: relative;\n transition: box-shadow var(--ic-transition-duration-fast),\n border-radius var(--ic-transition-duration-slow);\n}\n\n:host(.navigation-item-top-nav-child) ::slotted(a) {\n font: var(--ic-font-body) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt005) !important;\n}\n\n:host(.navigation-item-top-nav-child) .link:hover:not(:focus) {\n background-color: var(--ic-action-dark-bg-hover) !important;\n}\n\n:host(.navigation-item-top-nav-child) ::slotted(a:hover):not(:focus) {\n background-color: var(--ic-action-dark-bg-hover) !important;\n}\n\n:host(.navigation-item-top-nav-child) .link:focus,\n:host(.navigation-item-top-nav-child) ::slotted(a:focus) {\n z-index: 1;\n outline: var(--ic-hc-focus-outline);\n border-radius: var(--ic-border-radius-inset);\n box-shadow: var(--ic-border-focus-inset);\n transition: border-radius 0s, box-shadow var(--ic-transition-duration-fast);\n}\n\n:host(.navigation-item-top-nav-child) ::slotted(a.active:focus) {\n box-shadow: var(--ic-border-focus-inset);\n border-radius: var(--ic-border-radius-inset);\n}\n\n:host(.navigation-item-side-menu) .link:active:not(:focus) {\n background-color: var(--ic-action-dark-bg-active);\n}\n\n:host(.navigation-item-top-nav-child) .link:active:not(:focus),\n:host(.navigation-item-top-nav-child) ::slotted(a:active):not(:focus) {\n outline: var(--ic-hc-focus-outline);\n background-color: var(--ic-action-dark-bg-active);\n}\n\n:host(.navigation-item-top-nav-child) ::slotted(a:active):not(:focus),\n:host(.navigation-item-side-menu) ::slotted(a:active):not(:focus) {\n background-color: var(--ic-action-dark-bg-active) !important;\n}\n\n:host(.navigation-item-side-menu-selected) *,\n:host(.navigation-item-top-nav-child-selected) *,\n:host(.navigation-item-side-menu) ::slotted(a.active),\n:host(.navigation-item-top-nav-child) ::slotted(a.active) {\n font-weight: 700 !important;\n}\n\n:host(.navigation-item-top-nav-child) ::slotted(a.active)::before,\n:host(.navigation-item-top-nav-child-selected) .link::before,\n:host(.navigation-item-side-menu-selected) .link::before,\n:host(.navigation-item-side-menu) ::slotted(a.active)::before,\n:host(.navigation-item-side-menu-selected) .link:focus::before,\n:host(.navigation-item-side-menu) ::slotted(a.active:focus)::before {\n content: \"\";\n position: absolute;\n left: 0;\n width: var(--ic-space-xs);\n height: 2.5rem;\n margin-top: 0.25rem;\n margin-right: 0.313rem;\n background-color: var(--ic-action-default);\n transition: left 0s;\n}\n\n:host(.navigation-item-top-nav-child-selected) .link:focus {\n margin-left: var(--ic-space-xs);\n margin-right: calc(-1 * var(--ic-space-xs));\n padding-left: var(--ic-space-xs) !important;\n}\n\n:host(.navigation-item-top-nav-child-selected) .link:focus::before {\n left: calc(-1 * var(--ic-space-xs));\n z-index: 1;\n}\n\n:host(.navigation-item-side-menu-selected) .link::before,\n:host(.navigation-item-side-menu) ::slotted(a.active)::before,\n:host(.navigation-item-side-menu-selected) .link:focus::before,\n:host(.navigation-item-side-menu) ::slotted(a.active:focus)::before {\n z-index: 1;\n}\n\n:host(.navigation-item-side-menu-selected) .link:focus::before,\n:host(.navigation-item-side-menu) ::slotted(a.active:focus)::before,\n:host(.navigation-item-top-nav-child) ::slotted(a.active:focus)::before {\n left: calc(-1 * var(--ic-space-xs));\n}\n\n:host(.navigation-item-side-menu-selected) .link::after {\n display: none;\n}\n\n:host(.navigation-item-side-nav-collapsed) .link {\n height: 100%;\n}\n\n:host(.navigation-item-side-nav-collapsed) ::slotted(svg),\n:host(.navigation-item-side-nav-collapsed-with-label) ::slotted(svg) {\n margin: auto;\n pointer-events: none;\n}\n\n:host(.navigation-item-side-nav-collapsed) .icon,\n:host(.navigation-item-side-nav-collapsed-with-label) .icon,\n:host(.navigation-item-side-nav-collapsed-with-label) ic-typography {\n align-items: center;\n padding: 0;\n margin: auto 0;\n width: fit-content;\n pointer-events: none;\n}\n\n:host(.navigation-item-side-nav-collapsed-with-label) ic-typography {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n width: 100%;\n text-align: center;\n}\n\n:host(.navigation-item-side-nav-collapsed-with-label) .link,\n:host(.navigation-item-side-nav-collapsed-with-label) ::slotted(a) {\n display: flex;\n flex-direction: column;\n height: fit-content;\n padding: var(--ic-space-xs) !important;\n gap: var(--ic-space-xxs);\n}\n\n:host(.navigation-item-side-nav.navigation-item-side-nav-collapsed-with-label)\n .link,\n:host(.navigation-item-side-nav.navigation-item-side-nav-collapsed-with-label)\n ::slotted(a) {\n height: auto !important;\n gap: 0;\n}\n\n:host(.navigation-item-side-nav.navigation-item-side-nav-collapsed-with-label)\n ::slotted(a) {\n display: block;\n text-align: center;\n}\n\n:host(.navigation-item-side-nav.navigation-item-side-nav-collapsed-with-label)\n .link\n ic-typography {\n opacity: 1;\n}\n\n:host(.navigation-item-side-nav-collapsed) svg,\n:host(.navigation-item-side-nav-collapsed-with-label) svg {\n display: none;\n}\n\n::slotted(svg) {\n fill: var(--ic-theme-text);\n width: var(--ic-space-lg);\n margin-left: var(--ic-space-md);\n}\n\n.icon {\n height: var(--ic-space-lg);\n width: var(--ic-space-xxl);\n margin-left: calc(-1 * var(--ic-space-md));\n flex: 0 1 0%;\n}\n\n.icon > ::slotted(*) {\n margin-left: var(--ic-space-md) !important;\n}\n\n:host(.navigation-item-side-nav-collapsed) .icon > ::slotted(*) {\n margin: auto !important;\n}\n\n:host(.navigation-item-side-nav) .link,\n:host(.navigation-item-side-nav) ::slotted(a) {\n height: var(--navigation-item-height);\n width: var(--navigation-item-width);\n justify-content: var(--navigation-item-justify-content);\n display: flex;\n gap: var(--ic-space-xs);\n box-sizing: border-box;\n color: var(--navigation-item-child-color) !important;\n text-decoration: none !important;\n white-space: nowrap;\n padding: 0 var(--ic-space-md);\n}\n\n:host(.navigation-item-side-nav.navigation-item-top-nav-child) .link,\n:host(.navigation-item-side-nav.navigation-item-top-nav-child) ::slotted(a) {\n height: var(--navigation-item-child-height);\n width: var(--navigation-group-width);\n color: var(--navigation-item-child-color) !important;\n display: flex;\n gap: 0.625rem;\n box-sizing: border-box;\n min-width: 0;\n transition: box-shadow var(--ic-easing-transition-fast);\n text-decoration: none !important;\n white-space: nowrap;\n}\n\n:host(.navigation-item-side-nav.navigation-item-top-nav-child) .link:focus,\n:host(.navigation-item-side-nav.navigation-item-top-nav-child)\n ::slotted(a:focus) {\n box-shadow: var(--ic-border-focus-dark);\n}\n\n:host(.navigation-item-side-nav.navigation-item-side-menu) .link:active {\n background-color: var(--navigation-item-child-active);\n}\n\n:host(.navigation-item-side-nav.navigation-item-top-nav-child) .link:active,\n:host(.navigation-item-side-nav.navigation-item-top-nav-child)\n ::slotted(a:active) {\n background-color: var(--navigation-item-child-active);\n}\n\n:host(.navigation-item-side-nav) a.link ic-typography,\n:host(.navigation-item-side-nav.navigation-item-top-nav-child)\n a.link\n ic-typography,\n:host(.navigation-item-side-nav) div.link ic-typography,\n:host(.navigation-item-side-nav.navigation-item-top-nav-child)\n div.link\n ic-typography,\n.navigation-item-side-nav-slotted-text {\n opacity: var(--navigation-item-label-opacity);\n transition: opacity var(--ic-easing-transition-slow);\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n\n:host(.navigation-item-side-nav.navigation-item-selected) .link,\n:host(.navigation-item-side-nav.navigation-item) ::slotted(a.active) {\n box-shadow: inset 0.313rem 0 0 var(--ic-theme-text);\n}\n\n:host(.navigation-item-side-nav.navigation-item-selected) .link::before,\n:host(.navigation-item-side-nav) ::slotted(a.active)::before {\n content: \"\";\n display: block;\n position: absolute;\n inset: 0 0 0 0.313rem;\n border-radius: 0.688rem !important;\n transition: var(--ic-easing-transition-slow);\n}\n\n:host(.navigation-item-side-nav.navigation-item-selected) .link:focus::before,\n:host(.navigation-item-side-nav) ::slotted(a.active:focus)::before {\n box-shadow: var(--ic-border-focus-inset);\n}\n\n:host(:not(.navigation-item-side-nav-collapsed).navigation-item-side-nav.navigation-item-side-nav-collapsed-with-label)\n .link {\n opacity: var(--navigation-item-label-opacity);\n height: auto;\n}\n\n:host(.navigation-item-top-nav-child.navigation-item-side-nav-collapsed-with-label)\n .link,\n:host(.navigation-item-top-nav-child.navigation-item-side-nav-collapsed-with-label)\n ::slotted(a) {\n min-width: var(--navigation-group-item-min-width);\n padding: var(--ic-space-xs) !important;\n height: auto;\n gap: 0;\n}\n\n:host(.navigation-item-top-nav-child.navigation-item-side-nav-collapsed-with-label)\n ::slotted(a) {\n display: block;\n}\n\n:host(.navigation-item-side-nav.navigation-item-selected) .link::after,\n:host(.navigation-item-side-nav) ::slotted(a.active)::after {\n display: none;\n}\n\n:host(.navigation-item-side-nav.navigation-item) .link:focus,\n:host(.navigation-item-side-nav.navigation-item) ::slotted(a:focus) {\n box-shadow: var(--ic-border-focus-inset);\n border-radius: var(--ic-border-radius-inset);\n background-color: transparent;\n}\n\n:host(.navigation-item-side-nav.navigation-item-selected) .link:focus,\n:host(.navigation-item-side-nav) ::slotted(a.active:focus) {\n margin: 0 auto;\n box-shadow: inset 0.313rem 0 0 var(--ic-theme-text);\n border-radius: 0;\n}\n\n:host(.navigation-item-side-nav.navigation-item) .link:hover:not(:focus) {\n background-color: var(--ic-theme-hover) !important;\n}\n\n:host(.navigation-item-page-header).link,\n:host(.navigation-item-page-header) a,\n:host(.navigation-item-page-header) ::slotted(a) {\n height: 2.5rem !important;\n color: var(--ic-color-primary-text) !important;\n transition: all var(--ic-easing-transition-fast) !important;\n box-shadow: rgba(23 89 188 / 0%) !important;\n}\n\n:host(.navigation-item-page-header.navigation-item-selected) .link::after,\n:host(.navigation-item-page-header) ::slotted(a.active)::after {\n content: \" \" !important;\n position: absolute;\n bottom: 0;\n left: 0;\n right: 0;\n height: var(--ic-space-xxs);\n background-color: var(--ic-action-default) !important;\n}\n\n:host(.navigation-item-page-header) .link:hover,\n:host(.navigation-item-page-header) ::slotted(.link:hover),\n:host(.navigation-item-page-header) ::slotted(a:hover),\n:host(.navigation-item-page-header) .link:hover:not(:focus) {\n background-color: var(--ic-action-default-bg-hover) !important;\n cursor: pointer;\n}\n\n:host(.navigation-item-page-header) .link:focus,\n:host(.navigation-item-page-header) ::slotted(a:focus) {\n box-shadow: var(--ic-border-focus);\n}\n\n:host(.navigation-item-page-header) .link:active,\n:host(.navigation-item-page-header) ::slotted(a:active) {\n background-color: var(--ic-action-default-bg-active) !important;\n}\n\n:host(.navigation-item-page-header.navigation-item-selected) .link:focus::after,\n:host(.navigation-item-page-header) ::slotted(a.active:focus)::after {\n border-bottom-left-radius: var(--ic-border-radius);\n border-bottom-right-radius: var(--ic-border-radius);\n}\n\n:host(.navigation-item-page-header.navigation-item-selected.with-transition)\n .link,\n:host(.navigation-item-page-header.navigation-item-selected.with-transition)\n ::slotted(a.active) {\n transition: all var(--ic-easing-transition-fast),\n border-color var(--ic-transition-duration-fast);\n}\n\n:host(.navigation-item-page-header) ::slotted(a.active)::before,\n:host(.navigation-item-page-header) ::slotted(a.active:focus)::before,\n:host(.navigation-item-page-header.navigation-item-selected)\n .link:focus::before {\n display: none;\n}\n\n.open-in-new-icon {\n flex: 1;\n}\n\n.open-in-new-icon svg {\n margin-top: var(--ic-space-xxs);\n padding-left: var(--ic-space-xxs);\n}\n\n:host(.navigation-item-side-nav) .open-in-new-icon {\n margin-left: calc(-1 * var(--ic-space-xs));\n}\n\n:host(.navigation-item-top-nav) .open-in-new-icon svg,\n:host(.navigation-item-page-header) .open-in-new-icon svg,\n:host(.navigation-item-side-nav) .open-in-new-icon svg {\n height: 0.875rem;\n width: 0.875rem;\n}\n\n:host(.navigation-item-side-menu) .open-in-new-icon svg,\n:host(.navigation-item-top-nav-child) .open-in-new-icon svg {\n height: var(--ic-space-md);\n width: var(--ic-space-md);\n}\n\n:host(.navigation-item-page-header) .open-in-new-icon svg,\n:host(.navigation-item-top-nav-child) .open-in-new-icon svg,\n:host(.navigation-item-side-menu) .open-in-new-icon svg {\n fill: var(--ic-color-primary-text);\n}\n","import {\n Component,\n Element,\n Event,\n EventEmitter,\n Listen,\n Method,\n h,\n Host,\n Prop,\n State,\n} from \"@stencil/core\";\n\nimport {\n DEVICE_SIZES,\n getCurrentDeviceSize,\n getThemeForegroundColor,\n getParentElementType,\n getNavItemParentDetails,\n} from \"../../utils/helpers\";\nimport { IcNavType, IcTheme } from \"../../utils/types\";\n\nimport chevronIcon from \"../../assets/chevron-icon.svg\";\n\nimport OpenInNew from \"../../assets/OpenInNew.svg\";\n\n/**\n * @part link - The `<a>` within ic-navigation-item\n */\n\n@Component({\n tag: \"ic-navigation-item\",\n styleUrl: \"ic-navigation-item.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class NavigationItem {\n private navigationSlot: HTMLElement;\n private isInitialRender: boolean = true;\n private itemEl: HTMLElement;\n\n @Element() el: HTMLIcNavigationItemElement;\n\n @State() deviceSize: number = DEVICE_SIZES.XL;\n @State() focusStyle = getThemeForegroundColor();\n @State() inTopNavSideMenu: boolean = false;\n @State() isSideNavMobile: boolean = false;\n @State() isTopNavChild: boolean = false;\n @State() navigationType: IcNavType | \"\";\n @State() parentEl: HTMLElement;\n @State() sideNavExpanded: boolean = false;\n\n /**\n * @internal If `true`, the icon and label will be displayed when side navigation is collapsed.\n */\n @Prop() collapsedIconLabel: boolean = false;\n\n /**\n * @internal If `true`, the navigation item will be displayed within a tooltip.\n */\n @Prop() displayNavigationTooltip: boolean = false;\n\n /**\n * If `true`, the user can save the linked URL instead of navigating to it.\n */\n @Prop() download?: string | boolean = false;\n\n /**\n * @internal If `true`, the navigation item will be expandable.\n */\n @Prop() expandable: boolean = false;\n\n /**\n * The destination of the navigation item.\n */\n @Prop() href: string = \"\";\n\n /**\n * The human language of the linked URL.\n */\n @Prop() hreflang?: string;\n\n /**\n * The label of the navigation item.\n */\n @Prop() label: string;\n\n /**\n * The relationship of the linked URL as space-separated link types.\n */\n @Prop() rel?: string;\n\n /**\n * How much of the referrer to send when following the link.\n */\n @Prop() referrerpolicy?: ReferrerPolicy;\n\n /**\n * If `true`, the navigation item will be set in a selected state.\n */\n @Prop() selected: boolean = false;\n\n /**\n * The place to display the linked URL, as the name for a browsing context (a tab, window, or iframe).\n */\n @Prop() target?: string;\n\n /**\n * @internal - Emitted when item loses focus.\n */\n @Event() childBlur: EventEmitter<void>;\n\n /**\n * @internal - Emitted when navigation item clicked.\n */\n @Event() navItemClicked: EventEmitter<void>;\n\n disconnectedCallback(): void {\n if (this.navigationType === \"side\") {\n this.parentEl.removeEventListener(\n \"sideNavExpanded\",\n this.sideNavExpandHandler\n );\n } else if (this.navigationType === \"top\") {\n this.parentEl.removeEventListener(\n \"topNavResized\",\n this.topNavResizedHandler\n );\n }\n }\n\n componentWillLoad(): void {\n const navParentDetails = getNavItemParentDetails(this.el);\n this.navigationType = navParentDetails.navType;\n this.parentEl = navParentDetails.parent;\n\n if (this.navigationType === \"side\") {\n this.parentEl.addEventListener(\n \"sideNavExpanded\",\n this.sideNavExpandHandler\n );\n } else if (this.navigationType === \"top\") {\n this.parentEl.addEventListener(\n \"topNavResized\",\n this.topNavResizedHandler\n );\n }\n\n if (\n getParentElementType(this.el) === \"IC-NAVIGATION-GROUP\" &&\n this.navigationType === \"top\"\n ) {\n this.isTopNavChild = true;\n }\n\n this.deviceSize = getCurrentDeviceSize();\n if (this.deviceSize <= DEVICE_SIZES.L && this.navigationType === \"top\") {\n this.inTopNavSideMenu = true;\n }\n\n this.navigationSlot = this.el.querySelector('[slot=\"navigation-item\"]');\n if (this.navigationSlot) {\n this.navigationSlot.ariaLabel = this.navigationSlot.textContent.trim();\n }\n }\n\n componentDidUpdate(): void {\n this.isInitialRender = false;\n }\n\n @Listen(\"themeChange\", { target: \"document\" })\n themeChangeHandler(ev: CustomEvent): void {\n const theme: IcTheme = ev.detail;\n this.focusStyle = theme.mode;\n }\n\n /**\n * Sets focus on the nav item.\n */\n @Method()\n async setFocus(): Promise<void> {\n if (this.itemEl) {\n this.itemEl.focus();\n }\n }\n\n private displayDefaultNavigationItem = (\n href: string,\n hreflang: string,\n target: string,\n rel: string,\n referrerpolicy: ReferrerPolicy,\n download: string | boolean,\n label: string\n ): HTMLElement => {\n const variant =\n this.isTopNavChild || this.inTopNavSideMenu ? \"body\" : \"label\";\n const tooltipId = \"ic-tooltip-navigation-item\";\n const ChevronIconComponent = this.expandable && (\n <div class={{ svg: true }} innerHTML={chevronIcon}></div>\n );\n const IconComponent = this.el.querySelector('[slot=\"icon\"]') && (\n <div class=\"icon\">\n {\" \"}\n <slot name=\"icon\"></slot>{\" \"}\n </div>\n );\n\n if (href !== \"\") {\n return (\n <a\n href={href}\n target={target}\n rel={rel}\n hreflang={hreflang}\n referrerPolicy={referrerpolicy}\n download={download !== false ? download : null}\n class=\"link\"\n ref={(el) => (this.itemEl = el)}\n part=\"link\"\n aria-labelledby={tooltipId}\n >\n {IconComponent}\n\n <ic-typography variant={variant}>{label}</ic-typography>\n {ChevronIconComponent}\n {target === \"_blank\" && (\n <span class=\"open-in-new-icon\" innerHTML={OpenInNew} />\n )}\n </a>\n );\n }\n\n return (\n <div\n tabindex=\"0\"\n class=\"link\"\n ref={(el) => (this.itemEl = el)}\n aria-labelledby={tooltipId}\n >\n {IconComponent}\n <ic-typography variant={variant}>{label}</ic-typography>\n {ChevronIconComponent}\n </div>\n );\n };\n\n private topNavResizedHandler = (ev: CustomEvent): void => {\n const newSize = ev.detail.size;\n if (newSize !== this.deviceSize) {\n this.deviceSize = newSize;\n this.inTopNavSideMenu = newSize <= DEVICE_SIZES.L;\n }\n };\n\n private sideNavExpandHandler = (ev: CustomEvent): void => {\n const { sideNavExpanded, sideNavMobile } = ev.detail;\n this.sideNavExpanded = sideNavExpanded;\n this.isSideNavMobile = sideNavMobile;\n };\n\n private handleBlur = (ev: FocusEvent) => {\n if (ev.relatedTarget !== null) {\n const target = ev.relatedTarget as HTMLElement;\n if (target.tagName === \"IC-NAVIGATION-ITEM\") {\n return;\n }\n }\n this.childBlur.emit();\n };\n\n private handleClick = () => {\n this.navItemClicked.emit();\n };\n\n render() {\n const {\n href,\n hreflang,\n target,\n rel,\n referrerpolicy,\n download,\n label,\n inTopNavSideMenu,\n isTopNavChild,\n selected,\n navigationSlot,\n } = this;\n\n return (\n <Host\n class={{\n [\"navigation-item\"]: true,\n [\"navigation-item-top-nav\"]:\n !inTopNavSideMenu && this.navigationType === \"top\",\n [\"navigation-item-top-nav-child-selected\"]:\n isTopNavChild && !inTopNavSideMenu && selected,\n [this.focusStyle]:\n (!inTopNavSideMenu && !isTopNavChild) ||\n (this.navigationType === \"side\" && isTopNavChild),\n [\"navigation-item-selected\"]: !isTopNavChild && selected,\n [\"navigation-item-side-menu\"]: inTopNavSideMenu,\n [\"navigation-item-side-menu-selected\"]: inTopNavSideMenu && selected,\n [\"navigation-item-top-nav-child\"]: isTopNavChild && !inTopNavSideMenu,\n [\"navigation-item-page-header\"]:\n this.navigationType === \"page-header\",\n [\"with-transition\"]: !this.isInitialRender,\n [\"navigation-item-side-nav\"]: this.navigationType === \"side\",\n [\"navigation-item-side-nav-collapsed\"]:\n (!this.sideNavExpanded || this.displayNavigationTooltip) &&\n this.navigationType === \"side\",\n [\"navigation-item-side-nav-collapsed-with-label\"]:\n !this.sideNavExpanded &&\n this.navigationType === \"side\" &&\n this.collapsedIconLabel &&\n !this.isSideNavMobile,\n [\"expandable\"]: this.expandable,\n }}\n onBlur={isTopNavChild && !inTopNavSideMenu ? this.handleBlur : null}\n onClick={this.handleClick}\n aria-current={selected ? \"page\" : null}\n role=\"listitem\"\n >\n {/* Tooltip enabled by applying navigation-item-side-nav-collapsed class to host */}\n <ic-tooltip\n label={label || navigationSlot.textContent}\n target=\"navigation-item\"\n placement=\"right\"\n class={{\n [\"tooltip-navigation-item\"]: true,\n [\"tooltip-navigation-item-side-nav-collapsed\"]:\n (!this.sideNavExpanded || this.displayNavigationTooltip) &&\n this.navigationType === \"side\",\n [\"tooltip-long-label-navigation-item-side-nav-expanded\"]:\n this.el.hasAttribute(\"[display-navigation-tooltip = 'true']\"),\n }}\n >\n {navigationSlot ? (\n <slot name=\"navigation-item\"></slot>\n ) : (\n this.displayDefaultNavigationItem(\n href,\n hreflang,\n target,\n rel,\n referrerpolicy,\n download,\n label\n )\n )}\n </ic-tooltip>\n </Host>\n );\n }\n}\n"],"mappings":"gOAAA,MAAMA,EAAsB,m1kB,MCqCfC,EAAc,M,6GAEjBC,KAAAC,gBAA2B,KAoJ3BD,KAAAE,6BAA+B,CACrCC,EACAC,EACAC,EACAC,EACAC,EACAC,EACAC,KAEA,MAAMC,EACJV,KAAKW,eAAiBX,KAAKY,iBAAmB,OAAS,QACzD,MAAMC,EAAY,6BAClB,MAAMC,EAAuBd,KAAKe,YAChCC,EAAA,OAAKC,MAAO,CAAEC,IAAK,MAAQC,UAAWC,IAExC,MAAMC,EAAgBrB,KAAKsB,GAAGC,cAAc,kBAC1CP,EAAA,OAAKC,MAAM,QACR,IACDD,EAAA,QAAMQ,KAAK,SAAe,KAI9B,GAAIrB,IAAS,GAAI,CACf,OACEa,EAAA,KACEb,KAAMA,EACNE,OAAQA,EACRC,IAAKA,EACLF,SAAUA,EACVqB,eAAgBlB,EAChBC,SAAUA,IAAa,MAAQA,EAAW,KAC1CS,MAAM,OACNS,IAAMJ,GAAQtB,KAAK2B,OAASL,EAC5BM,KAAK,OAAM,kBACMf,GAEhBQ,EAEDL,EAAA,iBAAeN,QAASA,GAAUD,GACjCK,EACAT,IAAW,UACVW,EAAA,QAAMC,MAAM,mBAAmBE,UAAWU,I,CAMlD,OACEb,EAAA,OACEc,SAAS,IACTb,MAAM,OACNS,IAAMJ,GAAQtB,KAAK2B,OAASL,EAAG,kBACdT,GAEhBQ,EACDL,EAAA,iBAAeN,QAASA,GAAUD,GACjCK,EACG,EAIFd,KAAA+B,qBAAwBC,IAC9B,MAAMC,EAAUD,EAAGE,OAAOC,KAC1B,GAAIF,IAAYjC,KAAKoC,WAAY,CAC/BpC,KAAKoC,WAAaH,EAClBjC,KAAKY,iBAAmBqB,GAAWI,EAAaC,C,GAI5CtC,KAAAuC,qBAAwBP,IAC9B,MAAMQ,gBAAEA,EAAeC,cAAEA,GAAkBT,EAAGE,OAC9ClC,KAAKwC,gBAAkBA,EACvBxC,KAAK0C,gBAAkBD,CAAa,EAG9BzC,KAAA2C,WAAcX,IACpB,GAAIA,EAAGY,gBAAkB,KAAM,CAC7B,MAAMvC,EAAS2B,EAAGY,cAClB,GAAIvC,EAAOwC,UAAY,qBAAsB,CAC3C,M,EAGJ7C,KAAK8C,UAAUC,MAAM,EAGf/C,KAAAgD,YAAc,KACpBhD,KAAKiD,eAAeF,MAAM,E,gBArOEV,EAAaa,G,gBACrBC,I,sBACe,M,qBACD,M,mBACF,M,2EAGE,M,wBAKE,M,8BAKM,M,cAKN,M,gBAKR,M,UAKP,G,4GAyBK,M,sBAiB5BC,uBACE,GAAIpD,KAAKqD,iBAAmB,OAAQ,CAClCrD,KAAKsD,SAASC,oBACZ,kBACAvD,KAAKuC,qB,MAEF,GAAIvC,KAAKqD,iBAAmB,MAAO,CACxCrD,KAAKsD,SAASC,oBACZ,gBACAvD,KAAK+B,qB,EAKXyB,oBACE,MAAMC,EAAmBC,EAAwB1D,KAAKsB,IACtDtB,KAAKqD,eAAiBI,EAAiBE,QACvC3D,KAAKsD,SAAWG,EAAiBG,OAEjC,GAAI5D,KAAKqD,iBAAmB,OAAQ,CAClCrD,KAAKsD,SAASO,iBACZ,kBACA7D,KAAKuC,qB,MAEF,GAAIvC,KAAKqD,iBAAmB,MAAO,CACxCrD,KAAKsD,SAASO,iBACZ,gBACA7D,KAAK+B,qB,CAIT,GACE+B,EAAqB9D,KAAKsB,MAAQ,uBAClCtB,KAAKqD,iBAAmB,MACxB,CACArD,KAAKW,cAAgB,I,CAGvBX,KAAKoC,WAAa2B,IAClB,GAAI/D,KAAKoC,YAAcC,EAAaC,GAAKtC,KAAKqD,iBAAmB,MAAO,CACtErD,KAAKY,iBAAmB,I,CAG1BZ,KAAKgE,eAAiBhE,KAAKsB,GAAGC,cAAc,4BAC5C,GAAIvB,KAAKgE,eAAgB,CACvBhE,KAAKgE,eAAeC,UAAYjE,KAAKgE,eAAeE,YAAYC,M,EAIpEC,qBACEpE,KAAKC,gBAAkB,K,CAIzBoE,mBAAmBrC,GACjB,MAAMsC,EAAiBtC,EAAGE,OAC1BlC,KAAKuE,WAAaD,EAAME,I,CAO1BC,iBACE,GAAIzE,KAAK2B,OAAQ,CACf3B,KAAK2B,OAAO+C,O,EA6FhBC,SACE,MAAMxE,KACJA,EAAIC,SACJA,EAAQC,OACRA,EAAMC,IACNA,EAAGC,eACHA,EAAcC,SACdA,EAAQC,MACRA,EAAKG,iBACLA,EAAgBD,cAChBA,EAAaiE,SACbA,EAAQZ,eACRA,GACEhE,KAEJ,OACEgB,EAAC6D,EAAI,CACH5D,MAAO,CACL,CAAC,mBAAoB,KACrB,CAAC,4BACEL,GAAoBZ,KAAKqD,iBAAmB,MAC/C,CAAC,0CACC1C,IAAkBC,GAAoBgE,EACxC,CAAC5E,KAAKuE,aACF3D,IAAqBD,GACtBX,KAAKqD,iBAAmB,QAAU1C,EACrC,CAAC,6BAA8BA,GAAiBiE,EAChD,CAAC,6BAA8BhE,EAC/B,CAAC,sCAAuCA,GAAoBgE,EAC5D,CAAC,iCAAkCjE,IAAkBC,EACrD,CAAC,+BACCZ,KAAKqD,iBAAmB,cAC1B,CAAC,oBAAqBrD,KAAKC,gBAC3B,CAAC,4BAA6BD,KAAKqD,iBAAmB,OACtD,CAAC,wCACGrD,KAAKwC,iBAAmBxC,KAAK8E,2BAC/B9E,KAAKqD,iBAAmB,OAC1B,CAAC,kDACErD,KAAKwC,iBACNxC,KAAKqD,iBAAmB,QACxBrD,KAAK+E,qBACJ/E,KAAK0C,gBACR,CAAC,cAAe1C,KAAKe,YAEvBiE,OAAQrE,IAAkBC,EAAmBZ,KAAK2C,WAAa,KAC/DsC,QAASjF,KAAKgD,YAAW,eACX4B,EAAW,OAAS,KAClCM,KAAK,YAGLlE,EAAA,cACEP,MAAOA,GAASuD,EAAeE,YAC/B7D,OAAO,kBACP8E,UAAU,QACVlE,MAAO,CACL,CAAC,2BAA4B,KAC7B,CAAC,gDACGjB,KAAKwC,iBAAmBxC,KAAK8E,2BAC/B9E,KAAKqD,iBAAmB,OAC1B,CAAC,wDACCrD,KAAKsB,GAAG8D,aAAa,2CAGxBpB,EACChD,EAAA,QAAMQ,KAAK,oBAEXxB,KAAKE,6BACHC,EACAC,EACAC,EACAC,EACAC,EACAC,EACAC,I"}
@@ -0,0 +1,2 @@
1
+ import{r as e,h as t,H as i,g as o}from"./p-69920d86.js";import{i as a,D as s,g as n,s as l,c as r}from"./p-5dd0b02e.js";import"./p-6f57b13c.js";const d='/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0;}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px;}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font-style:inherit;vertical-align:baseline}:host{position:relative;display:block}.data{display:flex;align-items:center}.text-cells{display:flex;flex-grow:1;min-width:0}.label{width:12.5rem;min-width:12.5rem;margin-right:var(--ic-space-md);color:var(--ic-color-tertiary-text)}.value{flex-grow:1}slot[name="value"]::slotted(ic-text-field[readonly][hide-label]){margin-top:calc(var(--ic-space-xs) * -1)}slot[name="value"]::slotted(ic-text-field[small][readonly][hide-label]){margin-top:calc(var(--ic-space-xxs) * -1)}slot[name="value"]::slotted(ic-text-field[readonly][hide-label][rows]){margin-top:calc(var(--ic-space-xxs) * -1 - var(--ic-space-xxxs))}.end-component{width:-moz-fit-content;width:fit-content;margin-left:3.5rem}.divider{margin-top:var(--ic-space-md);height:var(--ic-space-1px);background-color:var(--ic-architectural-300)}:host(.small) .divider{margin-top:var(--ic-space-xs)}:host(.breakpoint-medium) .label{width:10rem;min-width:10rem}:host(.breakpoint-xs) .text-cells{flex-direction:column}:host(.breakpoint-xs) .label{width:8rem;margin-bottom:var(--ic-space-xs)}:host(.breakpoint-xs) .value{max-width:95%}:host(.breakpoint-xs) .end-component{margin-left:0}@media (forced-colors: active){.divider{background-color:canvastext}}';const c=class{constructor(i){e(this,i);this.hasEndComponent=false;this.resizeObserver=null;this.runResizeObserver=()=>{this.resizeObserver=new ResizeObserver((()=>{this.checkLabelAbove()}));this.resizeObserver.observe(this.el)};this.renderLabel=e=>{if(a(this.el,"label")){return t("div",{class:"label"},t("slot",{name:"label"}))}else if(e){return t("div",{class:"label"},t("ic-typography",{variant:this.entitySize==="xs"?"label":"subtitle-large"},e))}return null};this.deviceSize=s.XL;this.entitySize=undefined;this.label=undefined;this.small=false;this.value=undefined}disconnectedCallback(){if(this.resizeObserver!==null){this.resizeObserver.disconnect()}}componentWillLoad(){this.deviceSize=n();this.hasEndComponent=l(this.el,"end-component");this.checkLabelAbove()}componentDidLoad(){r(this.runResizeObserver);if(this.hasEndComponent){this.labelEndComponent()}}checkLabelAbove(){var e;const t=(e=this.el.shadowRoot.querySelector(".data"))===null||e===void 0?void 0:e.clientWidth;if(t){if(t+46<s.S){this.entitySize="xs"}else if(t+46<s.M){this.entitySize="m"}else{this.entitySize="xl"}}}labelEndComponent(){const e=this.el.shadowRoot.querySelectorAll("slot[name=end-component]");e.forEach((e=>e.setAttribute("aria-label","for "+this.label+" row")))}render(){const{label:e,value:o,small:a}=this;return t(i,{class:{["small"]:a,["breakpoint-medium"]:this.entitySize==="m",["breakpoint-xs"]:this.entitySize==="xs"},role:"listitem"},t("div",{class:"data"},t("div",{class:"text-cells"},this.renderLabel(e),t("div",{class:"value"},t("slot",{name:"value"},t("ic-typography",{variant:"body"},o)))),this.hasEndComponent&&t("div",{class:"end-component"},t("div",{role:"cell"},t("slot",{name:"end-component"})))),t("div",{class:"divider"}))}get el(){return o(this)}};c.style=d;export{c as ic_data_row};
2
+ //# sourceMappingURL=p-27d42378.entry.js.map