@ukic/web-components 3.0.0-alpha.11 → 3.0.0-alpha.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (985) hide show
  1. package/dist/cjs/app-globals-3a1e7e63.js +7 -0
  2. package/dist/cjs/app-globals-3a1e7e63.js.map +1 -0
  3. package/dist/cjs/core.cjs.js +13 -11
  4. package/dist/cjs/core.cjs.js.map +1 -1
  5. package/dist/cjs/{helpers-eca4c27e.js → helpers-08a9ec1c.js} +31 -26
  6. package/dist/cjs/helpers-08a9ec1c.js.map +1 -0
  7. package/dist/cjs/ic-accordion-group.cjs.entry.js +31 -14
  8. package/dist/cjs/ic-accordion-group.cjs.entry.js.map +1 -1
  9. package/dist/cjs/ic-accordion.cjs.entry.js +65 -42
  10. package/dist/cjs/ic-accordion.cjs.entry.js.map +1 -1
  11. package/dist/cjs/ic-alert.cjs.entry.js +37 -16
  12. package/dist/cjs/ic-alert.cjs.entry.js.map +1 -1
  13. package/dist/cjs/ic-back-to-top.cjs.entry.js +29 -15
  14. package/dist/cjs/ic-back-to-top.cjs.entry.js.map +1 -1
  15. package/dist/cjs/ic-badge.cjs.entry.js +41 -22
  16. package/dist/cjs/ic-badge.cjs.entry.js.map +1 -1
  17. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +53 -37
  18. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ic-breadcrumb.cjs.entry.js +35 -21
  20. package/dist/cjs/ic-breadcrumb.cjs.entry.js.map +1 -1
  21. package/dist/cjs/ic-button_3.cjs.entry.js +246 -144
  22. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  23. package/dist/cjs/ic-card-vertical.cjs.entry.js +53 -32
  24. package/dist/cjs/ic-card-vertical.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ic-checkbox-group.cjs.entry.js +32 -9
  26. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  27. package/dist/cjs/ic-checkbox.cjs.entry.js +48 -29
  28. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -1
  29. package/dist/cjs/ic-chip.cjs.entry.js +44 -23
  30. package/dist/cjs/ic-chip.cjs.entry.js.map +1 -1
  31. package/dist/cjs/ic-classification-banner.cjs.entry.js +20 -4
  32. package/dist/cjs/ic-classification-banner.cjs.entry.js.map +1 -1
  33. package/dist/cjs/ic-data-list.cjs.entry.js +11 -5
  34. package/dist/cjs/ic-data-list.cjs.entry.js.map +1 -1
  35. package/dist/cjs/ic-data-row.cjs.entry.js +28 -18
  36. package/dist/cjs/ic-data-row.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ic-dialog.cjs.entry.js +141 -98
  38. package/dist/cjs/ic-dialog.cjs.entry.js.map +1 -1
  39. package/dist/cjs/ic-divider.cjs.entry.js +35 -15
  40. package/dist/cjs/ic-divider.cjs.entry.js.map +1 -1
  41. package/dist/cjs/ic-empty-state.cjs.entry.js +15 -9
  42. package/dist/cjs/ic-empty-state.cjs.entry.js.map +1 -1
  43. package/dist/cjs/ic-footer-link-group.cjs.entry.js +8 -8
  44. package/dist/cjs/ic-footer-link-group.cjs.entry.js.map +1 -1
  45. package/dist/cjs/ic-footer-link.cjs.entry.js +9 -10
  46. package/dist/cjs/ic-footer-link.cjs.entry.js.map +1 -1
  47. package/dist/cjs/ic-footer.cjs.entry.js +32 -19
  48. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -1
  49. package/dist/cjs/ic-hero.cjs.entry.js +29 -17
  50. package/dist/cjs/ic-hero.cjs.entry.js.map +1 -1
  51. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +32 -20
  52. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js.map +1 -1
  53. package/dist/cjs/ic-input-component-container_3.cjs.entry.js +126 -68
  54. package/dist/cjs/ic-input-component-container_3.cjs.entry.js.map +1 -1
  55. package/dist/cjs/ic-input-label_2.cjs.entry.js +45 -17
  56. package/dist/cjs/ic-input-label_2.cjs.entry.js.map +1 -1
  57. package/dist/cjs/ic-link.cjs.entry.js +28 -21
  58. package/dist/cjs/ic-link.cjs.entry.js.map +1 -1
  59. package/dist/cjs/ic-menu-group.cjs.entry.js +5 -5
  60. package/dist/cjs/ic-menu-group.cjs.entry.js.map +1 -1
  61. package/dist/cjs/ic-menu-item.cjs.entry.js +20 -18
  62. package/dist/cjs/ic-menu-item.cjs.entry.js.map +1 -1
  63. package/dist/cjs/ic-navigation-button.cjs.entry.js +25 -19
  64. package/dist/cjs/ic-navigation-button.cjs.entry.js.map +1 -1
  65. package/dist/cjs/ic-navigation-group.cjs.entry.js +45 -27
  66. package/dist/cjs/ic-navigation-group.cjs.entry.js.map +1 -1
  67. package/dist/cjs/ic-navigation-item.cjs.entry.js +69 -48
  68. package/dist/cjs/ic-navigation-item.cjs.entry.js.map +1 -1
  69. package/dist/cjs/ic-navigation-menu.cjs.entry.js +23 -15
  70. package/dist/cjs/ic-navigation-menu.cjs.entry.js.map +1 -1
  71. package/dist/cjs/ic-page-header.cjs.entry.js +45 -25
  72. package/dist/cjs/ic-page-header.cjs.entry.js.map +1 -1
  73. package/dist/cjs/ic-pagination-item.cjs.entry.js +27 -14
  74. package/dist/cjs/ic-pagination-item.cjs.entry.js.map +1 -1
  75. package/dist/cjs/ic-pagination.cjs.entry.js +60 -27
  76. package/dist/cjs/ic-pagination.cjs.entry.js.map +1 -1
  77. package/dist/cjs/ic-popover-menu.cjs.entry.js +57 -42
  78. package/dist/cjs/ic-popover-menu.cjs.entry.js.map +1 -1
  79. package/dist/cjs/ic-radio-group.cjs.entry.js +53 -28
  80. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -1
  81. package/dist/cjs/ic-radio-option.cjs.entry.js +36 -24
  82. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  83. package/dist/cjs/ic-search-bar.cjs.entry.js +153 -63
  84. package/dist/cjs/ic-search-bar.cjs.entry.js.map +1 -1
  85. package/dist/cjs/ic-section-container.cjs.entry.js +12 -5
  86. package/dist/cjs/ic-section-container.cjs.entry.js.map +1 -1
  87. package/dist/cjs/ic-select.cjs.entry.js +230 -136
  88. package/dist/cjs/ic-select.cjs.entry.js.map +1 -1
  89. package/dist/cjs/ic-side-navigation.cjs.entry.js +104 -71
  90. package/dist/cjs/ic-side-navigation.cjs.entry.js.map +1 -1
  91. package/dist/cjs/ic-skeleton.cjs.entry.js +11 -4
  92. package/dist/cjs/ic-skeleton.cjs.entry.js.map +1 -1
  93. package/dist/cjs/ic-skip-link.cjs.entry.js +54 -0
  94. package/dist/cjs/ic-skip-link.cjs.entry.js.map +1 -0
  95. package/dist/cjs/ic-status-tag.cjs.entry.js +25 -6
  96. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -1
  97. package/dist/cjs/ic-step.cjs.entry.js +33 -32
  98. package/dist/cjs/ic-step.cjs.entry.js.map +1 -1
  99. package/dist/cjs/ic-stepper.cjs.entry.js +50 -35
  100. package/dist/cjs/ic-stepper.cjs.entry.js.map +1 -1
  101. package/dist/cjs/ic-switch.cjs.entry.js +50 -22
  102. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  103. package/dist/cjs/ic-tab-context.cjs.entry.js +45 -26
  104. package/dist/cjs/ic-tab-context.cjs.entry.js.map +1 -1
  105. package/dist/cjs/ic-tab-group.cjs.entry.js +14 -9
  106. package/dist/cjs/ic-tab-group.cjs.entry.js.map +1 -1
  107. package/dist/cjs/ic-tab-panel.cjs.entry.js +16 -12
  108. package/dist/cjs/ic-tab-panel.cjs.entry.js.map +1 -1
  109. package/dist/cjs/ic-tab.cjs.entry.js +21 -15
  110. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -1
  111. package/dist/cjs/ic-text-field.cjs.entry.js +175 -69
  112. package/dist/cjs/ic-text-field.cjs.entry.js.map +1 -1
  113. package/dist/cjs/ic-theme.cjs.entry.js +13 -7
  114. package/dist/cjs/ic-theme.cjs.entry.js.map +1 -1
  115. package/dist/cjs/ic-toast-region.cjs.entry.js +2 -3
  116. package/dist/cjs/ic-toast-region.cjs.entry.js.map +1 -1
  117. package/dist/cjs/ic-toast.cjs.entry.js +29 -21
  118. package/dist/cjs/ic-toast.cjs.entry.js.map +1 -1
  119. package/dist/cjs/ic-toggle-button-group.cjs.entry.js +61 -29
  120. package/dist/cjs/ic-toggle-button-group.cjs.entry.js.map +1 -1
  121. package/dist/cjs/ic-toggle-button.cjs.entry.js +81 -48
  122. package/dist/cjs/ic-toggle-button.cjs.entry.js.map +1 -1
  123. package/dist/cjs/ic-top-navigation.cjs.entry.js +60 -31
  124. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -1
  125. package/dist/cjs/ic-typography.cjs.entry.js +53 -27
  126. package/dist/cjs/ic-typography.cjs.entry.js.map +1 -1
  127. package/dist/cjs/index-d337cd8a.js +2611 -0
  128. package/dist/cjs/index-d337cd8a.js.map +1 -0
  129. package/dist/cjs/loader.cjs.js +5 -3
  130. package/dist/cjs/loader.cjs.js.map +1 -1
  131. package/dist/collection/collection-manifest.json +5 -4
  132. package/dist/collection/components/ic-accordion/ic-accordion.js +80 -46
  133. package/dist/collection/components/ic-accordion/ic-accordion.js.map +1 -1
  134. package/dist/collection/components/ic-accordion-group/ic-accordion-group.js +49 -21
  135. package/dist/collection/components/ic-accordion-group/ic-accordion-group.js.map +1 -1
  136. package/dist/collection/components/ic-alert/ic-alert.js +58 -22
  137. package/dist/collection/components/ic-alert/ic-alert.js.map +1 -1
  138. package/dist/collection/components/ic-back-to-top/ic-back-to-top.css +49 -18
  139. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js +59 -14
  140. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js.map +1 -1
  141. package/dist/collection/components/ic-back-to-top/ic-back-to-top.stories.js +54 -0
  142. package/dist/collection/components/ic-back-to-top/ic-back-to-top.types.js.map +1 -1
  143. package/dist/collection/components/ic-badge/ic-badge.js +69 -32
  144. package/dist/collection/components/ic-badge/ic-badge.js.map +1 -1
  145. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js +49 -24
  146. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js.map +1 -1
  147. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js +63 -40
  148. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js.map +1 -1
  149. package/dist/collection/components/ic-button/ic-button.css +0 -8
  150. package/dist/collection/components/ic-button/ic-button.js +211 -98
  151. package/dist/collection/components/ic-button/ic-button.js.map +1 -1
  152. package/dist/collection/components/ic-card-vertical/ic-card-vertical.js +88 -42
  153. package/dist/collection/components/ic-card-vertical/ic-card-vertical.js.map +1 -1
  154. package/dist/collection/components/ic-checkbox/ic-checkbox.js +91 -45
  155. package/dist/collection/components/ic-checkbox/ic-checkbox.js.map +1 -1
  156. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js +62 -20
  157. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js.map +1 -1
  158. package/dist/collection/components/ic-chip/ic-chip.js +67 -30
  159. package/dist/collection/components/ic-chip/ic-chip.js.map +1 -1
  160. package/dist/collection/components/ic-classification-banner/ic-classification-banner.js +32 -7
  161. package/dist/collection/components/ic-classification-banner/ic-classification-banner.js.map +1 -1
  162. package/dist/collection/components/ic-data-list/ic-data-list.js +18 -7
  163. package/dist/collection/components/ic-data-list/ic-data-list.js.map +1 -1
  164. package/dist/collection/components/ic-data-row/ic-data-row.js +38 -21
  165. package/dist/collection/components/ic-data-row/ic-data-row.js.map +1 -1
  166. package/dist/collection/components/ic-dialog/ic-dialog.js +176 -110
  167. package/dist/collection/components/ic-dialog/ic-dialog.js.map +1 -1
  168. package/dist/collection/components/ic-dialog/ic-dialog.stories.js +100 -49
  169. package/dist/collection/components/ic-divider/ic-divider.js +55 -22
  170. package/dist/collection/components/ic-divider/ic-divider.js.map +1 -1
  171. package/dist/collection/components/ic-divider/ic-divider.stories.js +2 -2
  172. package/dist/collection/components/ic-empty-state/ic-empty-state.js +32 -13
  173. package/dist/collection/components/ic-empty-state/ic-empty-state.js.map +1 -1
  174. package/dist/collection/components/ic-footer/ic-footer.js +49 -25
  175. package/dist/collection/components/ic-footer/ic-footer.js.map +1 -1
  176. package/dist/collection/components/ic-footer-link/ic-footer-link.js +24 -15
  177. package/dist/collection/components/ic-footer-link/ic-footer-link.js.map +1 -1
  178. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js +6 -5
  179. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js.map +1 -1
  180. package/dist/collection/components/ic-hero/ic-hero.css +1 -1
  181. package/dist/collection/components/ic-hero/ic-hero.js +54 -25
  182. package/dist/collection/components/ic-hero/ic-hero.js.map +1 -1
  183. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js +40 -21
  184. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js.map +1 -1
  185. package/dist/collection/components/ic-input-component-container/ic-input-component-container.css +9 -0
  186. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js +55 -20
  187. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js.map +1 -1
  188. package/dist/collection/components/ic-input-container/ic-input-container.js +16 -6
  189. package/dist/collection/components/ic-input-container/ic-input-container.js.map +1 -1
  190. package/dist/collection/components/ic-input-label/ic-input-label.js +48 -11
  191. package/dist/collection/components/ic-input-label/ic-input-label.js.map +1 -1
  192. package/dist/collection/components/ic-input-validation/ic-input-validation.js +31 -14
  193. package/dist/collection/components/ic-input-validation/ic-input-validation.js.map +1 -1
  194. package/dist/collection/components/ic-link/ic-link.js +49 -28
  195. package/dist/collection/components/ic-link/ic-link.js.map +1 -1
  196. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js +124 -66
  197. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js.map +1 -1
  198. package/dist/collection/components/ic-menu/ic-menu.js +136 -74
  199. package/dist/collection/components/ic-menu/ic-menu.js.map +1 -1
  200. package/dist/collection/components/ic-menu/ic-menu.types.js.map +1 -1
  201. package/dist/collection/components/ic-menu-group/ic-menu-group.js +4 -5
  202. package/dist/collection/components/ic-menu-group/ic-menu-group.js.map +1 -1
  203. package/dist/collection/components/ic-menu-item/ic-menu-item.js +53 -28
  204. package/dist/collection/components/ic-menu-item/ic-menu-item.js.map +1 -1
  205. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js +44 -23
  206. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js.map +1 -1
  207. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js +83 -28
  208. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js.map +1 -1
  209. package/dist/collection/components/ic-navigation-group/ic-navigation-group.types.js +2 -0
  210. package/dist/collection/components/ic-navigation-group/ic-navigation-group.types.js.map +1 -0
  211. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js +107 -63
  212. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js.map +1 -1
  213. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js +30 -17
  214. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js.map +1 -1
  215. package/dist/collection/components/ic-page-header/ic-page-header.js +68 -31
  216. package/dist/collection/components/ic-page-header/ic-page-header.js.map +1 -1
  217. package/dist/collection/components/ic-pagination/ic-pagination.js +100 -44
  218. package/dist/collection/components/ic-pagination/ic-pagination.js.map +1 -1
  219. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js +48 -22
  220. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js.map +1 -1
  221. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js +80 -52
  222. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js.map +1 -1
  223. package/dist/collection/components/ic-radio-group/ic-radio-group.js +87 -41
  224. package/dist/collection/components/ic-radio-group/ic-radio-group.js.map +1 -1
  225. package/dist/collection/components/ic-radio-group/ic-radio-group.stories.js +31 -0
  226. package/dist/collection/components/ic-radio-option/ic-radio-option.css +20 -0
  227. package/dist/collection/components/ic-radio-option/ic-radio-option.js +64 -33
  228. package/dist/collection/components/ic-radio-option/ic-radio-option.js.map +1 -1
  229. package/dist/collection/components/ic-search-bar/ic-search-bar.js +252 -101
  230. package/dist/collection/components/ic-search-bar/ic-search-bar.js.map +1 -1
  231. package/dist/collection/components/ic-search-bar/ic-search-bar.types.js.map +1 -1
  232. package/dist/collection/components/ic-section-container/ic-section-container.js +15 -5
  233. package/dist/collection/components/ic-section-container/ic-section-container.js.map +1 -1
  234. package/dist/collection/components/ic-select/ic-select.css +1 -1
  235. package/dist/collection/components/ic-select/ic-select.js +329 -176
  236. package/dist/collection/components/ic-select/ic-select.js.map +1 -1
  237. package/dist/collection/components/ic-side-navigation/ic-side-navigation.css +1 -2
  238. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js +143 -89
  239. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js.map +1 -1
  240. package/dist/collection/components/ic-skeleton/ic-skeleton.js +14 -4
  241. package/dist/collection/components/ic-skeleton/ic-skeleton.js.map +1 -1
  242. package/dist/collection/components/ic-skip-link/ic-skip-link.css +26 -0
  243. package/dist/collection/components/ic-skip-link/ic-skip-link.js +202 -0
  244. package/dist/collection/components/ic-skip-link/ic-skip-link.js.map +1 -0
  245. package/dist/collection/components/ic-skip-link/ic-skip-link.stories.js +160 -0
  246. package/dist/collection/components/ic-status-tag/ic-status-tag.js +41 -9
  247. package/dist/collection/components/ic-status-tag/ic-status-tag.js.map +1 -1
  248. package/dist/collection/components/ic-step/ic-step.js +66 -40
  249. package/dist/collection/components/ic-step/ic-step.js.map +1 -1
  250. package/dist/collection/components/ic-stepper/ic-stepper.js +61 -37
  251. package/dist/collection/components/ic-stepper/ic-stepper.js.map +1 -1
  252. package/dist/collection/components/ic-switch/ic-switch.js +72 -27
  253. package/dist/collection/components/ic-switch/ic-switch.js.map +1 -1
  254. package/dist/collection/components/ic-tab/ic-tab.js +40 -21
  255. package/dist/collection/components/ic-tab/ic-tab.js.map +1 -1
  256. package/dist/collection/components/ic-tab-context/ic-tab-context.js +60 -31
  257. package/dist/collection/components/ic-tab-context/ic-tab-context.js.map +1 -1
  258. package/dist/collection/components/ic-tab-group/ic-tab-group.js +21 -9
  259. package/dist/collection/components/ic-tab-group/ic-tab-group.js.map +1 -1
  260. package/dist/collection/components/ic-tab-panel/ic-tab-panel.css +5 -1
  261. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js +50 -14
  262. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js.map +1 -1
  263. package/dist/collection/components/ic-text-field/ic-text-field.js +321 -140
  264. package/dist/collection/components/ic-text-field/ic-text-field.js.map +1 -1
  265. package/dist/collection/components/ic-theme/ic-theme.js +19 -9
  266. package/dist/collection/components/ic-theme/ic-theme.js.map +1 -1
  267. package/dist/collection/components/ic-toast/ic-toast.js +49 -28
  268. package/dist/collection/components/ic-toast/ic-toast.js.map +1 -1
  269. package/dist/collection/components/ic-toast-region/ic-toast-region.js +6 -5
  270. package/dist/collection/components/ic-toast-region/ic-toast-region.js.map +1 -1
  271. package/dist/collection/components/ic-toggle-button/ic-toggle-button.js +116 -60
  272. package/dist/collection/components/ic-toggle-button/ic-toggle-button.js.map +1 -1
  273. package/dist/collection/components/ic-toggle-button-group/ic-toggle-button-group.js +90 -35
  274. package/dist/collection/components/ic-toggle-button-group/ic-toggle-button-group.js.map +1 -1
  275. package/dist/collection/components/ic-tooltip/ic-tooltip.js +65 -33
  276. package/dist/collection/components/ic-tooltip/ic-tooltip.js.map +1 -1
  277. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js +91 -45
  278. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js.map +1 -1
  279. package/dist/collection/components/ic-typography/ic-typography.js +73 -32
  280. package/dist/collection/components/ic-typography/ic-typography.js.map +1 -1
  281. package/dist/collection/utils/helpers.js +29 -24
  282. package/dist/collection/utils/helpers.js.map +1 -1
  283. package/dist/collection/utils/testa11y.helpers.js +2 -1
  284. package/dist/collection/utils/testa11y.helpers.js.map +1 -1
  285. package/dist/collection/utils/types.js.map +1 -1
  286. package/dist/components/helpers.js +29 -24
  287. package/dist/components/helpers.js.map +1 -1
  288. package/dist/components/ic-accordion-group.js +29 -12
  289. package/dist/components/ic-accordion-group.js.map +1 -1
  290. package/dist/components/ic-accordion.js +63 -40
  291. package/dist/components/ic-accordion.js.map +1 -1
  292. package/dist/components/ic-alert.js +35 -14
  293. package/dist/components/ic-alert.js.map +1 -1
  294. package/dist/components/ic-back-to-top.js +28 -13
  295. package/dist/components/ic-back-to-top.js.map +1 -1
  296. package/dist/components/ic-badge.js +39 -20
  297. package/dist/components/ic-badge.js.map +1 -1
  298. package/dist/components/ic-breadcrumb-group.js +51 -35
  299. package/dist/components/ic-breadcrumb-group.js.map +1 -1
  300. package/dist/components/ic-breadcrumb2.js +33 -19
  301. package/dist/components/ic-breadcrumb2.js.map +1 -1
  302. package/dist/components/ic-button2.js +113 -63
  303. package/dist/components/ic-button2.js.map +1 -1
  304. package/dist/components/ic-card-vertical.js +51 -30
  305. package/dist/components/ic-card-vertical.js.map +1 -1
  306. package/dist/components/ic-checkbox-group.js +30 -7
  307. package/dist/components/ic-checkbox-group.js.map +1 -1
  308. package/dist/components/ic-checkbox.js +46 -27
  309. package/dist/components/ic-checkbox.js.map +1 -1
  310. package/dist/components/ic-chip.js +42 -21
  311. package/dist/components/ic-chip.js.map +1 -1
  312. package/dist/components/ic-classification-banner.js +19 -3
  313. package/dist/components/ic-classification-banner.js.map +1 -1
  314. package/dist/components/ic-data-list.js +10 -4
  315. package/dist/components/ic-data-list.js.map +1 -1
  316. package/dist/components/ic-data-row.js +27 -17
  317. package/dist/components/ic-data-row.js.map +1 -1
  318. package/dist/components/ic-dialog.js +139 -96
  319. package/dist/components/ic-dialog.js.map +1 -1
  320. package/dist/components/ic-divider2.js +33 -13
  321. package/dist/components/ic-divider2.js.map +1 -1
  322. package/dist/components/ic-empty-state.js +13 -7
  323. package/dist/components/ic-empty-state.js.map +1 -1
  324. package/dist/components/ic-footer-link-group.js +6 -6
  325. package/dist/components/ic-footer-link-group.js.map +1 -1
  326. package/dist/components/ic-footer-link.js +7 -8
  327. package/dist/components/ic-footer-link.js.map +1 -1
  328. package/dist/components/ic-footer.js +31 -18
  329. package/dist/components/ic-footer.js.map +1 -1
  330. package/dist/components/ic-hero.js +27 -15
  331. package/dist/components/ic-hero.js.map +1 -1
  332. package/dist/components/ic-horizontal-scroll2.js +30 -18
  333. package/dist/components/ic-horizontal-scroll2.js.map +1 -1
  334. package/dist/components/ic-input-component-container2.js +31 -9
  335. package/dist/components/ic-input-component-container2.js.map +1 -1
  336. package/dist/components/ic-input-container2.js +12 -5
  337. package/dist/components/ic-input-container2.js.map +1 -1
  338. package/dist/components/ic-input-label2.js +28 -8
  339. package/dist/components/ic-input-label2.js.map +1 -1
  340. package/dist/components/ic-input-validation2.js +15 -7
  341. package/dist/components/ic-input-validation2.js.map +1 -1
  342. package/dist/components/ic-link2.js +26 -19
  343. package/dist/components/ic-link2.js.map +1 -1
  344. package/dist/components/ic-loading-indicator2.js +89 -54
  345. package/dist/components/ic-loading-indicator2.js.map +1 -1
  346. package/dist/components/ic-menu-group.js +3 -3
  347. package/dist/components/ic-menu-group.js.map +1 -1
  348. package/dist/components/ic-menu-item2.js +18 -16
  349. package/dist/components/ic-menu-item2.js.map +1 -1
  350. package/dist/components/ic-menu2.js +81 -52
  351. package/dist/components/ic-menu2.js.map +1 -1
  352. package/dist/components/ic-navigation-button.js +23 -17
  353. package/dist/components/ic-navigation-button.js.map +1 -1
  354. package/dist/components/ic-navigation-group.js +45 -27
  355. package/dist/components/ic-navigation-group.js.map +1 -1
  356. package/dist/components/ic-navigation-item.js +68 -47
  357. package/dist/components/ic-navigation-item.js.map +1 -1
  358. package/dist/components/ic-navigation-menu2.js +21 -13
  359. package/dist/components/ic-navigation-menu2.js.map +1 -1
  360. package/dist/components/ic-page-header.js +44 -24
  361. package/dist/components/ic-page-header.js.map +1 -1
  362. package/dist/components/ic-pagination-item2.js +25 -12
  363. package/dist/components/ic-pagination-item2.js.map +1 -1
  364. package/dist/components/ic-pagination.js +58 -25
  365. package/dist/components/ic-pagination.js.map +1 -1
  366. package/dist/components/ic-popover-menu.js +55 -40
  367. package/dist/components/ic-popover-menu.js.map +1 -1
  368. package/dist/components/ic-radio-group.js +51 -26
  369. package/dist/components/ic-radio-group.js.map +1 -1
  370. package/dist/components/ic-radio-option.js +34 -22
  371. package/dist/components/ic-radio-option.js.map +1 -1
  372. package/dist/components/ic-search-bar.js +151 -61
  373. package/dist/components/ic-search-bar.js.map +1 -1
  374. package/dist/components/ic-section-container2.js +11 -4
  375. package/dist/components/ic-section-container2.js.map +1 -1
  376. package/dist/components/ic-select.js +228 -134
  377. package/dist/components/ic-select.js.map +1 -1
  378. package/dist/components/ic-side-navigation.js +103 -70
  379. package/dist/components/ic-side-navigation.js.map +1 -1
  380. package/dist/components/ic-skeleton.js +10 -3
  381. package/dist/components/ic-skeleton.js.map +1 -1
  382. package/dist/components/ic-skip-link.d.ts +11 -0
  383. package/dist/components/ic-skip-link.js +82 -0
  384. package/dist/components/ic-skip-link.js.map +1 -0
  385. package/dist/components/ic-status-tag.js +23 -4
  386. package/dist/components/ic-status-tag.js.map +1 -1
  387. package/dist/components/ic-step.js +31 -30
  388. package/dist/components/ic-step.js.map +1 -1
  389. package/dist/components/ic-stepper.js +48 -33
  390. package/dist/components/ic-stepper.js.map +1 -1
  391. package/dist/components/ic-switch.js +48 -20
  392. package/dist/components/ic-switch.js.map +1 -1
  393. package/dist/components/ic-tab-context.js +44 -25
  394. package/dist/components/ic-tab-context.js.map +1 -1
  395. package/dist/components/ic-tab-group.js +12 -7
  396. package/dist/components/ic-tab-group.js.map +1 -1
  397. package/dist/components/ic-tab-panel.js +16 -11
  398. package/dist/components/ic-tab-panel.js.map +1 -1
  399. package/dist/components/ic-tab.js +19 -13
  400. package/dist/components/ic-tab.js.map +1 -1
  401. package/dist/components/ic-text-field.js +173 -67
  402. package/dist/components/ic-text-field.js.map +1 -1
  403. package/dist/components/ic-theme.js +11 -5
  404. package/dist/components/ic-theme.js.map +1 -1
  405. package/dist/components/ic-toast-region.js +1 -2
  406. package/dist/components/ic-toast-region.js.map +1 -1
  407. package/dist/components/ic-toast.js +27 -19
  408. package/dist/components/ic-toast.js.map +1 -1
  409. package/dist/components/ic-toggle-button-group.js +59 -27
  410. package/dist/components/ic-toggle-button-group.js.map +1 -1
  411. package/dist/components/ic-toggle-button.js +79 -46
  412. package/dist/components/ic-toggle-button.js.map +1 -1
  413. package/dist/components/ic-tooltip2.js +42 -25
  414. package/dist/components/ic-tooltip2.js.map +1 -1
  415. package/dist/components/ic-top-navigation.js +59 -30
  416. package/dist/components/ic-top-navigation.js.map +1 -1
  417. package/dist/components/ic-typography2.js +51 -25
  418. package/dist/components/ic-typography2.js.map +1 -1
  419. package/dist/core/core.css +40 -29
  420. package/dist/core/core.esm.js +1 -1
  421. package/dist/core/core.esm.js.map +1 -1
  422. package/dist/core/index.esm.js.map +1 -1
  423. package/dist/core/p-052d1ff0.entry.js +2 -0
  424. package/dist/core/p-052d1ff0.entry.js.map +1 -0
  425. package/dist/core/p-08fbea60.entry.js +2 -0
  426. package/dist/core/p-08fbea60.entry.js.map +1 -0
  427. package/dist/core/p-0b757d78.entry.js +2 -0
  428. package/dist/core/p-0b757d78.entry.js.map +1 -0
  429. package/dist/core/p-0f34465d.entry.js +2 -0
  430. package/dist/core/p-0f34465d.entry.js.map +1 -0
  431. package/dist/core/p-111b3186.entry.js +2 -0
  432. package/dist/core/p-111b3186.entry.js.map +1 -0
  433. package/dist/core/p-144a31ec.entry.js +2 -0
  434. package/dist/core/p-144a31ec.entry.js.map +1 -0
  435. package/dist/core/{p-ca11666f.entry.js → p-180ea8ac.entry.js} +2 -2
  436. package/dist/core/p-180ea8ac.entry.js.map +1 -0
  437. package/dist/core/{p-39ab6387.entry.js → p-196e3d33.entry.js} +2 -2
  438. package/dist/core/p-196e3d33.entry.js.map +1 -0
  439. package/dist/core/{p-96b4ca6e.entry.js → p-1d6638c8.entry.js} +2 -2
  440. package/dist/core/p-1d6638c8.entry.js.map +1 -0
  441. package/dist/core/p-1d9a929b.entry.js +2 -0
  442. package/dist/core/p-1d9a929b.entry.js.map +1 -0
  443. package/dist/core/{p-27274ca8.entry.js → p-1fccec19.entry.js} +2 -2
  444. package/dist/core/p-1fccec19.entry.js.map +1 -0
  445. package/dist/core/p-269f841d.js +2 -0
  446. package/dist/core/p-269f841d.js.map +1 -0
  447. package/dist/core/{p-094f51b6.entry.js → p-27de359f.entry.js} +2 -2
  448. package/dist/core/p-27de359f.entry.js.map +1 -0
  449. package/dist/core/p-2cb55e86.entry.js +2 -0
  450. package/dist/core/p-2cb55e86.entry.js.map +1 -0
  451. package/dist/core/p-30a262d2.entry.js +2 -0
  452. package/dist/core/p-30a262d2.entry.js.map +1 -0
  453. package/dist/core/p-3b185c32.js.map +1 -1
  454. package/dist/core/{p-a178d53c.entry.js → p-40bc1f3e.entry.js} +2 -2
  455. package/dist/core/p-40bc1f3e.entry.js.map +1 -0
  456. package/dist/core/p-426ec638.js.map +1 -1
  457. package/dist/core/p-47b46637.entry.js +2 -0
  458. package/dist/core/p-47b46637.entry.js.map +1 -0
  459. package/dist/core/p-4a5ab31e.entry.js +2 -0
  460. package/dist/core/p-4a5ab31e.entry.js.map +1 -0
  461. package/dist/core/p-4e4014cd.entry.js +2 -0
  462. package/dist/core/p-4e4014cd.entry.js.map +1 -0
  463. package/dist/core/{p-25d3c3a6.entry.js → p-55eb89cc.entry.js} +2 -2
  464. package/dist/core/p-55eb89cc.entry.js.map +1 -0
  465. package/dist/core/p-59287779.entry.js +2 -0
  466. package/dist/core/p-59287779.entry.js.map +1 -0
  467. package/dist/core/p-59fc58e1.entry.js +2 -0
  468. package/dist/core/p-59fc58e1.entry.js.map +1 -0
  469. package/dist/core/p-5b7d8ee9.entry.js +2 -0
  470. package/dist/core/p-5b7d8ee9.entry.js.map +1 -0
  471. package/dist/core/{p-b404b307.entry.js → p-5fa5ba50.entry.js} +2 -2
  472. package/dist/core/p-5fa5ba50.entry.js.map +1 -0
  473. package/dist/core/p-68a5aaff.js.map +1 -1
  474. package/dist/core/{p-bbd4f487.entry.js → p-6c8e72b4.entry.js} +2 -2
  475. package/dist/core/p-6c8e72b4.entry.js.map +1 -0
  476. package/dist/core/p-6fdb8a79.entry.js +2 -0
  477. package/dist/core/p-6fdb8a79.entry.js.map +1 -0
  478. package/dist/core/{p-146b2788.entry.js → p-72140621.entry.js} +2 -2
  479. package/dist/core/p-72140621.entry.js.map +1 -0
  480. package/dist/core/p-76bdbc98.entry.js +2 -0
  481. package/dist/core/p-76bdbc98.entry.js.map +1 -0
  482. package/dist/core/{p-4cfe1dd8.entry.js → p-78c3ca49.entry.js} +2 -2
  483. package/dist/core/p-78c3ca49.entry.js.map +1 -0
  484. package/dist/core/p-78c51cba.entry.js +2 -0
  485. package/dist/core/p-78c51cba.entry.js.map +1 -0
  486. package/dist/core/{p-3d565739.entry.js → p-7ea79205.entry.js} +2 -2
  487. package/dist/core/p-7ea79205.entry.js.map +1 -0
  488. package/dist/core/p-8577de91.entry.js +2 -0
  489. package/dist/core/p-8577de91.entry.js.map +1 -0
  490. package/dist/core/{p-26bc7c62.entry.js → p-8856dff4.entry.js} +2 -2
  491. package/dist/core/p-8856dff4.entry.js.map +1 -0
  492. package/dist/core/p-8870d5d8.entry.js +2 -0
  493. package/dist/core/p-8870d5d8.entry.js.map +1 -0
  494. package/dist/core/{p-00587c99.entry.js → p-8b928cc9.entry.js} +2 -2
  495. package/dist/core/p-8b928cc9.entry.js.map +1 -0
  496. package/dist/core/p-8d1bee7a.entry.js +2 -0
  497. package/dist/core/p-8d1bee7a.entry.js.map +1 -0
  498. package/dist/core/p-8e4e97b4.js +3 -0
  499. package/dist/core/p-8e4e97b4.js.map +1 -0
  500. package/dist/core/p-8f319e1e.entry.js +2 -0
  501. package/dist/core/p-8f319e1e.entry.js.map +1 -0
  502. package/dist/core/p-90de3f5d.entry.js +2 -0
  503. package/dist/core/p-90de3f5d.entry.js.map +1 -0
  504. package/dist/core/p-912c8594.entry.js +2 -0
  505. package/dist/core/p-912c8594.entry.js.map +1 -0
  506. package/dist/core/{p-67b3cd55.entry.js → p-9206379d.entry.js} +2 -2
  507. package/dist/core/p-9206379d.entry.js.map +1 -0
  508. package/dist/core/p-94748b96.entry.js +2 -0
  509. package/dist/core/p-94748b96.entry.js.map +1 -0
  510. package/dist/core/p-98f906ba.entry.js +2 -0
  511. package/dist/core/p-98f906ba.entry.js.map +1 -0
  512. package/dist/core/{p-5b836707.entry.js → p-999102ee.entry.js} +2 -2
  513. package/dist/core/p-999102ee.entry.js.map +1 -0
  514. package/dist/core/p-9b741f96.entry.js +2 -0
  515. package/dist/core/p-9b741f96.entry.js.map +1 -0
  516. package/dist/core/p-9bcd2c77.entry.js +2 -0
  517. package/dist/core/p-9bcd2c77.entry.js.map +1 -0
  518. package/dist/core/p-9ee2fe04.entry.js +2 -0
  519. package/dist/core/p-9ee2fe04.entry.js.map +1 -0
  520. package/dist/core/{p-e2cf6e7e.entry.js → p-a56ec6d8.entry.js} +2 -2
  521. package/dist/core/p-a56ec6d8.entry.js.map +1 -0
  522. package/dist/core/p-abf767e3.entry.js +2 -0
  523. package/dist/core/p-abf767e3.entry.js.map +1 -0
  524. package/dist/core/p-b594bf26.entry.js +2 -0
  525. package/dist/core/p-b594bf26.entry.js.map +1 -0
  526. package/dist/core/{p-6e94c79c.entry.js → p-bd802c2f.entry.js} +2 -2
  527. package/dist/core/p-bd802c2f.entry.js.map +1 -0
  528. package/dist/core/p-bfee1e84.entry.js +2 -0
  529. package/dist/core/p-bfee1e84.entry.js.map +1 -0
  530. package/dist/core/{p-7f984e25.entry.js → p-c19cdc86.entry.js} +2 -2
  531. package/dist/core/p-c19cdc86.entry.js.map +1 -0
  532. package/dist/core/p-c2e091d7.js.map +1 -1
  533. package/dist/core/{p-73d6092d.entry.js → p-c3785d57.entry.js} +2 -2
  534. package/dist/core/p-c3785d57.entry.js.map +1 -0
  535. package/dist/core/{p-7b26ef60.entry.js → p-caa46d81.entry.js} +2 -2
  536. package/dist/core/p-caa46d81.entry.js.map +1 -0
  537. package/dist/core/p-ce0fb53a.entry.js +2 -0
  538. package/dist/core/p-ce0fb53a.entry.js.map +1 -0
  539. package/dist/core/p-de7542fa.entry.js +2 -0
  540. package/dist/core/p-de7542fa.entry.js.map +1 -0
  541. package/dist/core/{p-07aaf9c4.entry.js → p-df56bc50.entry.js} +2 -2
  542. package/dist/core/p-df56bc50.entry.js.map +1 -0
  543. package/dist/core/p-e1255160.js +2 -0
  544. package/dist/core/p-e1255160.js.map +1 -0
  545. package/dist/core/p-e25feba1.entry.js +2 -0
  546. package/dist/core/p-e25feba1.entry.js.map +1 -0
  547. package/dist/core/{p-c1db155d.entry.js → p-e30c6d79.entry.js} +2 -2
  548. package/dist/core/p-e30c6d79.entry.js.map +1 -0
  549. package/dist/core/p-f074ef5b.js.map +1 -1
  550. package/dist/core/{p-abdc2912.entry.js → p-f486d4f4.entry.js} +2 -2
  551. package/dist/core/p-f486d4f4.entry.js.map +1 -0
  552. package/dist/core/{p-a87d13b3.entry.js → p-fbce5f9a.entry.js} +2 -2
  553. package/dist/core/p-fbce5f9a.entry.js.map +1 -0
  554. package/dist/esm/app-globals-0f993ce5.js +5 -0
  555. package/dist/esm/app-globals-0f993ce5.js.map +1 -0
  556. package/dist/esm/core.js +14 -12
  557. package/dist/esm/core.js.map +1 -1
  558. package/dist/esm/{helpers-a72a277b.js → helpers-de6293bf.js} +31 -26
  559. package/dist/esm/helpers-de6293bf.js.map +1 -0
  560. package/dist/esm/ic-accordion-group.entry.js +31 -14
  561. package/dist/esm/ic-accordion-group.entry.js.map +1 -1
  562. package/dist/esm/ic-accordion.entry.js +65 -42
  563. package/dist/esm/ic-accordion.entry.js.map +1 -1
  564. package/dist/esm/ic-alert.entry.js +37 -16
  565. package/dist/esm/ic-alert.entry.js.map +1 -1
  566. package/dist/esm/ic-back-to-top.entry.js +29 -15
  567. package/dist/esm/ic-back-to-top.entry.js.map +1 -1
  568. package/dist/esm/ic-badge.entry.js +41 -22
  569. package/dist/esm/ic-badge.entry.js.map +1 -1
  570. package/dist/esm/ic-breadcrumb-group.entry.js +53 -37
  571. package/dist/esm/ic-breadcrumb-group.entry.js.map +1 -1
  572. package/dist/esm/ic-breadcrumb.entry.js +35 -21
  573. package/dist/esm/ic-breadcrumb.entry.js.map +1 -1
  574. package/dist/esm/ic-button_3.entry.js +246 -144
  575. package/dist/esm/ic-button_3.entry.js.map +1 -1
  576. package/dist/esm/ic-card-vertical.entry.js +53 -32
  577. package/dist/esm/ic-card-vertical.entry.js.map +1 -1
  578. package/dist/esm/ic-checkbox-group.entry.js +32 -9
  579. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  580. package/dist/esm/ic-checkbox.entry.js +48 -29
  581. package/dist/esm/ic-checkbox.entry.js.map +1 -1
  582. package/dist/esm/ic-chip.entry.js +44 -23
  583. package/dist/esm/ic-chip.entry.js.map +1 -1
  584. package/dist/esm/ic-classification-banner.entry.js +20 -4
  585. package/dist/esm/ic-classification-banner.entry.js.map +1 -1
  586. package/dist/esm/ic-data-list.entry.js +11 -5
  587. package/dist/esm/ic-data-list.entry.js.map +1 -1
  588. package/dist/esm/ic-data-row.entry.js +28 -18
  589. package/dist/esm/ic-data-row.entry.js.map +1 -1
  590. package/dist/esm/ic-dialog.entry.js +141 -98
  591. package/dist/esm/ic-dialog.entry.js.map +1 -1
  592. package/dist/esm/ic-divider.entry.js +35 -15
  593. package/dist/esm/ic-divider.entry.js.map +1 -1
  594. package/dist/esm/ic-empty-state.entry.js +15 -9
  595. package/dist/esm/ic-empty-state.entry.js.map +1 -1
  596. package/dist/esm/ic-footer-link-group.entry.js +8 -8
  597. package/dist/esm/ic-footer-link-group.entry.js.map +1 -1
  598. package/dist/esm/ic-footer-link.entry.js +9 -10
  599. package/dist/esm/ic-footer-link.entry.js.map +1 -1
  600. package/dist/esm/ic-footer.entry.js +32 -19
  601. package/dist/esm/ic-footer.entry.js.map +1 -1
  602. package/dist/esm/ic-hero.entry.js +29 -17
  603. package/dist/esm/ic-hero.entry.js.map +1 -1
  604. package/dist/esm/ic-horizontal-scroll.entry.js +32 -20
  605. package/dist/esm/ic-horizontal-scroll.entry.js.map +1 -1
  606. package/dist/esm/ic-input-component-container_3.entry.js +126 -68
  607. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -1
  608. package/dist/esm/ic-input-label_2.entry.js +45 -17
  609. package/dist/esm/ic-input-label_2.entry.js.map +1 -1
  610. package/dist/esm/ic-link.entry.js +28 -21
  611. package/dist/esm/ic-link.entry.js.map +1 -1
  612. package/dist/esm/ic-menu-group.entry.js +5 -5
  613. package/dist/esm/ic-menu-group.entry.js.map +1 -1
  614. package/dist/esm/ic-menu-item.entry.js +20 -18
  615. package/dist/esm/ic-menu-item.entry.js.map +1 -1
  616. package/dist/esm/ic-navigation-button.entry.js +25 -19
  617. package/dist/esm/ic-navigation-button.entry.js.map +1 -1
  618. package/dist/esm/ic-navigation-group.entry.js +45 -27
  619. package/dist/esm/ic-navigation-group.entry.js.map +1 -1
  620. package/dist/esm/ic-navigation-item.entry.js +69 -48
  621. package/dist/esm/ic-navigation-item.entry.js.map +1 -1
  622. package/dist/esm/ic-navigation-menu.entry.js +23 -15
  623. package/dist/esm/ic-navigation-menu.entry.js.map +1 -1
  624. package/dist/esm/ic-page-header.entry.js +45 -25
  625. package/dist/esm/ic-page-header.entry.js.map +1 -1
  626. package/dist/esm/ic-pagination-item.entry.js +27 -14
  627. package/dist/esm/ic-pagination-item.entry.js.map +1 -1
  628. package/dist/esm/ic-pagination.entry.js +60 -27
  629. package/dist/esm/ic-pagination.entry.js.map +1 -1
  630. package/dist/esm/ic-popover-menu.entry.js +57 -42
  631. package/dist/esm/ic-popover-menu.entry.js.map +1 -1
  632. package/dist/esm/ic-radio-group.entry.js +53 -28
  633. package/dist/esm/ic-radio-group.entry.js.map +1 -1
  634. package/dist/esm/ic-radio-option.entry.js +36 -24
  635. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  636. package/dist/esm/ic-search-bar.entry.js +153 -63
  637. package/dist/esm/ic-search-bar.entry.js.map +1 -1
  638. package/dist/esm/ic-section-container.entry.js +12 -5
  639. package/dist/esm/ic-section-container.entry.js.map +1 -1
  640. package/dist/esm/ic-select.entry.js +230 -136
  641. package/dist/esm/ic-select.entry.js.map +1 -1
  642. package/dist/esm/ic-side-navigation.entry.js +104 -71
  643. package/dist/esm/ic-side-navigation.entry.js.map +1 -1
  644. package/dist/esm/ic-skeleton.entry.js +11 -4
  645. package/dist/esm/ic-skeleton.entry.js.map +1 -1
  646. package/dist/esm/ic-skip-link.entry.js +50 -0
  647. package/dist/esm/ic-skip-link.entry.js.map +1 -0
  648. package/dist/esm/ic-status-tag.entry.js +25 -6
  649. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  650. package/dist/esm/ic-step.entry.js +33 -32
  651. package/dist/esm/ic-step.entry.js.map +1 -1
  652. package/dist/esm/ic-stepper.entry.js +50 -35
  653. package/dist/esm/ic-stepper.entry.js.map +1 -1
  654. package/dist/esm/ic-switch.entry.js +50 -22
  655. package/dist/esm/ic-switch.entry.js.map +1 -1
  656. package/dist/esm/ic-tab-context.entry.js +45 -26
  657. package/dist/esm/ic-tab-context.entry.js.map +1 -1
  658. package/dist/esm/ic-tab-group.entry.js +14 -9
  659. package/dist/esm/ic-tab-group.entry.js.map +1 -1
  660. package/dist/esm/ic-tab-panel.entry.js +16 -12
  661. package/dist/esm/ic-tab-panel.entry.js.map +1 -1
  662. package/dist/esm/ic-tab.entry.js +21 -15
  663. package/dist/esm/ic-tab.entry.js.map +1 -1
  664. package/dist/esm/ic-text-field.entry.js +175 -69
  665. package/dist/esm/ic-text-field.entry.js.map +1 -1
  666. package/dist/esm/ic-theme.entry.js +13 -7
  667. package/dist/esm/ic-theme.entry.js.map +1 -1
  668. package/dist/esm/ic-toast-region.entry.js +2 -3
  669. package/dist/esm/ic-toast-region.entry.js.map +1 -1
  670. package/dist/esm/ic-toast.entry.js +29 -21
  671. package/dist/esm/ic-toast.entry.js.map +1 -1
  672. package/dist/esm/ic-toggle-button-group.entry.js +61 -29
  673. package/dist/esm/ic-toggle-button-group.entry.js.map +1 -1
  674. package/dist/esm/ic-toggle-button.entry.js +81 -48
  675. package/dist/esm/ic-toggle-button.entry.js.map +1 -1
  676. package/dist/esm/ic-top-navigation.entry.js +60 -31
  677. package/dist/esm/ic-top-navigation.entry.js.map +1 -1
  678. package/dist/esm/ic-typography.entry.js +53 -27
  679. package/dist/esm/ic-typography.entry.js.map +1 -1
  680. package/dist/esm/index-a7a720e7.js +2580 -0
  681. package/dist/esm/index-a7a720e7.js.map +1 -0
  682. package/dist/esm/loader.js +6 -4
  683. package/dist/esm/loader.js.map +1 -1
  684. package/dist/types/components/ic-accordion/ic-accordion.d.ts +3 -3
  685. package/dist/types/components/ic-accordion-group/ic-accordion-group.d.ts +5 -5
  686. package/dist/types/components/ic-alert/ic-alert.d.ts +1 -1
  687. package/dist/types/components/ic-back-to-top/ic-back-to-top.d.ts +6 -2
  688. package/dist/types/components/ic-back-to-top/ic-back-to-top.types.d.ts +1 -0
  689. package/dist/types/components/ic-badge/ic-badge.d.ts +1 -1
  690. package/dist/types/components/ic-breadcrumb/ic-breadcrumb.d.ts +1 -1
  691. package/dist/types/components/ic-breadcrumb-group/ic-breadcrumb-group.d.ts +2 -2
  692. package/dist/types/components/ic-button/ic-button.d.ts +6 -6
  693. package/dist/types/components/ic-checkbox/ic-checkbox.d.ts +10 -10
  694. package/dist/types/components/ic-checkbox-group/ic-checkbox-group.d.ts +6 -6
  695. package/dist/types/components/ic-data-list/ic-data-list.d.ts +1 -1
  696. package/dist/types/components/ic-data-row/ic-data-row.d.ts +2 -2
  697. package/dist/types/components/ic-dialog/ic-dialog.d.ts +9 -6
  698. package/dist/types/components/ic-divider/ic-divider.d.ts +3 -3
  699. package/dist/types/components/ic-footer/ic-footer.d.ts +4 -4
  700. package/dist/types/components/ic-hero/ic-hero.d.ts +3 -3
  701. package/dist/types/components/ic-input-component-container/ic-input-component-container.d.ts +6 -6
  702. package/dist/types/components/ic-input-label/ic-input-label.d.ts +2 -2
  703. package/dist/types/components/ic-input-validation/ic-input-validation.d.ts +4 -4
  704. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.d.ts +2 -2
  705. package/dist/types/components/ic-menu/ic-menu.d.ts +10 -10
  706. package/dist/types/components/ic-menu/ic-menu.types.d.ts +1 -1
  707. package/dist/types/components/ic-menu-item/ic-menu-item.d.ts +2 -2
  708. package/dist/types/components/ic-navigation-button/ic-navigation-button.d.ts +1 -1
  709. package/dist/types/components/ic-navigation-group/ic-navigation-group.d.ts +11 -4
  710. package/dist/types/components/ic-navigation-group/ic-navigation-group.types.d.ts +3 -0
  711. package/dist/types/components/ic-navigation-item/ic-navigation-item.d.ts +8 -8
  712. package/dist/types/components/ic-navigation-menu/ic-navigation-menu.d.ts +3 -3
  713. package/dist/types/components/ic-pagination/ic-pagination.d.ts +9 -9
  714. package/dist/types/components/ic-pagination-item/ic-pagination-item.d.ts +4 -4
  715. package/dist/types/components/ic-popover-menu/ic-popover-menu.d.ts +4 -4
  716. package/dist/types/components/ic-radio-group/ic-radio-group.d.ts +8 -8
  717. package/dist/types/components/ic-radio-option/ic-radio-option.d.ts +6 -6
  718. package/dist/types/components/ic-search-bar/ic-search-bar.d.ts +12 -12
  719. package/dist/types/components/ic-search-bar/ic-search-bar.types.d.ts +1 -1
  720. package/dist/types/components/ic-select/ic-select.d.ts +20 -20
  721. package/dist/types/components/ic-side-navigation/ic-side-navigation.d.ts +12 -12
  722. package/dist/types/components/ic-skip-link/ic-skip-link.d.ts +33 -0
  723. package/dist/types/components/ic-stepper/ic-stepper.d.ts +1 -1
  724. package/dist/types/components/ic-switch/ic-switch.d.ts +1 -1
  725. package/dist/types/components/ic-tab/ic-tab.d.ts +2 -2
  726. package/dist/types/components/ic-tab-panel/ic-tab-panel.d.ts +7 -1
  727. package/dist/types/components/ic-text-field/ic-text-field.d.ts +34 -33
  728. package/dist/types/components/ic-theme/ic-theme.d.ts +2 -2
  729. package/dist/types/components/ic-toast/ic-toast.d.ts +3 -3
  730. package/dist/types/components/ic-toast-region/ic-toast-region.d.ts +1 -1
  731. package/dist/types/components/ic-toggle-button/ic-toggle-button.d.ts +3 -3
  732. package/dist/types/components/ic-top-navigation/ic-top-navigation.d.ts +9 -9
  733. package/dist/types/components/ic-typography/ic-typography.d.ts +1 -1
  734. package/dist/types/components.d.ts +292 -197
  735. package/dist/types/stencil-public-runtime.d.ts +9 -10
  736. package/dist/types/utils/helpers.d.ts +10 -10
  737. package/dist/types/utils/types.d.ts +8 -4
  738. package/hydrate/index.d.ts +53 -12
  739. package/hydrate/index.js +32492 -20573
  740. package/hydrate/index.mjs +34265 -0
  741. package/hydrate/package.json +7 -1
  742. package/loader/cdn.js +1 -3
  743. package/loader/index.cjs.js +1 -3
  744. package/loader/index.d.ts +3 -0
  745. package/loader/index.es2017.js +1 -3
  746. package/loader/index.js +1 -3
  747. package/package.json +3 -3
  748. package/vscode-data.json +65 -330
  749. package/dist/cjs/helpers-eca4c27e.js.map +0 -1
  750. package/dist/cjs/index-f982899d.js +0 -3047
  751. package/dist/cjs/index-f982899d.js.map +0 -1
  752. package/dist/collection/components/ic-accordion/test/basic/ic-accordion.spec.js +0 -349
  753. package/dist/collection/components/ic-accordion/test/basic/ic-accordion.spec.js.map +0 -1
  754. package/dist/collection/components/ic-accordion-group/test/basic/ic-accordion-group.spec.js +0 -129
  755. package/dist/collection/components/ic-accordion-group/test/basic/ic-accordion-group.spec.js.map +0 -1
  756. package/dist/collection/components/ic-alert/test/basic/ic-alert.spec.js +0 -329
  757. package/dist/collection/components/ic-alert/test/basic/ic-alert.spec.js.map +0 -1
  758. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.spec.js +0 -145
  759. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.spec.js.map +0 -1
  760. package/dist/collection/components/ic-badge/test/basic/ic-badge.spec.js +0 -450
  761. package/dist/collection/components/ic-badge/test/basic/ic-badge.spec.js.map +0 -1
  762. package/dist/collection/components/ic-breadcrumb/test/basic/ic-breadcrumb.spec.js +0 -162
  763. package/dist/collection/components/ic-breadcrumb/test/basic/ic-breadcrumb.spec.js.map +0 -1
  764. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.spec.js +0 -219
  765. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.spec.js.map +0 -1
  766. package/dist/collection/components/ic-button/test/basic/ic-button.spec.js +0 -332
  767. package/dist/collection/components/ic-button/test/basic/ic-button.spec.js.map +0 -1
  768. package/dist/collection/components/ic-card-vertical/test/basic/ic-card-vertical.spec.js +0 -214
  769. package/dist/collection/components/ic-card-vertical/test/basic/ic-card-vertical.spec.js.map +0 -1
  770. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.spec.js +0 -284
  771. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.spec.js.map +0 -1
  772. package/dist/collection/components/ic-chip/test/basic/ic-chip.spec.js +0 -188
  773. package/dist/collection/components/ic-chip/test/basic/ic-chip.spec.js.map +0 -1
  774. package/dist/collection/components/ic-classification-banner/test/basic/ic-classification-banner.spec.js +0 -188
  775. package/dist/collection/components/ic-classification-banner/test/basic/ic-classification-banner.spec.js.map +0 -1
  776. package/dist/collection/components/ic-data-list/test/basic/ic-data-list.spec.js +0 -161
  777. package/dist/collection/components/ic-data-list/test/basic/ic-data-list.spec.js.map +0 -1
  778. package/dist/collection/components/ic-data-row/test/basic/ic-data-row.spec.js +0 -74
  779. package/dist/collection/components/ic-data-row/test/basic/ic-data-row.spec.js.map +0 -1
  780. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.spec.js +0 -448
  781. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.spec.js.map +0 -1
  782. package/dist/collection/components/ic-divider/test/basic/ic-divider.spec.js +0 -109
  783. package/dist/collection/components/ic-divider/test/basic/ic-divider.spec.js.map +0 -1
  784. package/dist/collection/components/ic-empty-state/test/basic/ic-empty-state.spec.js +0 -101
  785. package/dist/collection/components/ic-empty-state/test/basic/ic-empty-state.spec.js.map +0 -1
  786. package/dist/collection/components/ic-footer/test/basic/ic-footer.spec.js +0 -181
  787. package/dist/collection/components/ic-footer/test/basic/ic-footer.spec.js.map +0 -1
  788. package/dist/collection/components/ic-footer-link/test/basic/ic-footer-link.spec.js +0 -46
  789. package/dist/collection/components/ic-footer-link/test/basic/ic-footer-link.spec.js.map +0 -1
  790. package/dist/collection/components/ic-footer-link-group/test/basic/ic-footer-link-group.spec.js +0 -66
  791. package/dist/collection/components/ic-footer-link-group/test/basic/ic-footer-link-group.spec.js.map +0 -1
  792. package/dist/collection/components/ic-hero/test/basic/ic-hero.spec.js +0 -109
  793. package/dist/collection/components/ic-hero/test/basic/ic-hero.spec.js.map +0 -1
  794. package/dist/collection/components/ic-horizontal-scroll/test/basic/ic-horizontal-scroll.spec.js +0 -223
  795. package/dist/collection/components/ic-horizontal-scroll/test/basic/ic-horizontal-scroll.spec.js.map +0 -1
  796. package/dist/collection/components/ic-input-component-container/test/basic/ic-input-component-container.spec.js +0 -172
  797. package/dist/collection/components/ic-input-component-container/test/basic/ic-input-component-container.spec.js.map +0 -1
  798. package/dist/collection/components/ic-input-container/test/basic/ic-input-container.spec.js +0 -38
  799. package/dist/collection/components/ic-input-container/test/basic/ic-input-container.spec.js.map +0 -1
  800. package/dist/collection/components/ic-input-label/test/basic/ic-input-label.spec.js +0 -84
  801. package/dist/collection/components/ic-input-label/test/basic/ic-input-label.spec.js.map +0 -1
  802. package/dist/collection/components/ic-input-validation/test/basic/ic-input-validation.spec.js +0 -89
  803. package/dist/collection/components/ic-input-validation/test/basic/ic-input-validation.spec.js.map +0 -1
  804. package/dist/collection/components/ic-link/test/basic/ic-link.spec.js +0 -120
  805. package/dist/collection/components/ic-link/test/basic/ic-link.spec.js.map +0 -1
  806. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.spec.js +0 -149
  807. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.spec.js.map +0 -1
  808. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js +0 -1108
  809. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js.map +0 -1
  810. package/dist/collection/components/ic-menu-group/test/basic/ic-menu-group.spec.js +0 -94
  811. package/dist/collection/components/ic-menu-group/test/basic/ic-menu-group.spec.js.map +0 -1
  812. package/dist/collection/components/ic-menu-item/test/basic/ic-menu-item.spec.js +0 -121
  813. package/dist/collection/components/ic-menu-item/test/basic/ic-menu-item.spec.js.map +0 -1
  814. package/dist/collection/components/ic-navigation-button/test/basic/ic-navigation-button.spec.js +0 -95
  815. package/dist/collection/components/ic-navigation-button/test/basic/ic-navigation-button.spec.js.map +0 -1
  816. package/dist/collection/components/ic-navigation-group/test/basic/ic-navigation-group.spec.js +0 -309
  817. package/dist/collection/components/ic-navigation-group/test/basic/ic-navigation-group.spec.js.map +0 -1
  818. package/dist/collection/components/ic-navigation-item/test/basic/ic-navigation-item.spec.js +0 -130
  819. package/dist/collection/components/ic-navigation-item/test/basic/ic-navigation-item.spec.js.map +0 -1
  820. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.spec.js +0 -176
  821. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.spec.js.map +0 -1
  822. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.spec.js +0 -291
  823. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.spec.js.map +0 -1
  824. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.spec.js +0 -390
  825. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.spec.js.map +0 -1
  826. package/dist/collection/components/ic-pagination-item/test/basic/ic-pagination-item.spec.js +0 -79
  827. package/dist/collection/components/ic-pagination-item/test/basic/ic-pagination-item.spec.js.map +0 -1
  828. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.spec.js +0 -398
  829. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.spec.js.map +0 -1
  830. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.spec.js +0 -389
  831. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.spec.js.map +0 -1
  832. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.spec.js +0 -553
  833. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.spec.js.map +0 -1
  834. package/dist/collection/components/ic-section-container/test/basic/ic-section-container.spec.js +0 -69
  835. package/dist/collection/components/ic-section-container/test/basic/ic-section-container.spec.js.map +0 -1
  836. package/dist/collection/components/ic-select/test/basic/ic-select.spec.js +0 -1672
  837. package/dist/collection/components/ic-select/test/basic/ic-select.spec.js.map +0 -1
  838. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.spec.js +0 -503
  839. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.spec.js.map +0 -1
  840. package/dist/collection/components/ic-skeleton/test/basic/ic-skeleton.spec.js +0 -89
  841. package/dist/collection/components/ic-skeleton/test/basic/ic-skeleton.spec.js.map +0 -1
  842. package/dist/collection/components/ic-status-tag/test/basic/ic-status-tag.spec.js +0 -26
  843. package/dist/collection/components/ic-status-tag/test/basic/ic-status-tag.spec.js.map +0 -1
  844. package/dist/collection/components/ic-step/test/basic/ic-step.spec.js +0 -176
  845. package/dist/collection/components/ic-step/test/basic/ic-step.spec.js.map +0 -1
  846. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.spec.js +0 -752
  847. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.spec.js.map +0 -1
  848. package/dist/collection/components/ic-switch/test/basic/ic-switch.spec.js +0 -93
  849. package/dist/collection/components/ic-switch/test/basic/ic-switch.spec.js.map +0 -1
  850. package/dist/collection/components/ic-tab/test/basic/ic-tab.spec.js +0 -175
  851. package/dist/collection/components/ic-tab/test/basic/ic-tab.spec.js.map +0 -1
  852. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.spec.js +0 -390
  853. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.spec.js.map +0 -1
  854. package/dist/collection/components/ic-tab-panel/test/basic/ic-tab-panel.spec.js +0 -50
  855. package/dist/collection/components/ic-tab-panel/test/basic/ic-tab-panel.spec.js.map +0 -1
  856. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.input.spec.js +0 -312
  857. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.input.spec.js.map +0 -1
  858. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.textarea.spec.js +0 -341
  859. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.textarea.spec.js.map +0 -1
  860. package/dist/collection/components/ic-theme/test/basic/ic-theme.e2e.js +0 -72
  861. package/dist/collection/components/ic-theme/test/basic/ic-theme.e2e.js.map +0 -1
  862. package/dist/collection/components/ic-theme/test/basic/ic-theme.spec.js +0 -79
  863. package/dist/collection/components/ic-theme/test/basic/ic-theme.spec.js.map +0 -1
  864. package/dist/collection/components/ic-toast/test/basic/ic-toast.spec.js +0 -314
  865. package/dist/collection/components/ic-toast/test/basic/ic-toast.spec.js.map +0 -1
  866. package/dist/collection/components/ic-toast-region/test/basic/ic-toast-region.spec.js +0 -64
  867. package/dist/collection/components/ic-toast-region/test/basic/ic-toast-region.spec.js.map +0 -1
  868. package/dist/collection/components/ic-toggle-button/test/basic/ic-toggle-button.spec.js +0 -126
  869. package/dist/collection/components/ic-toggle-button/test/basic/ic-toggle-button.spec.js.map +0 -1
  870. package/dist/collection/components/ic-toggle-button-group/test/ic-toggle-button-group.spec.js +0 -337
  871. package/dist/collection/components/ic-toggle-button-group/test/ic-toggle-button-group.spec.js.map +0 -1
  872. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.spec.js +0 -321
  873. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.spec.js.map +0 -1
  874. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.spec.js +0 -314
  875. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.spec.js.map +0 -1
  876. package/dist/collection/components/ic-typography/test/basic/ic-typography.spec.js +0 -407
  877. package/dist/collection/components/ic-typography/test/basic/ic-typography.spec.js.map +0 -1
  878. package/dist/collection/testspec.setup.js +0 -77
  879. package/dist/collection/testspec.setup.js.map +0 -1
  880. package/dist/core/p-00587c99.entry.js.map +0 -1
  881. package/dist/core/p-07aaf9c4.entry.js.map +0 -1
  882. package/dist/core/p-094f51b6.entry.js.map +0 -1
  883. package/dist/core/p-146b2788.entry.js.map +0 -1
  884. package/dist/core/p-15082ea5.entry.js +0 -2
  885. package/dist/core/p-15082ea5.entry.js.map +0 -1
  886. package/dist/core/p-174de9d7.entry.js +0 -2
  887. package/dist/core/p-174de9d7.entry.js.map +0 -1
  888. package/dist/core/p-17f9921d.entry.js +0 -2
  889. package/dist/core/p-17f9921d.entry.js.map +0 -1
  890. package/dist/core/p-246ea059.entry.js +0 -2
  891. package/dist/core/p-246ea059.entry.js.map +0 -1
  892. package/dist/core/p-25d3c3a6.entry.js.map +0 -1
  893. package/dist/core/p-26bc7c62.entry.js.map +0 -1
  894. package/dist/core/p-27274ca8.entry.js.map +0 -1
  895. package/dist/core/p-39ab6387.entry.js.map +0 -1
  896. package/dist/core/p-3d565739.entry.js.map +0 -1
  897. package/dist/core/p-3ea4a005.entry.js +0 -2
  898. package/dist/core/p-3ea4a005.entry.js.map +0 -1
  899. package/dist/core/p-41b7c67c.entry.js +0 -2
  900. package/dist/core/p-41b7c67c.entry.js.map +0 -1
  901. package/dist/core/p-4572b2ba.entry.js +0 -2
  902. package/dist/core/p-4572b2ba.entry.js.map +0 -1
  903. package/dist/core/p-4cfe1dd8.entry.js.map +0 -1
  904. package/dist/core/p-5b836707.entry.js.map +0 -1
  905. package/dist/core/p-67b3cd55.entry.js.map +0 -1
  906. package/dist/core/p-67b8a829.entry.js +0 -2
  907. package/dist/core/p-67b8a829.entry.js.map +0 -1
  908. package/dist/core/p-6b5e91e2.js +0 -3
  909. package/dist/core/p-6b5e91e2.js.map +0 -1
  910. package/dist/core/p-6dfa5a4b.entry.js +0 -2
  911. package/dist/core/p-6dfa5a4b.entry.js.map +0 -1
  912. package/dist/core/p-6e94c79c.entry.js.map +0 -1
  913. package/dist/core/p-73d6092d.entry.js.map +0 -1
  914. package/dist/core/p-770c52a7.entry.js +0 -2
  915. package/dist/core/p-770c52a7.entry.js.map +0 -1
  916. package/dist/core/p-7b26ef60.entry.js.map +0 -1
  917. package/dist/core/p-7f984e25.entry.js.map +0 -1
  918. package/dist/core/p-86caada0.entry.js +0 -2
  919. package/dist/core/p-86caada0.entry.js.map +0 -1
  920. package/dist/core/p-8c03b8b5.entry.js +0 -2
  921. package/dist/core/p-8c03b8b5.entry.js.map +0 -1
  922. package/dist/core/p-8fdb9b16.entry.js +0 -2
  923. package/dist/core/p-8fdb9b16.entry.js.map +0 -1
  924. package/dist/core/p-91a221b5.entry.js +0 -2
  925. package/dist/core/p-91a221b5.entry.js.map +0 -1
  926. package/dist/core/p-96b4ca6e.entry.js.map +0 -1
  927. package/dist/core/p-9e0c2c19.entry.js +0 -2
  928. package/dist/core/p-9e0c2c19.entry.js.map +0 -1
  929. package/dist/core/p-9f569f90.entry.js +0 -2
  930. package/dist/core/p-9f569f90.entry.js.map +0 -1
  931. package/dist/core/p-a178d53c.entry.js.map +0 -1
  932. package/dist/core/p-a3b7a147.entry.js +0 -2
  933. package/dist/core/p-a3b7a147.entry.js.map +0 -1
  934. package/dist/core/p-a72685f6.entry.js +0 -2
  935. package/dist/core/p-a72685f6.entry.js.map +0 -1
  936. package/dist/core/p-a87d13b3.entry.js.map +0 -1
  937. package/dist/core/p-abdc2912.entry.js.map +0 -1
  938. package/dist/core/p-b260b967.entry.js +0 -2
  939. package/dist/core/p-b260b967.entry.js.map +0 -1
  940. package/dist/core/p-b404b307.entry.js.map +0 -1
  941. package/dist/core/p-b6ce9ca3.entry.js +0 -2
  942. package/dist/core/p-b6ce9ca3.entry.js.map +0 -1
  943. package/dist/core/p-b6e010f3.entry.js +0 -2
  944. package/dist/core/p-b6e010f3.entry.js.map +0 -1
  945. package/dist/core/p-bbd4f487.entry.js.map +0 -1
  946. package/dist/core/p-bd9f3961.entry.js +0 -2
  947. package/dist/core/p-bd9f3961.entry.js.map +0 -1
  948. package/dist/core/p-c1db155d.entry.js.map +0 -1
  949. package/dist/core/p-c7bcdb8e.entry.js +0 -2
  950. package/dist/core/p-c7bcdb8e.entry.js.map +0 -1
  951. package/dist/core/p-ca11666f.entry.js.map +0 -1
  952. package/dist/core/p-cda4aca9.js +0 -2
  953. package/dist/core/p-cda4aca9.js.map +0 -1
  954. package/dist/core/p-d0afa458.entry.js +0 -2
  955. package/dist/core/p-d0afa458.entry.js.map +0 -1
  956. package/dist/core/p-d8690838.entry.js +0 -2
  957. package/dist/core/p-d8690838.entry.js.map +0 -1
  958. package/dist/core/p-dededae6.entry.js +0 -2
  959. package/dist/core/p-dededae6.entry.js.map +0 -1
  960. package/dist/core/p-df957570.entry.js +0 -2
  961. package/dist/core/p-df957570.entry.js.map +0 -1
  962. package/dist/core/p-e2cf6e7e.entry.js.map +0 -1
  963. package/dist/core/p-e6189634.entry.js +0 -2
  964. package/dist/core/p-e6189634.entry.js.map +0 -1
  965. package/dist/core/p-e6dc3cd1.entry.js +0 -2
  966. package/dist/core/p-e6dc3cd1.entry.js.map +0 -1
  967. package/dist/core/p-e831277e.entry.js +0 -2
  968. package/dist/core/p-e831277e.entry.js.map +0 -1
  969. package/dist/core/p-eb7c589b.entry.js +0 -2
  970. package/dist/core/p-eb7c589b.entry.js.map +0 -1
  971. package/dist/core/p-f65179fe.entry.js +0 -2
  972. package/dist/core/p-f65179fe.entry.js.map +0 -1
  973. package/dist/core/p-fd60eef7.entry.js +0 -2
  974. package/dist/core/p-fd60eef7.entry.js.map +0 -1
  975. package/dist/core/p-fd9f3fd0.entry.js +0 -2
  976. package/dist/core/p-fd9f3fd0.entry.js.map +0 -1
  977. package/dist/esm/helpers-a72a277b.js.map +0 -1
  978. package/dist/esm/index-d1d2c456.js +0 -3016
  979. package/dist/esm/index-d1d2c456.js.map +0 -1
  980. package/dist/esm/polyfills/core-js.js +0 -11
  981. package/dist/esm/polyfills/dom.js +0 -79
  982. package/dist/esm/polyfills/es5-html-element.js +0 -1
  983. package/dist/esm/polyfills/index.js +0 -34
  984. package/dist/esm/polyfills/system.js +0 -6
  985. package/dist/types/testspec.setup.d.ts +0 -24
@@ -2,10 +2,11 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-f982899d.js');
6
- const helpers = require('./helpers-eca4c27e.js');
5
+ const index = require('./index-d337cd8a.js');
6
+ const helpers = require('./helpers-08a9ec1c.js');
7
7
 
8
8
  const icNavigationButtonCss = "/*! 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;margin-right:var(--ic-space-xs);list-style:none}:host(.in-side-menu){margin-right:0}:host::part(button){height:100%;min-height:2.5rem}:host(.in-side-menu) ::part(button){color:var(--ic-top-navigation-icon-active)}:host(.in-side-menu) ::part(button):hover{color:var(--ic-top-navigation-icon-hover);background-color:var(--ic-top-navigation-icon-hover-background)}:host(.in-side-menu) ::part(button):active{color:var(--ic-top-navigation-icon-pressed);background-color:var(--ic-top-navigation-icon-pressed-background)}:host(.in-side-menu) ::slotted(ic-badge){margin-left:var(--ic-space-xs)}";
9
+ const IcNavigationButtonStyle0 = icNavigationButtonCss;
9
10
 
10
11
  const MUTABLE_ATTRIBUTES = [...helpers.IC_INHERITED_ARIA, "title"];
11
12
  const NavigationButton = class {
@@ -13,30 +14,35 @@ const NavigationButton = class {
13
14
  index.registerInstance(this, hostRef);
14
15
  this.inheritedAttributes = {};
15
16
  this.hostMutationObserver = null;
17
+ this.initialAppearance = helpers.getBrandForegroundAppearance();
18
+ /**
19
+ * The display mode.
20
+ */
21
+ this.mode = "navbar";
22
+ /**
23
+ * If `true`, the user can save the linked URL instead of navigating to it.
24
+ */
25
+ this.download = false;
26
+ /**
27
+ * Sets the theme color to the dark or light theme color. "inherit" will set the color based on the system settings or ic-theme component.
28
+ */
29
+ this.theme = "inherit";
16
30
  // triggered when attributes of host element change
17
31
  this.hostMutationCallback = (mutationList) => {
18
32
  let forceComponentUpdate = false;
19
33
  mutationList.forEach(({ attributeName }) => {
20
- if (MUTABLE_ATTRIBUTES.includes(attributeName)) {
21
- this.inheritedAttributes[attributeName] =
22
- this.el.getAttribute(attributeName);
23
- forceComponentUpdate = true;
34
+ if (attributeName) {
35
+ const attribute = this.el.getAttribute(attributeName);
36
+ if (attribute && MUTABLE_ATTRIBUTES.includes(attributeName)) {
37
+ this.inheritedAttributes[attributeName] = attribute;
38
+ forceComponentUpdate = true;
39
+ }
24
40
  }
25
41
  });
26
42
  if (forceComponentUpdate) {
27
43
  index.forceUpdate(this);
28
44
  }
29
45
  };
30
- this.initialAppearance = helpers.getBrandForegroundAppearance();
31
- this.mode = "navbar";
32
- this.download = false;
33
- this.href = undefined;
34
- this.hreflang = undefined;
35
- this.label = undefined;
36
- this.referrerpolicy = undefined;
37
- this.rel = undefined;
38
- this.target = undefined;
39
- this.theme = "inherit";
40
46
  }
41
47
  componentWillLoad() {
42
48
  this.inheritedAttributes = helpers.inheritAttributes(this.el, MUTABLE_ATTRIBUTES);
@@ -103,15 +109,15 @@ const NavigationButton = class {
103
109
  fullWidth,
104
110
  disableTooltip,
105
111
  };
106
- return (index.h(index.Host, { class: {
112
+ return (index.h(index.Host, { key: '191dcba5e7f00412136b96bc866671928f3108d6', class: {
107
113
  ["in-side-menu"]: this.mode === "menu",
108
114
  [`ic-theme-${this.theme}`]: this.theme !== "inherit",
109
- } }, index.h("ic-button", Object.assign({ class: className, "aria-label": variant == "icon" ? this.label : null, ref: (el) => (this.buttonEl = el) }, buttonProps, this.inheritedAttributes, { monochrome: this.mode !== "menu", theme: helpers.getBrandForegroundAppearance() == "light" ? "light" : "dark" }), label, index.h("slot", { slot: "left-icon", name: "icon" }), helpers.isSlotUsed(this.el, "badge") && index.h("slot", { name: "badge" }))));
115
+ } }, index.h("ic-button", Object.assign({ key: '4321bb3ed17c49b9ad48039f59f4c5ec2a2f7603', class: className, "aria-label": variant == "icon" ? this.label : null, ref: (el) => (this.buttonEl = el) }, buttonProps, this.inheritedAttributes, { monochrome: this.mode !== "menu", theme: helpers.getBrandForegroundAppearance() == "light" ? "light" : "dark" }), label, index.h("slot", { key: 'b6c2e1dd8ec444c77ceef484f43649e1c67755fe', slot: "left-icon", name: "icon" }), helpers.isSlotUsed(this.el, "badge") && index.h("slot", { key: '7012bc0f69b65991adccbdf34ce487fc75ad976a', name: "badge" }))));
110
116
  }
111
117
  static get delegatesFocus() { return true; }
112
118
  get el() { return index.getElement(this); }
113
119
  };
114
- NavigationButton.style = icNavigationButtonCss;
120
+ NavigationButton.style = IcNavigationButtonStyle0;
115
121
 
116
122
  exports.ic_navigation_button = NavigationButton;
117
123
 
@@ -1 +1 @@
1
- {"file":"ic-navigation-button.entry.cjs.js","mappings":"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","names":["IC_INHERITED_ARIA","forceUpdate","getBrandForegroundAppearance","inheritAttributes","onComponentRequiredPropUndefined","IcBrandForegroundEnum","h","Host","isSlotUsed"],"sources":["src/components/ic-navigation-button/ic-navigation-button.css?tag=ic-navigation-button&encapsulation=shadow","src/components/ic-navigation-button/ic-navigation-button.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n:host {\n display: block;\n margin-right: var(--ic-space-xs);\n list-style: none;\n}\n\n:host(.in-side-menu) {\n margin-right: 0;\n}\n\n:host::part(button) {\n height: 100%;\n min-height: 2.5rem;\n}\n\n:host(.in-side-menu) ::part(button) {\n color: var(--ic-top-navigation-icon-active);\n}\n\n:host(.in-side-menu) ::part(button):hover {\n color: var(--ic-top-navigation-icon-hover);\n background-color: var(--ic-top-navigation-icon-hover-background);\n}\n\n:host(.in-side-menu) ::part(button):active {\n color: var(--ic-top-navigation-icon-pressed);\n background-color: var(--ic-top-navigation-icon-pressed-background);\n}\n\n:host(.in-side-menu) ::slotted(ic-badge) {\n margin-left: var(--ic-space-xs);\n}\n","import {\n Component,\n Element,\n Host,\n Prop,\n State,\n h,\n Listen,\n Method,\n forceUpdate,\n} from \"@stencil/core\";\n\nimport {\n getBrandForegroundAppearance,\n inheritAttributes,\n onComponentRequiredPropUndefined,\n isSlotUsed,\n} from \"../../utils/helpers\";\nimport { IC_INHERITED_ARIA } from \"../../utils/constants\";\nimport {\n IcBrand,\n IcBrandForeground,\n IcBrandForegroundEnum,\n IcBrandForegroundNoDefault,\n IcThemeMode,\n} from \"../../utils/types\";\nimport { IcNavButtonModes } from \"./ic-navigation-button.types\";\n\nconst MUTABLE_ATTRIBUTES = [...IC_INHERITED_ARIA, \"title\"];\n\n/**\n * @slot icon - Content will be placed to the left of the button label.\n * @slot badge - Badge component overlaying the top right of the button.\n */\n\n@Component({\n tag: \"ic-navigation-button\",\n styleUrl: \"ic-navigation-button.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class NavigationButton {\n private buttonEl: HTMLIcButtonElement;\n private inheritedAttributes: { [k: string]: string } = {};\n private hostMutationObserver: MutationObserver = null;\n\n @Element() el: HTMLIcNavigationButtonElement;\n\n @State() initialAppearance: IcBrandForegroundNoDefault | IcBrandForeground =\n getBrandForegroundAppearance();\n /**\n * The display mode.\n */\n @State() mode: IcNavButtonModes = \"navbar\";\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 * The URL that the link points to. This will render the button 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 info to display.\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 * 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 * Sets the theme color to the dark or light theme color. \"inherit\" will set the color based on the system settings or ic-theme component.\n */\n @Prop() theme?: IcThemeMode = \"inherit\";\n\n componentWillLoad(): void {\n this.inheritedAttributes = inheritAttributes(this.el, MUTABLE_ATTRIBUTES);\n }\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.label, propName: \"label\" }],\n \"Navigation Button\"\n );\n\n this.hostMutationObserver = new MutationObserver(this.hostMutationCallback);\n this.hostMutationObserver.observe(this.el, {\n attributes: true,\n });\n }\n\n componentWillRender(): void {\n const iconEl = this.el.querySelector(`[slot=\"icon\"]`);\n iconEl !== null && iconEl.setAttribute(\"viewBox\", \"0 0 24 24\");\n }\n\n disconnectedCallback(): void {\n this.hostMutationObserver?.disconnect();\n }\n\n @Listen(\"icNavigationMenuOpened\", { target: \"document\" })\n navBarMenuOpenHandler(): void {\n this.mode = \"menu\";\n }\n\n @Listen(\"icNavigationMenuClosed\", { target: \"document\" })\n navBarMenuCloseHandler(): void {\n this.mode = \"navbar\";\n }\n\n @Listen(\"brandChange\", { target: \"document\" })\n brandChangeHandler(ev: CustomEvent<IcBrand>): void {\n this.initialAppearance = ev.detail.mode;\n }\n\n /**\n * Sets focus on the native `button`.\n */\n @Method()\n async setFocus(): Promise<void> {\n if (this.buttonEl) {\n this.buttonEl.focus();\n }\n }\n\n // triggered when attributes of host element change\n private hostMutationCallback = (mutationList: MutationRecord[]): void => {\n let forceComponentUpdate = false;\n mutationList.forEach(({ attributeName }) => {\n if (MUTABLE_ATTRIBUTES.includes(attributeName)) {\n this.inheritedAttributes[attributeName] =\n this.el.getAttribute(attributeName);\n forceComponentUpdate = true;\n }\n });\n if (forceComponentUpdate) {\n forceUpdate(this);\n }\n };\n\n render() {\n const { href, target, rel, download, referrerpolicy } = this;\n\n let label = \"\";\n let className = \"\";\n let variant: \"icon\" | \"tertiary\" = \"icon\";\n let appearance: IcBrandForeground | IcBrandForegroundEnum.Default =\n this.initialAppearance;\n let size: \"medium\" | \"large\" = \"large\";\n let fullWidth = false;\n let disableTooltip = false;\n\n if (this.mode === \"menu\") {\n label = this.label;\n variant = \"tertiary\";\n appearance = IcBrandForegroundEnum.Default;\n size = \"medium\";\n fullWidth = true;\n className = \"popout-menu-button\";\n disableTooltip = true;\n }\n\n const buttonProps = {\n variant,\n appearance,\n size,\n href,\n target,\n rel,\n download,\n referrerpolicy,\n fullWidth,\n disableTooltip,\n };\n\n return (\n <Host\n class={{\n [\"in-side-menu\"]: this.mode === \"menu\",\n [`ic-theme-${this.theme}`]: this.theme !== \"inherit\",\n }}\n >\n <ic-button\n class={className}\n aria-label={variant == \"icon\" ? this.label : null}\n ref={(el) => (this.buttonEl = el)}\n {...buttonProps}\n {...this.inheritedAttributes}\n monochrome={this.mode !== \"menu\"}\n theme={getBrandForegroundAppearance() == \"light\" ? \"light\" : \"dark\"}\n >\n {label}\n <slot slot=\"left-icon\" name=\"icon\"></slot>\n {isSlotUsed(this.el, \"badge\") && <slot name=\"badge\"></slot>}\n </ic-button>\n </Host>\n );\n }\n}\n"],"version":3}
1
+ {"file":"ic-navigation-button.entry.cjs.js","mappings":"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","names":["IC_INHERITED_ARIA","getBrandForegroundAppearance","forceUpdate","inheritAttributes","onComponentRequiredPropUndefined","IcBrandForegroundEnum","h","Host","isSlotUsed"],"sources":["src/components/ic-navigation-button/ic-navigation-button.css?tag=ic-navigation-button&encapsulation=shadow","src/components/ic-navigation-button/ic-navigation-button.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n:host {\n display: block;\n margin-right: var(--ic-space-xs);\n list-style: none;\n}\n\n:host(.in-side-menu) {\n margin-right: 0;\n}\n\n:host::part(button) {\n height: 100%;\n min-height: 2.5rem;\n}\n\n:host(.in-side-menu) ::part(button) {\n color: var(--ic-top-navigation-icon-active);\n}\n\n:host(.in-side-menu) ::part(button):hover {\n color: var(--ic-top-navigation-icon-hover);\n background-color: var(--ic-top-navigation-icon-hover-background);\n}\n\n:host(.in-side-menu) ::part(button):active {\n color: var(--ic-top-navigation-icon-pressed);\n background-color: var(--ic-top-navigation-icon-pressed-background);\n}\n\n:host(.in-side-menu) ::slotted(ic-badge) {\n margin-left: var(--ic-space-xs);\n}\n","import {\n Component,\n Element,\n Host,\n Prop,\n State,\n h,\n Listen,\n Method,\n forceUpdate,\n} from \"@stencil/core\";\n\nimport {\n getBrandForegroundAppearance,\n inheritAttributes,\n onComponentRequiredPropUndefined,\n isSlotUsed,\n} from \"../../utils/helpers\";\nimport { IC_INHERITED_ARIA } from \"../../utils/constants\";\nimport {\n IcBrand,\n IcBrandForeground,\n IcBrandForegroundEnum,\n IcBrandForegroundNoDefault,\n IcThemeMode,\n} from \"../../utils/types\";\nimport { IcNavButtonModes } from \"./ic-navigation-button.types\";\n\nconst MUTABLE_ATTRIBUTES = [...IC_INHERITED_ARIA, \"title\"];\n\n/**\n * @slot icon - Content will be placed to the left of the button label.\n * @slot badge - Badge component overlaying the top right of the button.\n */\n\n@Component({\n tag: \"ic-navigation-button\",\n styleUrl: \"ic-navigation-button.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class NavigationButton {\n private buttonEl?: HTMLIcButtonElement;\n private inheritedAttributes: { [k: string]: string } = {};\n private hostMutationObserver: MutationObserver | null = null;\n\n @Element() el: HTMLIcNavigationButtonElement;\n\n @State() initialAppearance: IcBrandForegroundNoDefault | IcBrandForeground =\n getBrandForegroundAppearance();\n /**\n * The display mode.\n */\n @State() mode: IcNavButtonModes = \"navbar\";\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 * The URL that the link points to. This will render the button 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 info to display.\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 * 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 * Sets the theme color to the dark or light theme color. \"inherit\" will set the color based on the system settings or ic-theme component.\n */\n @Prop() theme?: IcThemeMode = \"inherit\";\n\n componentWillLoad(): void {\n this.inheritedAttributes = inheritAttributes(this.el, MUTABLE_ATTRIBUTES);\n }\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.label, propName: \"label\" }],\n \"Navigation Button\"\n );\n\n this.hostMutationObserver = new MutationObserver(this.hostMutationCallback);\n this.hostMutationObserver.observe(this.el, {\n attributes: true,\n });\n }\n\n componentWillRender(): void {\n const iconEl = this.el.querySelector(`[slot=\"icon\"]`);\n iconEl !== null && iconEl.setAttribute(\"viewBox\", \"0 0 24 24\");\n }\n\n disconnectedCallback(): void {\n this.hostMutationObserver?.disconnect();\n }\n\n @Listen(\"icNavigationMenuOpened\", { target: \"document\" })\n navBarMenuOpenHandler(): void {\n this.mode = \"menu\";\n }\n\n @Listen(\"icNavigationMenuClosed\", { target: \"document\" })\n navBarMenuCloseHandler(): void {\n this.mode = \"navbar\";\n }\n\n @Listen(\"brandChange\", { target: \"document\" })\n brandChangeHandler(ev: CustomEvent<IcBrand>): void {\n this.initialAppearance = ev.detail.mode;\n }\n\n /**\n * Sets focus on the native `button`.\n */\n @Method()\n async setFocus(): Promise<void> {\n if (this.buttonEl) {\n this.buttonEl.focus();\n }\n }\n\n // triggered when attributes of host element change\n private hostMutationCallback = (mutationList: MutationRecord[]): void => {\n let forceComponentUpdate = false;\n mutationList.forEach(({ attributeName }) => {\n if (attributeName) {\n const attribute = this.el.getAttribute(attributeName);\n if (attribute && MUTABLE_ATTRIBUTES.includes(attributeName)) {\n this.inheritedAttributes[attributeName] = attribute;\n forceComponentUpdate = true;\n }\n }\n });\n if (forceComponentUpdate) {\n forceUpdate(this);\n }\n };\n\n render() {\n const { href, target, rel, download, referrerpolicy } = this;\n\n let label = \"\";\n let className = \"\";\n let variant: \"icon\" | \"tertiary\" = \"icon\";\n let appearance: IcBrandForeground | IcBrandForegroundEnum.Default =\n this.initialAppearance;\n let size: \"medium\" | \"large\" = \"large\";\n let fullWidth = false;\n let disableTooltip = false;\n\n if (this.mode === \"menu\") {\n label = this.label;\n variant = \"tertiary\";\n appearance = IcBrandForegroundEnum.Default;\n size = \"medium\";\n fullWidth = true;\n className = \"popout-menu-button\";\n disableTooltip = true;\n }\n\n const buttonProps = {\n variant,\n appearance,\n size,\n href,\n target,\n rel,\n download,\n referrerpolicy,\n fullWidth,\n disableTooltip,\n };\n\n return (\n <Host\n class={{\n [\"in-side-menu\"]: this.mode === \"menu\",\n [`ic-theme-${this.theme}`]: this.theme !== \"inherit\",\n }}\n >\n <ic-button\n class={className}\n aria-label={variant == \"icon\" ? this.label : null}\n ref={(el) => (this.buttonEl = el)}\n {...buttonProps}\n {...this.inheritedAttributes}\n monochrome={this.mode !== \"menu\"}\n theme={getBrandForegroundAppearance() == \"light\" ? \"light\" : \"dark\"}\n >\n {label}\n <slot slot=\"left-icon\" name=\"icon\"></slot>\n {isSlotUsed(this.el, \"badge\") && <slot name=\"badge\"></slot>}\n </ic-button>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -2,24 +2,40 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-f982899d.js');
6
- const helpers = require('./helpers-eca4c27e.js');
5
+ const index = require('./index-d337cd8a.js');
6
+ const helpers = require('./helpers-08a9ec1c.js');
7
7
  const chevronIcon = require('./chevron-icon-3bf07531.js');
8
8
 
9
9
  const icNavigationGroupCss = "/*! 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;--ic-typography-color:currentcolor}:host(.in-side-menu){border-bottom:var(--ic-border-width) solid\n var(--ic-divider-background-monochrome);padding:var(--ic-space-md) 0}:host .navigation-group{height:100%;width:-moz-fit-content;width:fit-content;color:var(--ic-brand-text-color);display:flex;align-items:center;justify-content:center;padding:0 var(--ic-space-md) var(--ic-space-xxs);transition:var(--ic-easing-transition-slow);position:relative;background:none;border:none;white-space:nowrap}:host(.in-side-menu) .navigation-group{height:2.5rem;width:100%;text-align:left}:host(.in-side-menu) .navigation-group .ic-typography-label{width:11.875rem}:host(.in-side-menu) .navigation-group-side-menu{color:var(--ic-top-navigation-nav-group-link);justify-content:flex-start;padding:0 var(--ic-space-md) 0 var(--ic-space-md)}:host(.in-side-menu) .navigation-group-side-menu-collapsed,:host(.in-side-menu) .navigation-group-side-menu-expanded{color:var(--ic-top-navigation-nav-group-link);justify-content:flex-start;padding-left:var(--ic-space-md)}:host(.in-side-menu) .navigation-group-side-menu-expanded{margin-bottom:var(--ic-space-xs)}:host(.in-side-menu) .navigation-group-side-menu-collapsed::after,:host(.in-side-menu) .navigation-group-side-menu-expanded::after{border-style:solid;border-width:0.125em 0.125em 0 0;content:\"\";display:inline-block;height:0.45em;left:0.75em;position:relative;top:-0.1em;transform:rotate(135deg);vertical-align:top;width:0.45em}:host(.in-side-menu) .navigation-group-side-menu-expanded::after{top:0.15em;transform:rotate(-45deg)}:host .navigation-group:hover,:host .navigation-group:active,:host .selected{background-color:var(--ic-architectural-20);color:var(--ic-color-text-primary-light);outline:none;cursor:pointer}:host(:not(.in-side-menu)) .navigation-group:focus{box-shadow:var(--ic-border-focus);border-radius:var(--ic-border-radius);outline:var(--ic-hc-focus-outline);z-index:var(--ic-z-index-navigation-item);transition:box-shadow var(--ic-easing-transition-fast)}:host(.in-side-menu) .navigation-group-side-menu:hover,:host(.in-side-menu) .navigation-group-side-menu:focus{background-color:var(--ic-top-navigation-nav-group-hover);color:var(--ic-top-navigation-nav-group-link);cursor:auto;box-shadow:none;outline:none}:host(.in-side-menu) .navigation-group-side-menu:active{background-color:var(--ic-top-navigation-nav-group-pressed);color:var(--ic-top-navigation-nav-group-link)}:host(.in-side-menu) .navigation-group-side-menu:focus{outline:var(--ic-hc-focus-outline)}:host(.in-side-menu) .navigation-group-side-menu-expanded:hover:not(:focus),:host(.in-side-menu) .navigation-group-side-menu-collapsed:hover:not(:focus){background-color:var(--ic-action-dark-bg-hover);color:var(--ic-action-default);cursor:pointer}:host(.in-side-menu) .navigation-group-side-menu-expanded:active:not(:focus),:host(.in-side-menu) .navigation-group-side-menu-collapsed:active:not(:focus){background-color:var(--ic-action-dark-bg-pressed);color:var(--ic-action-default)}:host(.in-side-menu) .navigation-group-side-menu-expanded:focus,:host(.in-side-menu) .navigation-group-side-menu-collapsed:focus{color:var(--ic-action-default);box-shadow:var(--ic-border-focus-inset);border-radius:var(--ic-border-radius-inset);outline:var(--ic-hc-focus-outline)}:host .navigation-group-dropdown{background-color:var(--ic-top-navigation-menu-background);border-bottom:var(--ic-space-1px) solid var(--ic-top-navigation-menu-border);position:absolute;left:0;right:0;padding:var(--ic-space-xs) var(--ic-space-md);box-shadow:0 0.375rem 0.5rem -0.375rem rgba(0 0 0 / 20%);z-index:calc(var(--ic-z-index-navigation-item) - 1)}:host .navigation-group-dropdown-items-list{list-style:none;display:flex;flex-flow:column wrap;align-content:flex-start;padding-left:var(--ic-space-md);max-height:16.5rem}:host .chevron-toggle-icon-wrapper{display:flex;align-items:center}:host .chevron-toggle-icon-wrapper svg{transform:rotate(90deg);height:var(--ic-space-lg);width:var(--ic-space-lg)}:host .chevron-toggle-icon-closed svg{transform:rotate(-90deg)}:host(.ic-navigation-group-expanded) .grouped-links-wrapper{height:var(--navigation-child-items-height, auto) !important;transition:var(--ic-easing-transition-slow);overflow:hidden}:host(.ic-navigation-group-side-nav) .link,:host(.ic-navigation-group-side-nav) ::slotted(a){height:var(--navigation-child-items-height, auto)}:host(.ic-navigation-group-collapsed) .grouped-links-wrapper{height:0;transition:var(--ic-easing-transition-slow);overflow:hidden}:host(.ic-navigation-group-side-nav) .navigation-group{height:var(--navigation-group-height);width:var(--navigation-group-width);justify-content:var(--navigation-group-justify-content);padding-right:var(--navigation-group-expand-toggle-padding)}:host(.ic-navigation-group-side-nav) .navigation-group:hover,:host(.ic-navigation-group-side-nav) .navigation-group:active,:host(.ic-navigation-group-side-nav) .selected{background-color:var(--navigation-group-hover);color:var(--navigation-group-text-hover)}:host(.ic-navigation-group-side-nav) .navigation-group:focus{box-shadow:var(--ic-border-focus-inset);border-radius:var(--ic-border-radius-inset);background:none}:host(.ic-navigation-group-side-nav) .ic-typography-caption{position:var(--navigation-group-title-position);left:var(--navigation-group-title-position-left);white-space:nowrap}";
10
+ const IcNavigationGroupStyle0 = icNavigationGroupCss;
10
11
 
11
12
  const NavigationGroup = class {
12
13
  constructor(hostRef) {
13
14
  index.registerInstance(this, hostRef);
15
+ this.navigationGroupOpened = index.createEvent(this, "navigationGroupOpened", 7);
14
16
  this.allGroupedNavigationItems = [];
15
17
  this.DYNAMIC_GROUPED_LINKS_HEIGHT_MS = 100;
16
18
  this.IC_NAVIGATION_ITEM = "ic-navigation-item";
17
19
  this.mouseGate = false;
18
20
  this.nodeName = "IC-NAVIGATION-GROUP";
19
21
  this.GROUPED_LINKS_WRAPPER_CLASS = ".grouped-links-wrapper";
22
+ this.deviceSize = helpers.DEVICE_SIZES.XL;
23
+ this.dropdownOpen = false;
24
+ this.expanded = true;
25
+ this.focusStyle = helpers.getBrandForegroundAppearance();
26
+ this.inTopNavSideMenu = false;
27
+ /**
28
+ * If `true`, the group will be expandable in the side menu.
29
+ */
30
+ this.expandable = false;
31
+ /**
32
+ * Sets the theme color to the dark or light theme color. "inherit" will set the color based on the system settings or ic-theme component.
33
+ */
34
+ this.theme = "inherit";
20
35
  this.sideNavExpandHandler = (event) => {
36
+ var _a;
21
37
  this.isSideNavExpanded = event.detail.sideNavExpanded;
22
- const linkWrapper = this.el.shadowRoot.querySelector(this.GROUPED_LINKS_WRAPPER_CLASS);
38
+ const linkWrapper = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(this.GROUPED_LINKS_WRAPPER_CLASS);
23
39
  if (!linkWrapper)
24
40
  return;
25
41
  if (this.isSideNavExpanded) {
@@ -59,7 +75,8 @@ const NavigationGroup = class {
59
75
  this.el
60
76
  .querySelectorAll(this.IC_NAVIGATION_ITEM)
61
77
  .forEach((navigationItem) => {
62
- const navItem = navigationItem.shadowRoot.querySelector("a") ||
78
+ var _a;
79
+ const navItem = ((_a = navigationItem.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector("a")) ||
63
80
  navigationItem.querySelector("a");
64
81
  if (navItem) {
65
82
  navItem.setAttribute("tabindex", tabIndexValue);
@@ -84,8 +101,9 @@ const NavigationGroup = class {
84
101
  }
85
102
  };
86
103
  this.toggleExpanded = () => {
104
+ var _a;
87
105
  this.expanded = !this.expanded;
88
- const linkWrapper = this.el.shadowRoot.querySelector(this.GROUPED_LINKS_WRAPPER_CLASS);
106
+ const linkWrapper = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(this.GROUPED_LINKS_WRAPPER_CLASS);
89
107
  this.toggleGroupedLinkWrapperHeight(linkWrapper, this.expanded);
90
108
  };
91
109
  this.handleClick = (ev) => {
@@ -166,7 +184,7 @@ const NavigationGroup = class {
166
184
  ["navigation-group-dropdown"]: !this.inTopNavSideMenu,
167
185
  ["navigation-group-dropdown-side-menu"]: this.inTopNavSideMenu,
168
186
  ["selected"]: this.dropdownOpen && !this.inTopNavSideMenu,
169
- }, onMouseLeave: !this.inTopNavSideMenu ? this.handleMouseLeave : null, ref: (el) => (this.dropdown = el) }, index.h("nav", { class: {
187
+ }, onMouseLeave: !this.inTopNavSideMenu ? this.handleMouseLeave : undefined, ref: (el) => (this.dropdown = el) }, index.h("nav", { class: {
170
188
  ["navigation-group-dropdown-items"]: !this.inTopNavSideMenu,
171
189
  } }, index.h("ul", null, index.h("slot", null)))));
172
190
  this.renderGroupedLinks = () => (index.h("ul", { class: "grouped-links-wrapper" }, index.h("slot", null)));
@@ -182,7 +200,8 @@ const NavigationGroup = class {
182
200
  return `${navigationChildItemsHeight}px`;
183
201
  };
184
202
  this.setInitialGroupedLinksWrapperHeight = () => {
185
- const linkWrapper = this.el.shadowRoot.querySelector(this.GROUPED_LINKS_WRAPPER_CLASS);
203
+ var _a;
204
+ const linkWrapper = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(this.GROUPED_LINKS_WRAPPER_CLASS);
186
205
  if (!linkWrapper)
187
206
  return;
188
207
  if (!this.isSideNavExpanded &&
@@ -205,16 +224,6 @@ const NavigationGroup = class {
205
224
  }
206
225
  return null;
207
226
  };
208
- this.deviceSize = helpers.DEVICE_SIZES.XL;
209
- this.dropdownOpen = false;
210
- this.expanded = true;
211
- this.focusStyle = helpers.getBrandForegroundAppearance();
212
- this.inTopNavSideMenu = false;
213
- this.navigationType = undefined;
214
- this.parentEl = undefined;
215
- this.expandable = false;
216
- this.label = undefined;
217
- this.theme = "inherit";
218
227
  }
219
228
  disconnectedCallback() {
220
229
  var _a, _b;
@@ -226,15 +235,16 @@ const NavigationGroup = class {
226
235
  }
227
236
  }
228
237
  componentWillLoad() {
238
+ var _a, _b;
229
239
  this.deviceSize = helpers.getCurrentDeviceSize();
230
240
  const { navType, parent } = helpers.getNavItemParentDetails(this.el);
231
241
  this.navigationType = navType;
232
242
  this.parentEl = parent;
233
243
  if (this.navigationType === "side") {
234
- this.parentEl.addEventListener("icSideNavExpanded", this.sideNavExpandHandler);
244
+ (_a = this.parentEl) === null || _a === void 0 ? void 0 : _a.addEventListener("icSideNavExpanded", this.sideNavExpandHandler);
235
245
  }
236
246
  else if (this.navigationType === "top") {
237
- this.parentEl.addEventListener("icTopNavResized", this.topNavResizedHandler);
247
+ (_b = this.parentEl) === null || _b === void 0 ? void 0 : _b.addEventListener("icTopNavResized", this.topNavResizedHandler);
238
248
  if (this.deviceSize <=
239
249
  this.parentEl.customMobileBreakpoint)
240
250
  this.inTopNavSideMenu = true;
@@ -251,6 +261,11 @@ const NavigationGroup = class {
251
261
  childBlurHandler() {
252
262
  this.hideDropdown();
253
263
  }
264
+ handleNavigationGroupOpened(event) {
265
+ if (event.detail.source !== this.el) {
266
+ this.hideDropdown();
267
+ }
268
+ }
254
269
  navItemClickHandler() {
255
270
  this.hideDropdown();
256
271
  }
@@ -270,6 +285,9 @@ const NavigationGroup = class {
270
285
  }
271
286
  showDropdown() {
272
287
  if (!this.dropdownOpen) {
288
+ this.navigationGroupOpened.emit({
289
+ source: this.el,
290
+ });
273
291
  this.toggleDropdown();
274
292
  }
275
293
  }
@@ -284,22 +302,22 @@ const NavigationGroup = class {
284
302
  }
285
303
  render() {
286
304
  const { label, dropdownOpen, inTopNavSideMenu, expandable } = this;
287
- return (index.h(index.Host, { class: {
305
+ return (index.h(index.Host, { key: 'd2dca685d7a98166838f646a06b12d0f29c63874', class: {
288
306
  ["in-side-menu"]: inTopNavSideMenu,
289
307
  "ic-navigation-group-expanded": this.expanded,
290
308
  "ic-navigation-group-collapsed": !this.expanded,
291
309
  ["ic-navigation-group-side-nav"]: this.navigationType === "side",
292
310
  [`ic-theme-${this.theme}`]: this.theme !== "inherit",
293
- }, role: "listitem" }, index.h("button", { onMouseEnter: !inTopNavSideMenu &&
294
- this.navigationType === "top" &&
295
- this.handleMouseEnter, onMouseLeave: this.navigationType === "top" && this.handleMouseLeave, tabindex: inTopNavSideMenu && !expandable ? "-1" : "0", onBlur: this.handleBlur, onClick: expandable ? this.handleClick : null, onKeyDown: this.handleKeydown, class: {
311
+ }, role: "listitem" }, index.h("button", { key: 'bf8357c5bc6324a69330e1ead95e36acb130a7d9', onMouseEnter: !inTopNavSideMenu && this.navigationType === "top"
312
+ ? this.handleMouseEnter
313
+ : undefined, onMouseLeave: this.navigationType === "top" ? this.handleMouseLeave : undefined, tabindex: inTopNavSideMenu && !expandable ? "-1" : "0", onBlur: this.handleBlur, onClick: expandable ? this.handleClick : undefined, onKeyDown: this.handleKeydown, class: {
296
314
  ["navigation-group"]: true,
297
315
  [this.focusStyle]: !inTopNavSideMenu,
298
316
  ["navigation-group-side-menu"]: inTopNavSideMenu && !expandable,
299
- ["navigation-group-side-menu-collapsed"]: inTopNavSideMenu && expandable && !dropdownOpen,
300
- ["navigation-group-side-menu-expanded"]: inTopNavSideMenu && expandable && dropdownOpen,
317
+ ["navigation-group-side-menu-collapsed"]: inTopNavSideMenu && !!expandable && !dropdownOpen,
318
+ ["navigation-group-side-menu-expanded"]: inTopNavSideMenu && !!expandable && dropdownOpen,
301
319
  ["selected"]: dropdownOpen && !inTopNavSideMenu,
302
- }, ref: (el) => (this.groupEl = el), "aria-expanded": `${dropdownOpen || this.expanded}`, "aria-haspopup": `${!inTopNavSideMenu && this.navigationType === "top"}` }, index.h("ic-typography", { variant: this.navigationType === "side" ? "caption" : "label" }, label), this.navigationType === "side" && expandable && (index.h("div", { class: {
320
+ }, ref: (el) => (this.groupEl = el), "aria-expanded": `${dropdownOpen || this.expanded}`, "aria-haspopup": `${!inTopNavSideMenu && this.navigationType === "top"}` }, index.h("ic-typography", { key: '47326c810d96a81521003d0a4c865eb94b1a2d0c', variant: this.navigationType === "side" ? "caption" : "label" }, label), this.navigationType === "side" && expandable && (index.h("div", { key: '847e7a598e215c4199f0fce73626deda6804b509', class: {
303
321
  "chevron-toggle-icon-wrapper": true,
304
322
  "chevron-toggle-icon-closed": this.expanded,
305
323
  }, innerHTML: chevronIcon.Chevron }))), this.renderNavigationItems()));
@@ -307,7 +325,7 @@ const NavigationGroup = class {
307
325
  static get delegatesFocus() { return true; }
308
326
  get el() { return index.getElement(this); }
309
327
  };
310
- NavigationGroup.style = icNavigationGroupCss;
328
+ NavigationGroup.style = IcNavigationGroupStyle0;
311
329
 
312
330
  exports.ic_navigation_group = NavigationGroup;
313
331
 
@@ -1 +1 @@
1
- {"file":"ic-navigation-group.entry.cjs.js","mappings":"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","names":["DEVICE_SIZES","h","getBrandForegroundAppearance","getCurrentDeviceSize","getNavItemParentDetails","Host","chevronIcon"],"sources":["src/components/ic-navigation-group/ic-navigation-group.css?tag=ic-navigation-group&encapsulation=shadow","src/components/ic-navigation-group/ic-navigation-group.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n/**\n * @prop --ic-z-index-navigation-item: z-index of navigation group item\n */\n\n:host {\n display: block;\n\n --ic-typography-color: currentcolor;\n}\n\n:host(.in-side-menu) {\n border-bottom: var(--ic-border-width) solid\n var(--ic-divider-background-monochrome);\n padding: var(--ic-space-md) 0;\n}\n\n:host .navigation-group {\n height: 100%;\n width: fit-content;\n color: var(--ic-brand-text-color);\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 0 var(--ic-space-md) var(--ic-space-xxs);\n transition: var(--ic-easing-transition-slow);\n position: relative;\n background: none;\n border: none;\n white-space: nowrap;\n}\n\n:host(.in-side-menu) .navigation-group {\n height: 2.5rem;\n width: 100%;\n text-align: left;\n}\n\n:host(.in-side-menu) .navigation-group .ic-typography-label {\n width: 11.875rem;\n}\n\n:host(.in-side-menu) .navigation-group-side-menu {\n color: var(--ic-top-navigation-nav-group-link);\n justify-content: flex-start;\n padding: 0 var(--ic-space-md) 0 var(--ic-space-md);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-collapsed,\n:host(.in-side-menu) .navigation-group-side-menu-expanded {\n color: var(--ic-top-navigation-nav-group-link);\n justify-content: flex-start;\n padding-left: var(--ic-space-md);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-expanded {\n margin-bottom: var(--ic-space-xs);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-collapsed::after,\n:host(.in-side-menu) .navigation-group-side-menu-expanded::after {\n border-style: solid;\n border-width: 0.125em 0.125em 0 0;\n content: \"\";\n display: inline-block;\n height: 0.45em;\n left: 0.75em;\n position: relative;\n top: -0.1em;\n transform: rotate(135deg);\n vertical-align: top;\n width: 0.45em;\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-expanded::after {\n top: 0.15em;\n transform: rotate(-45deg);\n}\n\n:host .navigation-group:hover,\n:host .navigation-group:active,\n:host .selected {\n background-color: var(--ic-architectural-20);\n color: var(--ic-color-text-primary-light);\n outline: none;\n cursor: pointer;\n}\n\n:host(:not(.in-side-menu)) .navigation-group:focus {\n box-shadow: var(--ic-border-focus);\n border-radius: var(--ic-border-radius);\n outline: var(--ic-hc-focus-outline);\n z-index: var(--ic-z-index-navigation-item);\n transition: box-shadow var(--ic-easing-transition-fast);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu:hover,\n:host(.in-side-menu) .navigation-group-side-menu:focus {\n background-color: var(--ic-top-navigation-nav-group-hover);\n color: var(--ic-top-navigation-nav-group-link);\n cursor: auto;\n box-shadow: none;\n outline: none;\n}\n\n:host(.in-side-menu) .navigation-group-side-menu:active {\n background-color: var(--ic-top-navigation-nav-group-pressed);\n color: var(--ic-top-navigation-nav-group-link);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu:focus {\n outline: var(--ic-hc-focus-outline);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-expanded:hover:not(:focus),\n:host(.in-side-menu) .navigation-group-side-menu-collapsed:hover:not(:focus) {\n background-color: var(--ic-action-dark-bg-hover);\n color: var(--ic-action-default);\n cursor: pointer;\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-expanded:active:not(:focus),\n:host(.in-side-menu) .navigation-group-side-menu-collapsed:active:not(:focus) {\n background-color: var(--ic-action-dark-bg-pressed);\n color: var(--ic-action-default);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-expanded:focus,\n:host(.in-side-menu) .navigation-group-side-menu-collapsed:focus {\n color: var(--ic-action-default);\n box-shadow: var(--ic-border-focus-inset);\n border-radius: var(--ic-border-radius-inset);\n outline: var(--ic-hc-focus-outline);\n}\n\n:host .navigation-group-dropdown {\n background-color: var(--ic-top-navigation-menu-background);\n border-bottom: var(--ic-space-1px) solid var(--ic-top-navigation-menu-border);\n position: absolute;\n left: 0;\n right: 0;\n padding: var(--ic-space-xs) var(--ic-space-md);\n box-shadow: 0 0.375rem 0.5rem -0.375rem rgba(0 0 0 / 20%);\n z-index: calc(var(--ic-z-index-navigation-item) - 1);\n}\n\n:host .navigation-group-dropdown-items-list {\n list-style: none;\n display: flex;\n flex-flow: column wrap;\n align-content: flex-start;\n padding-left: var(--ic-space-md);\n max-height: 16.5rem;\n}\n\n:host .chevron-toggle-icon-wrapper {\n display: flex;\n align-items: center;\n}\n\n:host .chevron-toggle-icon-wrapper svg {\n transform: rotate(90deg);\n height: var(--ic-space-lg);\n width: var(--ic-space-lg);\n}\n\n:host .chevron-toggle-icon-closed svg {\n transform: rotate(-90deg);\n}\n\n:host(.ic-navigation-group-expanded) .grouped-links-wrapper {\n height: var(--navigation-child-items-height, auto) !important;\n transition: var(--ic-easing-transition-slow);\n overflow: hidden;\n}\n\n:host(.ic-navigation-group-side-nav) .link,\n:host(.ic-navigation-group-side-nav) ::slotted(a) {\n height: var(--navigation-child-items-height, auto);\n}\n\n:host(.ic-navigation-group-collapsed) .grouped-links-wrapper {\n height: 0;\n transition: var(--ic-easing-transition-slow);\n overflow: hidden;\n}\n\n:host(.ic-navigation-group-side-nav) .navigation-group {\n height: var(--navigation-group-height);\n width: var(--navigation-group-width);\n justify-content: var(--navigation-group-justify-content);\n padding-right: var(--navigation-group-expand-toggle-padding);\n}\n\n:host(.ic-navigation-group-side-nav) .navigation-group:hover,\n:host(.ic-navigation-group-side-nav) .navigation-group:active,\n:host(.ic-navigation-group-side-nav) .selected {\n background-color: var(--navigation-group-hover);\n color: var(--navigation-group-text-hover);\n}\n\n:host(.ic-navigation-group-side-nav) .navigation-group:focus {\n box-shadow: var(--ic-border-focus-inset);\n border-radius: var(--ic-border-radius-inset);\n background: none;\n}\n\n:host(.ic-navigation-group-side-nav) .ic-typography-caption {\n position: var(--navigation-group-title-position);\n left: var(--navigation-group-title-position-left);\n white-space: nowrap;\n}\n","import {\n Component,\n Element,\n Host,\n Prop,\n State,\n Listen,\n h,\n Method,\n} from \"@stencil/core\";\n\nimport {\n DEVICE_SIZES,\n getCurrentDeviceSize,\n getBrandForegroundAppearance,\n getNavItemParentDetails,\n} from \"../../utils/helpers\";\nimport {\n IcNavType,\n IcBrand,\n IcBrandForeground,\n IcBrandForegroundNoDefault,\n IcThemeMode,\n} from \"../../utils/types\";\n\nimport chevronIcon from \"../../assets/chevron-icon.svg\";\n@Component({\n tag: \"ic-navigation-group\",\n styleUrl: \"ic-navigation-group.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class NavigationGroup {\n private allGroupedNavigationItems: HTMLIcNavigationItemElement[] = [];\n private collapsedNavItemsHeight: string;\n private dropdown: HTMLElement;\n private DYNAMIC_GROUPED_LINKS_HEIGHT_MS = 100;\n private expandedNavItemsHeight: string;\n private groupEl: HTMLElement;\n private IC_NAVIGATION_ITEM = \"ic-navigation-item\";\n private isSideNavExpanded: boolean;\n private mouseGate: boolean = false;\n private nodeName = \"IC-NAVIGATION-GROUP\";\n private GROUPED_LINKS_WRAPPER_CLASS = \".grouped-links-wrapper\";\n\n @Element() el: HTMLIcNavigationGroupElement;\n\n @State() deviceSize: number = DEVICE_SIZES.XL;\n @State() dropdownOpen: boolean = false;\n @State() expanded: boolean = true;\n @State() focusStyle: IcBrandForegroundNoDefault | IcBrandForeground =\n getBrandForegroundAppearance();\n @State() inTopNavSideMenu: boolean = false;\n @State() navigationType: IcNavType | \"\";\n @State() parentEl: HTMLElement;\n\n /**\n * If `true`, the group will be expandable in the side menu.\n */\n @Prop() expandable: boolean = false;\n\n /**\n * The label to display on the group.\n */\n @Prop() label: string;\n\n /**\n * Sets the theme color to the dark or light theme color. \"inherit\" will set the color based on the system settings or ic-theme component.\n */\n @Prop() theme?: IcThemeMode = \"inherit\";\n\n disconnectedCallback(): void {\n if (this.navigationType === \"side\") {\n this.parentEl?.removeEventListener(\n \"icSideNavExpanded\",\n this.sideNavExpandHandler\n );\n } else if (this.navigationType === \"top\") {\n this.parentEl?.removeEventListener(\n \"icTopNavResized\",\n this.topNavResizedHandler\n );\n }\n }\n\n componentWillLoad(): void {\n this.deviceSize = getCurrentDeviceSize();\n const { navType, parent } = getNavItemParentDetails(this.el);\n this.navigationType = navType;\n this.parentEl = parent;\n\n if (this.navigationType === \"side\") {\n this.parentEl.addEventListener(\n \"icSideNavExpanded\",\n this.sideNavExpandHandler\n );\n } else if (this.navigationType === \"top\") {\n this.parentEl.addEventListener(\n \"icTopNavResized\",\n this.topNavResizedHandler\n );\n if (\n this.deviceSize <=\n (this.parentEl as HTMLIcTopNavigationElement).customMobileBreakpoint\n )\n this.inTopNavSideMenu = true;\n }\n }\n\n componentDidLoad(): void {\n this.allGroupedNavigationItems = Array.from(\n this.el.querySelectorAll(this.IC_NAVIGATION_ITEM)\n );\n\n /**\n * debounce is required as the incorrect height was retrieved instantly after\n * componentDidLoad is invoked.\n */\n setTimeout(\n () => this.setInitialGroupedLinksWrapperHeight(),\n this.DYNAMIC_GROUPED_LINKS_HEIGHT_MS\n );\n }\n\n @Listen(\"childBlur\")\n childBlurHandler(): void {\n this.hideDropdown();\n }\n\n @Listen(\"navItemClicked\")\n navItemClickHandler(): void {\n this.hideDropdown();\n }\n\n @Listen(\"brandChange\", { target: \"document\" })\n brandChangeHandler(ev: CustomEvent<IcBrand>): void {\n this.focusStyle = ev.detail.mode;\n }\n\n /**\n * Sets focus on the nav item.\n */\n @Method()\n async setFocus(): Promise<void> {\n if (this.groupEl) {\n this.groupEl.focus();\n }\n }\n\n private sideNavExpandHandler = (event?: CustomEvent): void => {\n this.isSideNavExpanded = event.detail.sideNavExpanded;\n const linkWrapper = this.el.shadowRoot.querySelector(\n this.GROUPED_LINKS_WRAPPER_CLASS\n ) as HTMLElement;\n\n if (!linkWrapper) return;\n\n if (this.isSideNavExpanded) {\n if (this.expanded && this.expandedNavItemsHeight) {\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.expandedNavItemsHeight\n );\n } else if (this.expanded) {\n setTimeout(() => {\n this.expandedNavItemsHeight = this.getNavigationChildItemsHeight();\n\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.expandedNavItemsHeight\n );\n }, this.DYNAMIC_GROUPED_LINKS_HEIGHT_MS);\n }\n } else {\n if (this.expanded && this.collapsedNavItemsHeight) {\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.collapsedNavItemsHeight\n );\n } else if (this.expanded) {\n setTimeout(() => {\n this.collapsedNavItemsHeight = this.getNavigationChildItemsHeight();\n\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.collapsedNavItemsHeight\n );\n }, this.DYNAMIC_GROUPED_LINKS_HEIGHT_MS);\n }\n }\n };\n\n private topNavResizedHandler = ({\n detail,\n }: CustomEvent<{ size: number }>): void => {\n const { size } = detail;\n if (size !== this.deviceSize) {\n this.deviceSize = size;\n this.inTopNavSideMenu =\n size <=\n ((this.parentEl as HTMLIcTopNavigationElement)\n ?.customMobileBreakpoint || DEVICE_SIZES.L);\n }\n };\n\n private toggleDropdown() {\n this.dropdownOpen = !this.dropdownOpen;\n }\n\n private setGroupedNavItemTabIndex = (tabIndexValue: string) => {\n this.el\n .querySelectorAll(this.IC_NAVIGATION_ITEM)\n .forEach((navigationItem) => {\n const navItem =\n navigationItem.shadowRoot.querySelector(\"a\") ||\n navigationItem.querySelector(\"a\");\n if (navItem) {\n navItem.setAttribute(\"tabindex\", tabIndexValue);\n }\n });\n };\n\n private toggleGroupedLinkWrapperHeight = (\n wrapper: HTMLElement,\n expanded: boolean\n ) => {\n if (!wrapper) return;\n\n if (expanded) {\n if (this.isSideNavExpanded) {\n this.setGroupedLinksElementHeight(wrapper, this.expandedNavItemsHeight);\n } else {\n this.setGroupedLinksElementHeight(\n wrapper,\n this.collapsedNavItemsHeight\n );\n }\n this.setGroupedNavItemTabIndex(\"0\");\n } else {\n wrapper.style.setProperty(\"--navigation-child-items-height\", \"0\");\n this.setGroupedNavItemTabIndex(\"-1\");\n }\n };\n\n private toggleExpanded = () => {\n this.expanded = !this.expanded;\n const linkWrapper = this.el.shadowRoot.querySelector(\n this.GROUPED_LINKS_WRAPPER_CLASS\n ) as HTMLElement;\n this.toggleGroupedLinkWrapperHeight(linkWrapper, this.expanded);\n };\n\n private showDropdown() {\n if (!this.dropdownOpen) {\n this.toggleDropdown();\n }\n }\n\n private hideDropdown() {\n document.removeEventListener(\"keydown\", this.handleKeydown);\n if (this.dropdownOpen) {\n this.toggleDropdown();\n }\n }\n\n private handleClick = (ev: MouseEvent) => {\n if (this.navigationType === \"top\" && ev.detail) {\n this.toggleDropdown();\n } else {\n this.toggleExpanded();\n }\n };\n\n private handleBlur = (ev: FocusEvent) => {\n const target = ev.relatedTarget as HTMLElement;\n if (!this.el.contains(target)) {\n this.hideDropdown();\n }\n };\n\n private handleTopNavKeydown = (ev: KeyboardEvent) => {\n if (ev.key === \" \" || ev.key === \"Enter\") {\n this.toggleDropdown();\n } else if (!this.inTopNavSideMenu && ev.key === \"Escape\") {\n this.hideDropdown();\n }\n };\n\n private handleKeydown = (ev: KeyboardEvent) => {\n if (ev.key === \"Enter\" || ev.key === \" \" || ev.key === \"Escape\") {\n switch (this.navigationType) {\n case \"top\":\n this.handleTopNavKeydown(ev as KeyboardEvent);\n break;\n case \"side\":\n this.toggleExpanded();\n ev.preventDefault();\n break;\n default:\n this.toggleExpanded();\n break;\n }\n }\n };\n\n private handleMouseLeave = (ev: MouseEvent) => {\n const relTarget = ev.relatedTarget as HTMLElement;\n\n this.mouseGate = false;\n\n if (\n !this.el.contains(relTarget) &&\n relTarget !== this.dropdown &&\n document.activeElement !== this.el &&\n !this.el.contains(document.activeElement) &&\n relTarget?.nodeName === this.nodeName &&\n this.dropdownOpen === true\n ) {\n this.mouseGate = true;\n this.hideDropdown();\n } else if (\n !this.el.contains(relTarget) &&\n relTarget !== this.dropdown &&\n !this.el.contains(document.activeElement)\n ) {\n this.mouseGate = false;\n setTimeout(() => {\n this.dropdownOpen ? this.hideDropdown() : null;\n }, 500);\n }\n };\n\n private handleMouseEnter = (ev: MouseEvent) => {\n const relTarget = ev.relatedTarget as HTMLElement;\n document.addEventListener(\"keydown\", this.handleKeydown);\n\n if (relTarget?.nodeName === this.nodeName && this.mouseGate === true) {\n this.showDropdown();\n } else if (\n this.dropdownOpen === false &&\n relTarget !== null &&\n this.mouseGate === false\n ) {\n this.mouseGate = true;\n setTimeout(() => {\n this.mouseGate && this.showDropdown();\n }, 500);\n }\n };\n\n private renderDropdownGroupedLinks = (): HTMLDivElement => (\n <div\n class={{\n [\"navigation-group-dropdown\"]: !this.inTopNavSideMenu,\n [\"navigation-group-dropdown-side-menu\"]: this.inTopNavSideMenu,\n [\"selected\"]: this.dropdownOpen && !this.inTopNavSideMenu,\n }}\n onMouseLeave={!this.inTopNavSideMenu ? this.handleMouseLeave : null}\n ref={(el) => (this.dropdown = el)}\n >\n <nav\n class={{\n [\"navigation-group-dropdown-items\"]: !this.inTopNavSideMenu,\n }}\n >\n <ul>\n <slot></slot>\n </ul>\n </nav>\n </div>\n );\n\n private renderGroupedLinks = (): HTMLDivElement => (\n <ul class=\"grouped-links-wrapper\">\n <slot></slot>\n </ul>\n );\n\n /**\n * Gets the total height of navigation links to improve\n * smoothness of expand/collapse animations\n */\n private getNavigationChildItemsHeight = (): string => {\n let navigationChildItemsHeight = 0;\n this.allGroupedNavigationItems.forEach((navItem) => {\n navigationChildItemsHeight += navItem.offsetHeight;\n });\n\n return `${navigationChildItemsHeight}px`;\n };\n\n private setInitialGroupedLinksWrapperHeight = () => {\n const linkWrapper = this.el.shadowRoot.querySelector(\n this.GROUPED_LINKS_WRAPPER_CLASS\n ) as HTMLElement;\n\n if (!linkWrapper) return;\n\n if (\n !this.isSideNavExpanded &&\n !this.collapsedNavItemsHeight &&\n this.expanded\n ) {\n this.collapsedNavItemsHeight = this.getNavigationChildItemsHeight();\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.collapsedNavItemsHeight\n );\n }\n\n if (this.isSideNavExpanded && this.expanded) {\n this.expandedNavItemsHeight = this.getNavigationChildItemsHeight();\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.expandedNavItemsHeight\n );\n }\n };\n\n private renderNavigationItems = (): HTMLDivElement | null => {\n if (this.dropdownOpen || (this.inTopNavSideMenu && !this.expandable)) {\n return this.renderDropdownGroupedLinks();\n }\n\n if (this.navigationType !== \"top\") {\n return this.renderGroupedLinks();\n }\n\n return null;\n };\n\n private setGroupedLinksElementHeight(\n groupedNavItemWrapper: HTMLElement,\n height: string\n ) {\n groupedNavItemWrapper.style.setProperty(\n \"--navigation-child-items-height\",\n height\n );\n }\n\n render() {\n const { label, dropdownOpen, inTopNavSideMenu, expandable } = this;\n\n return (\n <Host\n class={{\n [\"in-side-menu\"]: inTopNavSideMenu,\n \"ic-navigation-group-expanded\": this.expanded,\n \"ic-navigation-group-collapsed\": !this.expanded,\n [\"ic-navigation-group-side-nav\"]: this.navigationType === \"side\",\n [`ic-theme-${this.theme}`]: this.theme !== \"inherit\",\n }}\n role=\"listitem\"\n >\n <button\n onMouseEnter={\n !inTopNavSideMenu &&\n this.navigationType === \"top\" &&\n this.handleMouseEnter\n }\n onMouseLeave={this.navigationType === \"top\" && this.handleMouseLeave}\n tabindex={inTopNavSideMenu && !expandable ? \"-1\" : \"0\"}\n onBlur={this.handleBlur}\n onClick={expandable ? this.handleClick : null}\n onKeyDown={this.handleKeydown}\n class={{\n [\"navigation-group\"]: true,\n [this.focusStyle]: !inTopNavSideMenu,\n [\"navigation-group-side-menu\"]: inTopNavSideMenu && !expandable,\n [\"navigation-group-side-menu-collapsed\"]:\n inTopNavSideMenu && expandable && !dropdownOpen,\n [\"navigation-group-side-menu-expanded\"]:\n inTopNavSideMenu && expandable && dropdownOpen,\n [\"selected\"]: dropdownOpen && !inTopNavSideMenu,\n }}\n ref={(el) => (this.groupEl = el)}\n aria-expanded={`${dropdownOpen || this.expanded}`}\n aria-haspopup={`${\n !inTopNavSideMenu && this.navigationType === \"top\"\n }`}\n >\n <ic-typography\n variant={this.navigationType === \"side\" ? \"caption\" : \"label\"}\n >\n {label}\n </ic-typography>\n {this.navigationType === \"side\" && expandable && (\n <div\n class={{\n \"chevron-toggle-icon-wrapper\": true,\n \"chevron-toggle-icon-closed\": this.expanded,\n }}\n innerHTML={chevronIcon}\n ></div>\n )}\n </button>\n {this.renderNavigationItems()}\n </Host>\n );\n }\n}\n"],"version":3}
1
+ {"file":"ic-navigation-group.entry.cjs.js","mappings":"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","names":["DEVICE_SIZES","getBrandForegroundAppearance","h","getCurrentDeviceSize","getNavItemParentDetails","Host","chevronIcon"],"sources":["src/components/ic-navigation-group/ic-navigation-group.css?tag=ic-navigation-group&encapsulation=shadow","src/components/ic-navigation-group/ic-navigation-group.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n/**\n * @prop --ic-z-index-navigation-item: z-index of navigation group item\n */\n\n:host {\n display: block;\n\n --ic-typography-color: currentcolor;\n}\n\n:host(.in-side-menu) {\n border-bottom: var(--ic-border-width) solid\n var(--ic-divider-background-monochrome);\n padding: var(--ic-space-md) 0;\n}\n\n:host .navigation-group {\n height: 100%;\n width: fit-content;\n color: var(--ic-brand-text-color);\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 0 var(--ic-space-md) var(--ic-space-xxs);\n transition: var(--ic-easing-transition-slow);\n position: relative;\n background: none;\n border: none;\n white-space: nowrap;\n}\n\n:host(.in-side-menu) .navigation-group {\n height: 2.5rem;\n width: 100%;\n text-align: left;\n}\n\n:host(.in-side-menu) .navigation-group .ic-typography-label {\n width: 11.875rem;\n}\n\n:host(.in-side-menu) .navigation-group-side-menu {\n color: var(--ic-top-navigation-nav-group-link);\n justify-content: flex-start;\n padding: 0 var(--ic-space-md) 0 var(--ic-space-md);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-collapsed,\n:host(.in-side-menu) .navigation-group-side-menu-expanded {\n color: var(--ic-top-navigation-nav-group-link);\n justify-content: flex-start;\n padding-left: var(--ic-space-md);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-expanded {\n margin-bottom: var(--ic-space-xs);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-collapsed::after,\n:host(.in-side-menu) .navigation-group-side-menu-expanded::after {\n border-style: solid;\n border-width: 0.125em 0.125em 0 0;\n content: \"\";\n display: inline-block;\n height: 0.45em;\n left: 0.75em;\n position: relative;\n top: -0.1em;\n transform: rotate(135deg);\n vertical-align: top;\n width: 0.45em;\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-expanded::after {\n top: 0.15em;\n transform: rotate(-45deg);\n}\n\n:host .navigation-group:hover,\n:host .navigation-group:active,\n:host .selected {\n background-color: var(--ic-architectural-20);\n color: var(--ic-color-text-primary-light);\n outline: none;\n cursor: pointer;\n}\n\n:host(:not(.in-side-menu)) .navigation-group:focus {\n box-shadow: var(--ic-border-focus);\n border-radius: var(--ic-border-radius);\n outline: var(--ic-hc-focus-outline);\n z-index: var(--ic-z-index-navigation-item);\n transition: box-shadow var(--ic-easing-transition-fast);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu:hover,\n:host(.in-side-menu) .navigation-group-side-menu:focus {\n background-color: var(--ic-top-navigation-nav-group-hover);\n color: var(--ic-top-navigation-nav-group-link);\n cursor: auto;\n box-shadow: none;\n outline: none;\n}\n\n:host(.in-side-menu) .navigation-group-side-menu:active {\n background-color: var(--ic-top-navigation-nav-group-pressed);\n color: var(--ic-top-navigation-nav-group-link);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu:focus {\n outline: var(--ic-hc-focus-outline);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-expanded:hover:not(:focus),\n:host(.in-side-menu) .navigation-group-side-menu-collapsed:hover:not(:focus) {\n background-color: var(--ic-action-dark-bg-hover);\n color: var(--ic-action-default);\n cursor: pointer;\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-expanded:active:not(:focus),\n:host(.in-side-menu) .navigation-group-side-menu-collapsed:active:not(:focus) {\n background-color: var(--ic-action-dark-bg-pressed);\n color: var(--ic-action-default);\n}\n\n:host(.in-side-menu) .navigation-group-side-menu-expanded:focus,\n:host(.in-side-menu) .navigation-group-side-menu-collapsed:focus {\n color: var(--ic-action-default);\n box-shadow: var(--ic-border-focus-inset);\n border-radius: var(--ic-border-radius-inset);\n outline: var(--ic-hc-focus-outline);\n}\n\n:host .navigation-group-dropdown {\n background-color: var(--ic-top-navigation-menu-background);\n border-bottom: var(--ic-space-1px) solid var(--ic-top-navigation-menu-border);\n position: absolute;\n left: 0;\n right: 0;\n padding: var(--ic-space-xs) var(--ic-space-md);\n box-shadow: 0 0.375rem 0.5rem -0.375rem rgba(0 0 0 / 20%);\n z-index: calc(var(--ic-z-index-navigation-item) - 1);\n}\n\n:host .navigation-group-dropdown-items-list {\n list-style: none;\n display: flex;\n flex-flow: column wrap;\n align-content: flex-start;\n padding-left: var(--ic-space-md);\n max-height: 16.5rem;\n}\n\n:host .chevron-toggle-icon-wrapper {\n display: flex;\n align-items: center;\n}\n\n:host .chevron-toggle-icon-wrapper svg {\n transform: rotate(90deg);\n height: var(--ic-space-lg);\n width: var(--ic-space-lg);\n}\n\n:host .chevron-toggle-icon-closed svg {\n transform: rotate(-90deg);\n}\n\n:host(.ic-navigation-group-expanded) .grouped-links-wrapper {\n height: var(--navigation-child-items-height, auto) !important;\n transition: var(--ic-easing-transition-slow);\n overflow: hidden;\n}\n\n:host(.ic-navigation-group-side-nav) .link,\n:host(.ic-navigation-group-side-nav) ::slotted(a) {\n height: var(--navigation-child-items-height, auto);\n}\n\n:host(.ic-navigation-group-collapsed) .grouped-links-wrapper {\n height: 0;\n transition: var(--ic-easing-transition-slow);\n overflow: hidden;\n}\n\n:host(.ic-navigation-group-side-nav) .navigation-group {\n height: var(--navigation-group-height);\n width: var(--navigation-group-width);\n justify-content: var(--navigation-group-justify-content);\n padding-right: var(--navigation-group-expand-toggle-padding);\n}\n\n:host(.ic-navigation-group-side-nav) .navigation-group:hover,\n:host(.ic-navigation-group-side-nav) .navigation-group:active,\n:host(.ic-navigation-group-side-nav) .selected {\n background-color: var(--navigation-group-hover);\n color: var(--navigation-group-text-hover);\n}\n\n:host(.ic-navigation-group-side-nav) .navigation-group:focus {\n box-shadow: var(--ic-border-focus-inset);\n border-radius: var(--ic-border-radius-inset);\n background: none;\n}\n\n:host(.ic-navigation-group-side-nav) .ic-typography-caption {\n position: var(--navigation-group-title-position);\n left: var(--navigation-group-title-position-left);\n white-space: nowrap;\n}\n","import {\n Component,\n Element,\n Host,\n Prop,\n State,\n Listen,\n h,\n Method,\n Event,\n EventEmitter,\n} from \"@stencil/core\";\n\nimport {\n DEVICE_SIZES,\n getCurrentDeviceSize,\n getBrandForegroundAppearance,\n getNavItemParentDetails,\n} from \"../../utils/helpers\";\nimport {\n IcNavType,\n IcBrand,\n IcBrandForeground,\n IcBrandForegroundNoDefault,\n IcThemeMode,\n} from \"../../utils/types\";\n\nimport chevronIcon from \"../../assets/chevron-icon.svg\";\nimport { IcNavigationOpenEventDetail } from \"./ic-navigation-group.types\";\n\n@Component({\n tag: \"ic-navigation-group\",\n styleUrl: \"ic-navigation-group.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class NavigationGroup {\n private allGroupedNavigationItems: HTMLIcNavigationItemElement[] = [];\n private collapsedNavItemsHeight: string;\n private dropdown?: HTMLElement;\n private DYNAMIC_GROUPED_LINKS_HEIGHT_MS = 100;\n private expandedNavItemsHeight: string;\n private groupEl?: HTMLElement;\n private IC_NAVIGATION_ITEM = \"ic-navigation-item\";\n private isSideNavExpanded: boolean;\n private mouseGate: boolean = false;\n private nodeName = \"IC-NAVIGATION-GROUP\";\n private GROUPED_LINKS_WRAPPER_CLASS = \".grouped-links-wrapper\";\n\n @Element() el: HTMLIcNavigationGroupElement;\n\n @State() deviceSize: number = DEVICE_SIZES.XL;\n @State() dropdownOpen: boolean = false;\n @State() expanded: boolean = true;\n @State() focusStyle: IcBrandForegroundNoDefault | IcBrandForeground =\n getBrandForegroundAppearance();\n @State() inTopNavSideMenu: boolean = false;\n @State() navigationType: IcNavType | \"\";\n @State() parentEl: HTMLElement | null;\n\n /**\n * If `true`, the group will be expandable in the side menu.\n */\n @Prop() expandable?: boolean = false;\n\n /**\n * The label to display on the group.\n */\n @Prop() label!: string;\n\n /**\n * Sets the theme color to the dark or light theme color. \"inherit\" will set the color based on the system settings or ic-theme component.\n */\n @Prop() theme?: IcThemeMode = \"inherit\";\n\n /**\n * @internal Emitted when a navigation group opens.\n */\n @Event() navigationGroupOpened: EventEmitter<IcNavigationOpenEventDetail>;\n\n disconnectedCallback(): void {\n if (this.navigationType === \"side\") {\n this.parentEl?.removeEventListener(\n \"icSideNavExpanded\",\n this.sideNavExpandHandler as EventListener\n );\n } else if (this.navigationType === \"top\") {\n this.parentEl?.removeEventListener(\n \"icTopNavResized\",\n this.topNavResizedHandler as EventListener\n );\n }\n }\n\n componentWillLoad(): void {\n this.deviceSize = getCurrentDeviceSize();\n const { navType, parent } = getNavItemParentDetails(this.el);\n this.navigationType = navType;\n this.parentEl = parent;\n\n if (this.navigationType === \"side\") {\n this.parentEl?.addEventListener(\n \"icSideNavExpanded\",\n this.sideNavExpandHandler as EventListener\n );\n } else if (this.navigationType === \"top\") {\n this.parentEl?.addEventListener(\n \"icTopNavResized\",\n this.topNavResizedHandler as EventListener\n );\n if (\n this.deviceSize <=\n (this.parentEl as HTMLIcTopNavigationElement).customMobileBreakpoint!\n )\n this.inTopNavSideMenu = true;\n }\n }\n\n componentDidLoad(): void {\n this.allGroupedNavigationItems = Array.from(\n this.el.querySelectorAll(this.IC_NAVIGATION_ITEM)\n );\n\n /**\n * debounce is required as the incorrect height was retrieved instantly after\n * componentDidLoad is invoked.\n */\n setTimeout(\n () => this.setInitialGroupedLinksWrapperHeight(),\n this.DYNAMIC_GROUPED_LINKS_HEIGHT_MS\n );\n }\n\n @Listen(\"childBlur\")\n childBlurHandler(): void {\n this.hideDropdown();\n }\n\n @Listen(\"navigationGroupOpened\", { target: \"document\" })\n handleNavigationGroupOpened(event: CustomEvent): void {\n if (event.detail.source !== this.el) {\n this.hideDropdown();\n }\n }\n\n @Listen(\"navItemClicked\")\n navItemClickHandler(): void {\n this.hideDropdown();\n }\n\n @Listen(\"brandChange\", { target: \"document\" })\n brandChangeHandler(ev: CustomEvent<IcBrand>): void {\n this.focusStyle = ev.detail.mode;\n }\n\n /**\n * Sets focus on the nav item.\n */\n @Method()\n async setFocus(): Promise<void> {\n if (this.groupEl) {\n this.groupEl.focus();\n }\n }\n\n private sideNavExpandHandler = (event: CustomEvent): void => {\n this.isSideNavExpanded = event.detail.sideNavExpanded;\n const linkWrapper = this.el.shadowRoot?.querySelector(\n this.GROUPED_LINKS_WRAPPER_CLASS\n ) as HTMLElement;\n\n if (!linkWrapper) return;\n\n if (this.isSideNavExpanded) {\n if (this.expanded && this.expandedNavItemsHeight) {\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.expandedNavItemsHeight\n );\n } else if (this.expanded) {\n setTimeout(() => {\n this.expandedNavItemsHeight = this.getNavigationChildItemsHeight();\n\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.expandedNavItemsHeight\n );\n }, this.DYNAMIC_GROUPED_LINKS_HEIGHT_MS);\n }\n } else {\n if (this.expanded && this.collapsedNavItemsHeight) {\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.collapsedNavItemsHeight\n );\n } else if (this.expanded) {\n setTimeout(() => {\n this.collapsedNavItemsHeight = this.getNavigationChildItemsHeight();\n\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.collapsedNavItemsHeight\n );\n }, this.DYNAMIC_GROUPED_LINKS_HEIGHT_MS);\n }\n }\n };\n\n private topNavResizedHandler = ({\n detail,\n }: CustomEvent<{ size: number }>): void => {\n const { size } = detail;\n if (size !== this.deviceSize) {\n this.deviceSize = size;\n this.inTopNavSideMenu =\n size <=\n ((this.parentEl as HTMLIcTopNavigationElement)\n ?.customMobileBreakpoint || DEVICE_SIZES.L);\n }\n };\n\n private toggleDropdown() {\n this.dropdownOpen = !this.dropdownOpen;\n }\n\n private setGroupedNavItemTabIndex = (tabIndexValue: string) => {\n this.el\n .querySelectorAll(this.IC_NAVIGATION_ITEM)\n .forEach((navigationItem) => {\n const navItem =\n navigationItem.shadowRoot?.querySelector(\"a\") ||\n navigationItem.querySelector(\"a\");\n if (navItem) {\n navItem.setAttribute(\"tabindex\", tabIndexValue);\n }\n });\n };\n\n private toggleGroupedLinkWrapperHeight = (\n wrapper: HTMLElement,\n expanded: boolean\n ) => {\n if (!wrapper) return;\n\n if (expanded) {\n if (this.isSideNavExpanded) {\n this.setGroupedLinksElementHeight(wrapper, this.expandedNavItemsHeight);\n } else {\n this.setGroupedLinksElementHeight(\n wrapper,\n this.collapsedNavItemsHeight\n );\n }\n this.setGroupedNavItemTabIndex(\"0\");\n } else {\n wrapper.style.setProperty(\"--navigation-child-items-height\", \"0\");\n this.setGroupedNavItemTabIndex(\"-1\");\n }\n };\n\n private toggleExpanded = () => {\n this.expanded = !this.expanded;\n const linkWrapper = this.el.shadowRoot?.querySelector(\n this.GROUPED_LINKS_WRAPPER_CLASS\n ) as HTMLElement;\n this.toggleGroupedLinkWrapperHeight(linkWrapper, this.expanded);\n };\n\n private showDropdown() {\n if (!this.dropdownOpen) {\n this.navigationGroupOpened.emit({\n source: this.el,\n });\n\n this.toggleDropdown();\n }\n }\n\n private hideDropdown() {\n document.removeEventListener(\"keydown\", this.handleKeydown);\n if (this.dropdownOpen) {\n this.toggleDropdown();\n }\n }\n\n private handleClick = (ev: MouseEvent) => {\n if (this.navigationType === \"top\" && ev.detail) {\n this.toggleDropdown();\n } else {\n this.toggleExpanded();\n }\n };\n\n private handleBlur = (ev: FocusEvent) => {\n const target = ev.relatedTarget as HTMLElement;\n if (!this.el.contains(target)) {\n this.hideDropdown();\n }\n };\n\n private handleTopNavKeydown = (ev: KeyboardEvent) => {\n if (ev.key === \" \" || ev.key === \"Enter\") {\n this.toggleDropdown();\n } else if (!this.inTopNavSideMenu && ev.key === \"Escape\") {\n this.hideDropdown();\n }\n };\n\n private handleKeydown = (ev: KeyboardEvent) => {\n if (ev.key === \"Enter\" || ev.key === \" \" || ev.key === \"Escape\") {\n switch (this.navigationType) {\n case \"top\":\n this.handleTopNavKeydown(ev as KeyboardEvent);\n break;\n case \"side\":\n this.toggleExpanded();\n ev.preventDefault();\n break;\n default:\n this.toggleExpanded();\n break;\n }\n }\n };\n\n private handleMouseLeave = (ev: MouseEvent) => {\n const relTarget = ev.relatedTarget as HTMLElement;\n\n this.mouseGate = false;\n\n if (\n !this.el.contains(relTarget) &&\n relTarget !== this.dropdown &&\n document.activeElement !== this.el &&\n !this.el.contains(document.activeElement) &&\n relTarget?.nodeName === this.nodeName &&\n this.dropdownOpen === true\n ) {\n this.mouseGate = true;\n this.hideDropdown();\n } else if (\n !this.el.contains(relTarget) &&\n relTarget !== this.dropdown &&\n !this.el.contains(document.activeElement)\n ) {\n this.mouseGate = false;\n setTimeout(() => {\n this.dropdownOpen ? this.hideDropdown() : null;\n }, 500);\n }\n };\n\n private handleMouseEnter = (ev: MouseEvent) => {\n const relTarget = ev.relatedTarget as HTMLElement;\n document.addEventListener(\"keydown\", this.handleKeydown);\n\n if (relTarget?.nodeName === this.nodeName && this.mouseGate === true) {\n this.showDropdown();\n } else if (\n this.dropdownOpen === false &&\n relTarget !== null &&\n this.mouseGate === false\n ) {\n this.mouseGate = true;\n setTimeout(() => {\n this.mouseGate && this.showDropdown();\n }, 500);\n }\n };\n\n private renderDropdownGroupedLinks = (): HTMLDivElement => (\n <div\n class={{\n [\"navigation-group-dropdown\"]: !this.inTopNavSideMenu,\n [\"navigation-group-dropdown-side-menu\"]: this.inTopNavSideMenu,\n [\"selected\"]: this.dropdownOpen && !this.inTopNavSideMenu,\n }}\n onMouseLeave={!this.inTopNavSideMenu ? this.handleMouseLeave : undefined}\n ref={(el) => (this.dropdown = el)}\n >\n <nav\n class={{\n [\"navigation-group-dropdown-items\"]: !this.inTopNavSideMenu,\n }}\n >\n <ul>\n <slot></slot>\n </ul>\n </nav>\n </div>\n );\n\n private renderGroupedLinks = (): HTMLDivElement => (\n <ul class=\"grouped-links-wrapper\">\n <slot></slot>\n </ul>\n );\n\n /**\n * Gets the total height of navigation links to improve\n * smoothness of expand/collapse animations\n */\n private getNavigationChildItemsHeight = (): string => {\n let navigationChildItemsHeight = 0;\n this.allGroupedNavigationItems.forEach((navItem) => {\n navigationChildItemsHeight += navItem.offsetHeight;\n });\n\n return `${navigationChildItemsHeight}px`;\n };\n\n private setInitialGroupedLinksWrapperHeight = () => {\n const linkWrapper = this.el.shadowRoot?.querySelector(\n this.GROUPED_LINKS_WRAPPER_CLASS\n ) as HTMLElement;\n\n if (!linkWrapper) return;\n\n if (\n !this.isSideNavExpanded &&\n !this.collapsedNavItemsHeight &&\n this.expanded\n ) {\n this.collapsedNavItemsHeight = this.getNavigationChildItemsHeight();\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.collapsedNavItemsHeight\n );\n }\n\n if (this.isSideNavExpanded && this.expanded) {\n this.expandedNavItemsHeight = this.getNavigationChildItemsHeight();\n this.setGroupedLinksElementHeight(\n linkWrapper,\n this.expandedNavItemsHeight\n );\n }\n };\n\n private renderNavigationItems = (): HTMLDivElement | null => {\n if (this.dropdownOpen || (this.inTopNavSideMenu && !this.expandable)) {\n return this.renderDropdownGroupedLinks();\n }\n\n if (this.navigationType !== \"top\") {\n return this.renderGroupedLinks();\n }\n\n return null;\n };\n\n private setGroupedLinksElementHeight(\n groupedNavItemWrapper: HTMLElement,\n height: string\n ) {\n groupedNavItemWrapper.style.setProperty(\n \"--navigation-child-items-height\",\n height\n );\n }\n\n render() {\n const { label, dropdownOpen, inTopNavSideMenu, expandable } = this;\n\n return (\n <Host\n class={{\n [\"in-side-menu\"]: inTopNavSideMenu,\n \"ic-navigation-group-expanded\": this.expanded,\n \"ic-navigation-group-collapsed\": !this.expanded,\n [\"ic-navigation-group-side-nav\"]: this.navigationType === \"side\",\n [`ic-theme-${this.theme}`]: this.theme !== \"inherit\",\n }}\n role=\"listitem\"\n >\n <button\n onMouseEnter={\n !inTopNavSideMenu && this.navigationType === \"top\"\n ? this.handleMouseEnter\n : undefined\n }\n onMouseLeave={\n this.navigationType === \"top\" ? this.handleMouseLeave : undefined\n }\n tabindex={inTopNavSideMenu && !expandable ? \"-1\" : \"0\"}\n onBlur={this.handleBlur}\n onClick={expandable ? this.handleClick : undefined}\n onKeyDown={this.handleKeydown}\n class={{\n [\"navigation-group\"]: true,\n [this.focusStyle]: !inTopNavSideMenu,\n [\"navigation-group-side-menu\"]: inTopNavSideMenu && !expandable,\n [\"navigation-group-side-menu-collapsed\"]:\n inTopNavSideMenu && !!expandable && !dropdownOpen,\n [\"navigation-group-side-menu-expanded\"]:\n inTopNavSideMenu && !!expandable && dropdownOpen,\n [\"selected\"]: dropdownOpen && !inTopNavSideMenu,\n }}\n ref={(el) => (this.groupEl = el)}\n aria-expanded={`${dropdownOpen || this.expanded}`}\n aria-haspopup={`${\n !inTopNavSideMenu && this.navigationType === \"top\"\n }`}\n >\n <ic-typography\n variant={this.navigationType === \"side\" ? \"caption\" : \"label\"}\n >\n {label}\n </ic-typography>\n {this.navigationType === \"side\" && expandable && (\n <div\n class={{\n \"chevron-toggle-icon-wrapper\": true,\n \"chevron-toggle-icon-closed\": this.expanded,\n }}\n innerHTML={chevronIcon}\n ></div>\n )}\n </button>\n {this.renderNavigationItems()}\n </Host>\n );\n }\n}\n"],"version":3}