@ukic/canary-web-components 2.0.0-canary.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1298) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +162 -0
  3. package/dist/cjs/OpenInNew-f9958725.js +7 -0
  4. package/dist/cjs/OpenInNew-f9958725.js.map +1 -0
  5. package/dist/cjs/check-icon-b2f60716.js +10 -0
  6. package/dist/cjs/check-icon-b2f60716.js.map +1 -0
  7. package/dist/cjs/chevron-icon-2bb3a907.js +10 -0
  8. package/dist/cjs/chevron-icon-2bb3a907.js.map +1 -0
  9. package/dist/cjs/close-icon-8ccb0163.js +12 -0
  10. package/dist/cjs/close-icon-8ccb0163.js.map +1 -0
  11. package/dist/cjs/core.cjs.js +28 -0
  12. package/dist/cjs/core.cjs.js.map +1 -0
  13. package/dist/cjs/helpers-3811d14b.js +599 -0
  14. package/dist/cjs/helpers-3811d14b.js.map +1 -0
  15. package/dist/cjs/ic-alert.cjs.entry.js +73 -0
  16. package/dist/cjs/ic-alert.cjs.entry.js.map +1 -0
  17. package/dist/cjs/ic-back-to-top.cjs.entry.js +145 -0
  18. package/dist/cjs/ic-back-to-top.cjs.entry.js.map +1 -0
  19. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +188 -0
  20. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js.map +1 -0
  21. package/dist/cjs/ic-breadcrumb.cjs.entry.js +74 -0
  22. package/dist/cjs/ic-breadcrumb.cjs.entry.js.map +1 -0
  23. package/dist/cjs/ic-button_3.cjs.entry.js +560 -0
  24. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -0
  25. package/dist/cjs/ic-card.cjs.entry.js +126 -0
  26. package/dist/cjs/ic-card.cjs.entry.js.map +1 -0
  27. package/dist/cjs/ic-checkbox-group.cjs.entry.js +69 -0
  28. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -0
  29. package/dist/cjs/ic-checkbox.cjs.entry.js +114 -0
  30. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -0
  31. package/dist/cjs/ic-chip.cjs.entry.js +80 -0
  32. package/dist/cjs/ic-chip.cjs.entry.js.map +1 -0
  33. package/dist/cjs/ic-classification-banner.cjs.entry.js +42 -0
  34. package/dist/cjs/ic-classification-banner.cjs.entry.js.map +1 -0
  35. package/dist/cjs/ic-data-entity.cjs.entry.js +31 -0
  36. package/dist/cjs/ic-data-entity.cjs.entry.js.map +1 -0
  37. package/dist/cjs/ic-data-row.cjs.entry.js +91 -0
  38. package/dist/cjs/ic-data-row.cjs.entry.js.map +1 -0
  39. package/dist/cjs/ic-dialog.cjs.entry.js +295 -0
  40. package/dist/cjs/ic-dialog.cjs.entry.js.map +1 -0
  41. package/dist/cjs/ic-divider.cjs.entry.js +30 -0
  42. package/dist/cjs/ic-divider.cjs.entry.js.map +1 -0
  43. package/dist/cjs/ic-footer-link-group.cjs.entry.js +71 -0
  44. package/dist/cjs/ic-footer-link-group.cjs.entry.js.map +1 -0
  45. package/dist/cjs/ic-footer-link.cjs.entry.js +67 -0
  46. package/dist/cjs/ic-footer-link.cjs.entry.js.map +1 -0
  47. package/dist/cjs/ic-footer.cjs.entry.js +90 -0
  48. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -0
  49. package/dist/cjs/ic-hero.cjs.entry.js +75 -0
  50. package/dist/cjs/ic-hero.cjs.entry.js.map +1 -0
  51. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +177 -0
  52. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js.map +1 -0
  53. package/dist/cjs/ic-input-component-container_3.cjs.entry.js +699 -0
  54. package/dist/cjs/ic-input-component-container_3.cjs.entry.js.map +1 -0
  55. package/dist/cjs/ic-input-label_2.cjs.entry.js +85 -0
  56. package/dist/cjs/ic-input-label_2.cjs.entry.js.map +1 -0
  57. package/dist/cjs/ic-link.cjs.entry.js +76 -0
  58. package/dist/cjs/ic-link.cjs.entry.js.map +1 -0
  59. package/dist/cjs/ic-menu-group.cjs.entry.js +24 -0
  60. package/dist/cjs/ic-menu-group.cjs.entry.js.map +1 -0
  61. package/dist/cjs/ic-menu-item.cjs.entry.js +122 -0
  62. package/dist/cjs/ic-menu-item.cjs.entry.js.map +1 -0
  63. package/dist/cjs/ic-navigation-button.cjs.entry.js +88 -0
  64. package/dist/cjs/ic-navigation-button.cjs.entry.js.map +1 -0
  65. package/dist/cjs/ic-navigation-group.cjs.entry.js +289 -0
  66. package/dist/cjs/ic-navigation-group.cjs.entry.js.map +1 -0
  67. package/dist/cjs/ic-navigation-item.cjs.entry.js +154 -0
  68. package/dist/cjs/ic-navigation-item.cjs.entry.js.map +1 -0
  69. package/dist/cjs/ic-navigation-menu.cjs.entry.js +124 -0
  70. package/dist/cjs/ic-navigation-menu.cjs.entry.js.map +1 -0
  71. package/dist/cjs/ic-page-header.cjs.entry.js +105 -0
  72. package/dist/cjs/ic-page-header.cjs.entry.js.map +1 -0
  73. package/dist/cjs/ic-pagination-bar.cjs.entry.js +270 -0
  74. package/dist/cjs/ic-pagination-bar.cjs.entry.js.map +1 -0
  75. package/dist/cjs/ic-pagination_4.cjs.entry.js +1115 -0
  76. package/dist/cjs/ic-pagination_4.cjs.entry.js.map +1 -0
  77. package/dist/cjs/ic-popover-menu.cjs.entry.js +237 -0
  78. package/dist/cjs/ic-popover-menu.cjs.entry.js.map +1 -0
  79. package/dist/cjs/ic-radio-group.cjs.entry.js +130 -0
  80. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -0
  81. package/dist/cjs/ic-radio-option.cjs.entry.js +141 -0
  82. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -0
  83. package/dist/cjs/ic-search-bar.cjs.entry.js +493 -0
  84. package/dist/cjs/ic-search-bar.cjs.entry.js.map +1 -0
  85. package/dist/cjs/ic-section-container.cjs.entry.js +29 -0
  86. package/dist/cjs/ic-section-container.cjs.entry.js.map +1 -0
  87. package/dist/cjs/ic-side-navigation.cjs.entry.js +435 -0
  88. package/dist/cjs/ic-side-navigation.cjs.entry.js.map +1 -0
  89. package/dist/cjs/ic-skeleton.cjs.entry.js +59 -0
  90. package/dist/cjs/ic-skeleton.cjs.entry.js.map +1 -0
  91. package/dist/cjs/ic-status-tag.cjs.entry.js +36 -0
  92. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -0
  93. package/dist/cjs/ic-step.cjs.entry.js +140 -0
  94. package/dist/cjs/ic-step.cjs.entry.js.map +1 -0
  95. package/dist/cjs/ic-stepper.cjs.entry.js +221 -0
  96. package/dist/cjs/ic-stepper.cjs.entry.js.map +1 -0
  97. package/dist/cjs/ic-switch.cjs.entry.js +86 -0
  98. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -0
  99. package/dist/cjs/ic-tab-context.cjs.entry.js +269 -0
  100. package/dist/cjs/ic-tab-context.cjs.entry.js.map +1 -0
  101. package/dist/cjs/ic-tab-group.cjs.entry.js +38 -0
  102. package/dist/cjs/ic-tab-group.cjs.entry.js.map +1 -0
  103. package/dist/cjs/ic-tab-panel.cjs.entry.js +44 -0
  104. package/dist/cjs/ic-tab-panel.cjs.entry.js.map +1 -0
  105. package/dist/cjs/ic-tab.cjs.entry.js +103 -0
  106. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -0
  107. package/dist/cjs/ic-theme.cjs.entry.js +62 -0
  108. package/dist/cjs/ic-theme.cjs.entry.js.map +1 -0
  109. package/dist/cjs/ic-toast-region.cjs.entry.js +48 -0
  110. package/dist/cjs/ic-toast-region.cjs.entry.js.map +1 -0
  111. package/dist/cjs/ic-toast.cjs.entry.js +169 -0
  112. package/dist/cjs/ic-toast.cjs.entry.js.map +1 -0
  113. package/dist/cjs/ic-top-navigation.cjs.entry.js +217 -0
  114. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -0
  115. package/dist/cjs/ic-typography.cjs.entry.js +128 -0
  116. package/dist/cjs/ic-typography.cjs.entry.js.map +1 -0
  117. package/dist/cjs/ic-unstable-data-table.cjs.entry.js +271 -0
  118. package/dist/cjs/ic-unstable-data-table.cjs.entry.js.map +1 -0
  119. package/dist/cjs/index-4f4d2b43.js +2689 -0
  120. package/dist/cjs/index-4f4d2b43.js.map +1 -0
  121. package/dist/cjs/index.cjs.js +4 -0
  122. package/dist/cjs/index.cjs.js.map +1 -0
  123. package/dist/cjs/loader.cjs.js +24 -0
  124. package/dist/cjs/loader.cjs.js.map +1 -0
  125. package/dist/cjs/popper-d7adcfc6.js +1796 -0
  126. package/dist/cjs/popper-d7adcfc6.js.map +1 -0
  127. package/dist/cjs/types-3eb02246.js +16 -0
  128. package/dist/cjs/types-3eb02246.js.map +1 -0
  129. package/dist/collection/assets/OpenInNew.svg +1 -0
  130. package/dist/collection/assets/back-icon.svg +3 -0
  131. package/dist/collection/assets/check-icon.svg +3 -0
  132. package/dist/collection/assets/chevron-icon.svg +3 -0
  133. package/dist/collection/assets/clear-icon.svg +3 -0
  134. package/dist/collection/assets/close-icon.svg +5 -0
  135. package/dist/collection/assets/dismiss-icon.svg +3 -0
  136. package/dist/collection/assets/error-icon.svg +6 -0
  137. package/dist/collection/assets/hamburger-menu-icon.svg +5 -0
  138. package/dist/collection/assets/info-icon.svg +6 -0
  139. package/dist/collection/assets/neutral-icon.svg +6 -0
  140. package/dist/collection/assets/pagination-first-last.svg +3 -0
  141. package/dist/collection/assets/pagination-next-previous.svg +3 -0
  142. package/dist/collection/assets/search-icon.svg +3 -0
  143. package/dist/collection/assets/success-icon.svg +6 -0
  144. package/dist/collection/assets/warning-icon-outline.svg +3 -0
  145. package/dist/collection/assets/warning-icon.svg +6 -0
  146. package/dist/collection/collection-manifest.json +71 -0
  147. package/dist/collection/components/ic-alert/ic-alert.css +616 -0
  148. package/dist/collection/components/ic-alert/ic-alert.js +243 -0
  149. package/dist/collection/components/ic-alert/ic-alert.js.map +1 -0
  150. package/dist/collection/components/ic-alert/test/a11y/ic-alert.test.a11y.js +11 -0
  151. package/dist/collection/components/ic-alert/test/a11y/ic-alert.test.a11y.js.map +1 -0
  152. package/dist/collection/components/ic-alert/test/basic/ic-alert.e2e.js +16 -0
  153. package/dist/collection/components/ic-alert/test/basic/ic-alert.e2e.js.map +1 -0
  154. package/dist/collection/components/ic-alert/test/basic/ic-alert.spec.js +182 -0
  155. package/dist/collection/components/ic-alert/test/basic/ic-alert.spec.js.map +1 -0
  156. package/dist/collection/components/ic-back-to-top/assets/ArrowUpward.svg +3 -0
  157. package/dist/collection/components/ic-back-to-top/ic-back-to-top.css +542 -0
  158. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js +171 -0
  159. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js.map +1 -0
  160. package/dist/collection/components/ic-back-to-top/test/a11y/ic-back-to-top.test.a11y.js +28 -0
  161. package/dist/collection/components/ic-back-to-top/test/a11y/ic-back-to-top.test.a11y.js.map +1 -0
  162. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.e2e.js +68 -0
  163. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.e2e.js.map +1 -0
  164. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.spec.js +123 -0
  165. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.spec.js.map +1 -0
  166. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.css +100 -0
  167. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js +166 -0
  168. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js.map +1 -0
  169. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.types.js +2 -0
  170. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.types.js.map +1 -0
  171. package/dist/collection/components/ic-breadcrumb/test/basic/ic-breadcrumb.spec.js +118 -0
  172. package/dist/collection/components/ic-breadcrumb/test/basic/ic-breadcrumb.spec.js.map +1 -0
  173. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.css +36 -0
  174. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js +234 -0
  175. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js.map +1 -0
  176. package/dist/collection/components/ic-breadcrumb-group/test/a11y/ic-breadcrumb-group.test.a11y.js +21 -0
  177. package/dist/collection/components/ic-breadcrumb-group/test/a11y/ic-breadcrumb-group.test.a11y.js.map +1 -0
  178. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group-test-examples.js +35 -0
  179. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group-test-examples.js.map +1 -0
  180. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.e2e.js +41 -0
  181. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.e2e.js.map +1 -0
  182. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.spec.js +181 -0
  183. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.spec.js.map +1 -0
  184. package/dist/collection/components/ic-button/ic-button.css +871 -0
  185. package/dist/collection/components/ic-button/ic-button.js +727 -0
  186. package/dist/collection/components/ic-button/ic-button.js.map +1 -0
  187. package/dist/collection/components/ic-button/ic-button.types.js +2 -0
  188. package/dist/collection/components/ic-button/ic-button.types.js.map +1 -0
  189. package/dist/collection/components/ic-button/test/a11y/ic-button.test.a11y.js +11 -0
  190. package/dist/collection/components/ic-button/test/a11y/ic-button.test.a11y.js.map +1 -0
  191. package/dist/collection/components/ic-button/test/basic/ic-button.e2e.js +198 -0
  192. package/dist/collection/components/ic-button/test/basic/ic-button.e2e.js.map +1 -0
  193. package/dist/collection/components/ic-button/test/basic/ic-button.spec.js +256 -0
  194. package/dist/collection/components/ic-button/test/basic/ic-button.spec.js.map +1 -0
  195. package/dist/collection/components/ic-card/ic-card.css +620 -0
  196. package/dist/collection/components/ic-card/ic-card.js +400 -0
  197. package/dist/collection/components/ic-card/ic-card.js.map +1 -0
  198. package/dist/collection/components/ic-card/test/a11y/ic-card.test.a11y.js +21 -0
  199. package/dist/collection/components/ic-card/test/a11y/ic-card.test.a11y.js.map +1 -0
  200. package/dist/collection/components/ic-card/test/basic/ic-card.e2e.js +23 -0
  201. package/dist/collection/components/ic-card/test/basic/ic-card.e2e.js.map +1 -0
  202. package/dist/collection/components/ic-card/test/basic/ic-card.spec.js +152 -0
  203. package/dist/collection/components/ic-card/test/basic/ic-card.spec.js.map +1 -0
  204. package/dist/collection/components/ic-checkbox/ic-checkbox.css +675 -0
  205. package/dist/collection/components/ic-checkbox/ic-checkbox.js +386 -0
  206. package/dist/collection/components/ic-checkbox/ic-checkbox.js.map +1 -0
  207. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.css +482 -0
  208. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js +295 -0
  209. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js.map +1 -0
  210. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.types.js +2 -0
  211. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.types.js.map +1 -0
  212. package/dist/collection/components/ic-checkbox-group/test/a11y/ic-checkbox-group.test.a11y.js +16 -0
  213. package/dist/collection/components/ic-checkbox-group/test/a11y/ic-checkbox-group.test.a11y.js.map +1 -0
  214. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.e2e.js +201 -0
  215. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.e2e.js.map +1 -0
  216. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.spec.js +203 -0
  217. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.spec.js.map +1 -0
  218. package/dist/collection/components/ic-chip/ic-chip.css +597 -0
  219. package/dist/collection/components/ic-chip/ic-chip.js +250 -0
  220. package/dist/collection/components/ic-chip/ic-chip.js.map +1 -0
  221. package/dist/collection/components/ic-chip/ic-chip.types.js +2 -0
  222. package/dist/collection/components/ic-chip/ic-chip.types.js.map +1 -0
  223. package/dist/collection/components/ic-chip/test/a11y/ic-chip.test.a11y.js +11 -0
  224. package/dist/collection/components/ic-chip/test/a11y/ic-chip.test.a11y.js.map +1 -0
  225. package/dist/collection/components/ic-chip/test/basic/ic-chip.spec.js +110 -0
  226. package/dist/collection/components/ic-chip/test/basic/ic-chip.spec.js.map +1 -0
  227. package/dist/collection/components/ic-classification-banner/ic-classification-banner.css +504 -0
  228. package/dist/collection/components/ic-classification-banner/ic-classification-banner.js +141 -0
  229. package/dist/collection/components/ic-classification-banner/ic-classification-banner.js.map +1 -0
  230. package/dist/collection/components/ic-classification-banner/ic-classification-banner.types.js +2 -0
  231. package/dist/collection/components/ic-classification-banner/ic-classification-banner.types.js.map +1 -0
  232. package/dist/collection/components/ic-classification-banner/test/a11y/ic-classification-banner.test.a11y.js +11 -0
  233. package/dist/collection/components/ic-classification-banner/test/a11y/ic-classification-banner.test.a11y.js.map +1 -0
  234. package/dist/collection/components/ic-classification-banner/test/basic/ic-classification-banner.spec.js +140 -0
  235. package/dist/collection/components/ic-classification-banner/test/basic/ic-classification-banner.spec.js.map +1 -0
  236. package/dist/collection/components/ic-data-entity/ic-data-entity.css +474 -0
  237. package/dist/collection/components/ic-data-entity/ic-data-entity.js +70 -0
  238. package/dist/collection/components/ic-data-entity/ic-data-entity.js.map +1 -0
  239. package/dist/collection/components/ic-data-entity/test/a11y/ic-data-entity.test.a11y.js +11 -0
  240. package/dist/collection/components/ic-data-entity/test/a11y/ic-data-entity.test.a11y.js.map +1 -0
  241. package/dist/collection/components/ic-data-entity/test/basic/ic-data-entity.spec.js +161 -0
  242. package/dist/collection/components/ic-data-entity/test/basic/ic-data-entity.spec.js.map +1 -0
  243. package/dist/collection/components/ic-data-row/ic-data-row.css +525 -0
  244. package/dist/collection/components/ic-data-row/ic-data-row.js +157 -0
  245. package/dist/collection/components/ic-data-row/ic-data-row.js.map +1 -0
  246. package/dist/collection/components/ic-data-row/test/a11y/ic-data-row.test.a11y.js +18 -0
  247. package/dist/collection/components/ic-data-row/test/a11y/ic-data-row.test.a11y.js.map +1 -0
  248. package/dist/collection/components/ic-data-row/test/basic/ic-data-row.spec.js +74 -0
  249. package/dist/collection/components/ic-data-row/test/basic/ic-data-row.spec.js.map +1 -0
  250. package/dist/collection/components/ic-data-table/assets/ascending-icon.svg +3 -0
  251. package/dist/collection/components/ic-data-table/assets/descending-icon.svg +3 -0
  252. package/dist/collection/components/ic-data-table/assets/unsorted-icon.svg +3 -0
  253. package/dist/collection/components/ic-data-table/ic-data-table.css +214 -0
  254. package/dist/collection/components/ic-data-table/ic-data-table.js +533 -0
  255. package/dist/collection/components/ic-data-table/ic-data-table.js.map +1 -0
  256. package/dist/collection/components/ic-data-table/ic-data-table.types.js +2 -0
  257. package/dist/collection/components/ic-data-table/ic-data-table.types.js.map +1 -0
  258. package/dist/collection/components/ic-data-table/test/a11y/ic-data-table.test.a11y.js +28 -0
  259. package/dist/collection/components/ic-data-table/test/a11y/ic-data-table.test.a11y.js.map +1 -0
  260. package/dist/collection/components/ic-data-table/test/basic/ic-data-table.spec.js +466 -0
  261. package/dist/collection/components/ic-data-table/test/basic/ic-data-table.spec.js.map +1 -0
  262. package/dist/collection/components/ic-dialog/ic-dialog.css +592 -0
  263. package/dist/collection/components/ic-dialog/ic-dialog.js +640 -0
  264. package/dist/collection/components/ic-dialog/ic-dialog.js.map +1 -0
  265. package/dist/collection/components/ic-dialog/test/a11y/ic-dialog.test.a11y.js +28 -0
  266. package/dist/collection/components/ic-dialog/test/a11y/ic-dialog.test.a11y.js.map +1 -0
  267. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.e2e.js +207 -0
  268. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.e2e.js.map +1 -0
  269. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.spec.js +520 -0
  270. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.spec.js.map +1 -0
  271. package/dist/collection/components/ic-divider/ic-divider.css +11 -0
  272. package/dist/collection/components/ic-divider/ic-divider.js +44 -0
  273. package/dist/collection/components/ic-divider/ic-divider.js.map +1 -0
  274. package/dist/collection/components/ic-divider/test/basic/ic-divider.spec.js +24 -0
  275. package/dist/collection/components/ic-divider/test/basic/ic-divider.spec.js.map +1 -0
  276. package/dist/collection/components/ic-footer/ic-footer.css +543 -0
  277. package/dist/collection/components/ic-footer/ic-footer.js +252 -0
  278. package/dist/collection/components/ic-footer/ic-footer.js.map +1 -0
  279. package/dist/collection/components/ic-footer/ic-footer.types.js +2 -0
  280. package/dist/collection/components/ic-footer/ic-footer.types.js.map +1 -0
  281. package/dist/collection/components/ic-footer/test/a11y/ic-footer.test.a11y.js +21 -0
  282. package/dist/collection/components/ic-footer/test/a11y/ic-footer.test.a11y.js.map +1 -0
  283. package/dist/collection/components/ic-footer/test/basic/ic-footer.e2e.js +50 -0
  284. package/dist/collection/components/ic-footer/test/basic/ic-footer.e2e.js.map +1 -0
  285. package/dist/collection/components/ic-footer/test/basic/ic-footer.spec.js +140 -0
  286. package/dist/collection/components/ic-footer/test/basic/ic-footer.spec.js.map +1 -0
  287. package/dist/collection/components/ic-footer-link/ic-footer-link.css +612 -0
  288. package/dist/collection/components/ic-footer-link/ic-footer-link.js +200 -0
  289. package/dist/collection/components/ic-footer-link/ic-footer-link.js.map +1 -0
  290. package/dist/collection/components/ic-footer-link/test/a11y/ic-footer-link.test.a11y.js +21 -0
  291. package/dist/collection/components/ic-footer-link/test/a11y/ic-footer-link.test.a11y.js.map +1 -0
  292. package/dist/collection/components/ic-footer-link/test/basic/ic-footer-link.spec.js +62 -0
  293. package/dist/collection/components/ic-footer-link/test/basic/ic-footer-link.spec.js.map +1 -0
  294. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.css +522 -0
  295. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js +114 -0
  296. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js.map +1 -0
  297. package/dist/collection/components/ic-footer-link-group/test/a11y/ic-footer-link-group.test.a11y.js +21 -0
  298. package/dist/collection/components/ic-footer-link-group/test/a11y/ic-footer-link-group.test.a11y.js.map +1 -0
  299. package/dist/collection/components/ic-footer-link-group/test/basic/ic-footer-link-group.spec.js +98 -0
  300. package/dist/collection/components/ic-footer-link-group/test/basic/ic-footer-link-group.spec.js.map +1 -0
  301. package/dist/collection/components/ic-hero/ic-hero.css +726 -0
  302. package/dist/collection/components/ic-hero/ic-hero.js +275 -0
  303. package/dist/collection/components/ic-hero/ic-hero.js.map +1 -0
  304. package/dist/collection/components/ic-hero/ic-hero.types.js +2 -0
  305. package/dist/collection/components/ic-hero/ic-hero.types.js.map +1 -0
  306. package/dist/collection/components/ic-hero/test/a11y/ic-hero.test.a11y.js +11 -0
  307. package/dist/collection/components/ic-hero/test/a11y/ic-hero.test.a11y.js.map +1 -0
  308. package/dist/collection/components/ic-hero/test/basic/ic-hero.spec.js +76 -0
  309. package/dist/collection/components/ic-hero/test/basic/ic-hero.spec.js.map +1 -0
  310. package/dist/collection/components/ic-horizontal-scroll/assets/left-arrow.svg +3 -0
  311. package/dist/collection/components/ic-horizontal-scroll/assets/right-arrow.svg +3 -0
  312. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.css +535 -0
  313. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js +232 -0
  314. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js.map +1 -0
  315. package/dist/collection/components/ic-horizontal-scroll/test/a11y/ic-horizontal-scroll.test.a11y.js +34 -0
  316. package/dist/collection/components/ic-horizontal-scroll/test/a11y/ic-horizontal-scroll.test.a11y.js.map +1 -0
  317. package/dist/collection/components/ic-horizontal-scroll/test/basic/ic-horizontal-scroll.spec.js +180 -0
  318. package/dist/collection/components/ic-horizontal-scroll/test/basic/ic-horizontal-scroll.spec.js.map +1 -0
  319. package/dist/collection/components/ic-input-component-container/ic-input-component-container.css +166 -0
  320. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js +208 -0
  321. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js.map +1 -0
  322. package/dist/collection/components/ic-input-component-container/test/basic/ic-input-component-container.spec.js +117 -0
  323. package/dist/collection/components/ic-input-component-container/test/basic/ic-input-component-container.spec.js.map +1 -0
  324. package/dist/collection/components/ic-input-container/ic-input-container.css +4 -0
  325. package/dist/collection/components/ic-input-container/ic-input-container.js +66 -0
  326. package/dist/collection/components/ic-input-container/ic-input-container.js.map +1 -0
  327. package/dist/collection/components/ic-input-container/test/basic/ic-input-container.spec.js +38 -0
  328. package/dist/collection/components/ic-input-container/test/basic/ic-input-container.spec.js.map +1 -0
  329. package/dist/collection/components/ic-input-label/ic-input-label.css +35 -0
  330. package/dist/collection/components/ic-input-label/ic-input-label.js +194 -0
  331. package/dist/collection/components/ic-input-label/ic-input-label.js.map +1 -0
  332. package/dist/collection/components/ic-input-label/test/basic/ic-input-label.spec.js +98 -0
  333. package/dist/collection/components/ic-input-label/test/basic/ic-input-label.spec.js.map +1 -0
  334. package/dist/collection/components/ic-input-validation/ic-input-validation.css +34 -0
  335. package/dist/collection/components/ic-input-validation/ic-input-validation.js +152 -0
  336. package/dist/collection/components/ic-input-validation/ic-input-validation.js.map +1 -0
  337. package/dist/collection/components/ic-input-validation/ic-input-validation.types.js +2 -0
  338. package/dist/collection/components/ic-input-validation/ic-input-validation.types.js.map +1 -0
  339. package/dist/collection/components/ic-input-validation/test/basic/ic-input-validation.spec.js +89 -0
  340. package/dist/collection/components/ic-input-validation/test/basic/ic-input-validation.spec.js.map +1 -0
  341. package/dist/collection/components/ic-link/ic-link.css +558 -0
  342. package/dist/collection/components/ic-link/ic-link.js +264 -0
  343. package/dist/collection/components/ic-link/ic-link.js.map +1 -0
  344. package/dist/collection/components/ic-link/test/a11y/ic-link.test.a11y.js +11 -0
  345. package/dist/collection/components/ic-link/test/a11y/ic-link.test.a11y.js.map +1 -0
  346. package/dist/collection/components/ic-link/test/basic/ic-link.spec.js +203 -0
  347. package/dist/collection/components/ic-link/test/basic/ic-link.spec.js.map +1 -0
  348. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.css +663 -0
  349. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js +423 -0
  350. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js.map +1 -0
  351. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.types.js +2 -0
  352. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.types.js.map +1 -0
  353. package/dist/collection/components/ic-loading-indicator/test/a11y/ic-loading-indicator.test.a11y.js +11 -0
  354. package/dist/collection/components/ic-loading-indicator/test/a11y/ic-loading-indicator.test.a11y.js.map +1 -0
  355. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.e2e.js +34 -0
  356. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.e2e.js.map +1 -0
  357. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.spec.js +141 -0
  358. package/dist/collection/components/ic-loading-indicator/test/basic/ic-loading-indicator.spec.js.map +1 -0
  359. package/dist/collection/components/ic-menu/ic-menu.css +629 -0
  360. package/dist/collection/components/ic-menu/ic-menu.js +1150 -0
  361. package/dist/collection/components/ic-menu/ic-menu.js.map +1 -0
  362. package/dist/collection/components/ic-menu/ic-menu.types.js +2 -0
  363. package/dist/collection/components/ic-menu/ic-menu.types.js.map +1 -0
  364. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js +657 -0
  365. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js.map +1 -0
  366. package/dist/collection/components/ic-menu-group/ic-menu-group.css +465 -0
  367. package/dist/collection/components/ic-menu-group/ic-menu-group.js +45 -0
  368. package/dist/collection/components/ic-menu-group/ic-menu-group.js.map +1 -0
  369. package/dist/collection/components/ic-menu-group/test/basic/ic-menu-group.spec.js +94 -0
  370. package/dist/collection/components/ic-menu-group/test/basic/ic-menu-group.spec.js.map +1 -0
  371. package/dist/collection/components/ic-menu-item/ic-menu-item.css +628 -0
  372. package/dist/collection/components/ic-menu-item/ic-menu-item.js +394 -0
  373. package/dist/collection/components/ic-menu-item/ic-menu-item.js.map +1 -0
  374. package/dist/collection/components/ic-menu-item/ic-menu-item.types.js +2 -0
  375. package/dist/collection/components/ic-menu-item/ic-menu-item.types.js.map +1 -0
  376. package/dist/collection/components/ic-menu-item/test/basic/ic-menu-item.spec.js +108 -0
  377. package/dist/collection/components/ic-menu-item/test/basic/ic-menu-item.spec.js.map +1 -0
  378. package/dist/collection/components/ic-navigation-button/ic-navigation-button.css +456 -0
  379. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js +267 -0
  380. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js.map +1 -0
  381. package/dist/collection/components/ic-navigation-button/ic-navigation-button.types.js +2 -0
  382. package/dist/collection/components/ic-navigation-button/ic-navigation-button.types.js.map +1 -0
  383. package/dist/collection/components/ic-navigation-button/test/basic/ic-navigation-button.spec.js +84 -0
  384. package/dist/collection/components/ic-navigation-button/test/basic/ic-navigation-button.spec.js.map +1 -0
  385. package/dist/collection/components/ic-navigation-group/ic-navigation-group.css +646 -0
  386. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js +379 -0
  387. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js.map +1 -0
  388. package/dist/collection/components/ic-navigation-group/test/a11y/ic-navigation-group.test.a11y.js +18 -0
  389. package/dist/collection/components/ic-navigation-group/test/a11y/ic-navigation-group.test.a11y.js.map +1 -0
  390. package/dist/collection/components/ic-navigation-group/test/basic/ic-navigation-group.spec.js +309 -0
  391. package/dist/collection/components/ic-navigation-group/test/basic/ic-navigation-group.spec.js.map +1 -0
  392. package/dist/collection/components/ic-navigation-item/ic-navigation-item.css +1028 -0
  393. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js +444 -0
  394. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js.map +1 -0
  395. package/dist/collection/components/ic-navigation-item/test/a11y/ic-navigation-item.test.a11y.js +18 -0
  396. package/dist/collection/components/ic-navigation-item/test/a11y/ic-navigation-item.test.a11y.js.map +1 -0
  397. package/dist/collection/components/ic-navigation-item/test/basic/ic-navigation-item.spec.js +118 -0
  398. package/dist/collection/components/ic-navigation-item/test/basic/ic-navigation-item.spec.js.map +1 -0
  399. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.css +92 -0
  400. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js +202 -0
  401. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js.map +1 -0
  402. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.e2e.js +29 -0
  403. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.e2e.js.map +1 -0
  404. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.spec.js +176 -0
  405. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.spec.js.map +1 -0
  406. package/dist/collection/components/ic-page-header/ic-page-header.css +582 -0
  407. package/dist/collection/components/ic-page-header/ic-page-header.js +272 -0
  408. package/dist/collection/components/ic-page-header/ic-page-header.js.map +1 -0
  409. package/dist/collection/components/ic-page-header/test/a11y/ic-page-header.test.a11y.js +13 -0
  410. package/dist/collection/components/ic-page-header/test/a11y/ic-page-header.test.a11y.js.map +1 -0
  411. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.e2e.js +177 -0
  412. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.e2e.js.map +1 -0
  413. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.spec.js +284 -0
  414. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.spec.js.map +1 -0
  415. package/dist/collection/components/ic-pagination/ic-pagination.css +486 -0
  416. package/dist/collection/components/ic-pagination/ic-pagination.js +498 -0
  417. package/dist/collection/components/ic-pagination/ic-pagination.js.map +1 -0
  418. package/dist/collection/components/ic-pagination/ic-pagination.types.js +2 -0
  419. package/dist/collection/components/ic-pagination/ic-pagination.types.js.map +1 -0
  420. package/dist/collection/components/ic-pagination/test/a11y/ic-pagination.test.a11y.js +11 -0
  421. package/dist/collection/components/ic-pagination/test/a11y/ic-pagination.test.a11y.js.map +1 -0
  422. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.e2e.js +128 -0
  423. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.e2e.js.map +1 -0
  424. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.spec.js +335 -0
  425. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.spec.js.map +1 -0
  426. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.css +107 -0
  427. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.js +539 -0
  428. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.js.map +1 -0
  429. package/dist/collection/components/ic-pagination-bar/test/a11y/ic-pagination-bar.test.a11y.js +11 -0
  430. package/dist/collection/components/ic-pagination-bar/test/a11y/ic-pagination-bar.test.a11y.js.map +1 -0
  431. package/dist/collection/components/ic-pagination-bar/test/basic/ic-pagination-bar.spec.js +415 -0
  432. package/dist/collection/components/ic-pagination-bar/test/basic/ic-pagination-bar.spec.js.map +1 -0
  433. package/dist/collection/components/ic-pagination-item/ic-pagination-item.css +581 -0
  434. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js +229 -0
  435. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js.map +1 -0
  436. package/dist/collection/components/ic-pagination-item/ic-pagination-item.types.js +2 -0
  437. package/dist/collection/components/ic-pagination-item/ic-pagination-item.types.js.map +1 -0
  438. package/dist/collection/components/ic-popover-menu/ic-popover-menu.css +536 -0
  439. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js +433 -0
  440. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js.map +1 -0
  441. package/dist/collection/components/ic-popover-menu/test/a11y/ic-popover-menu.test.a11y.js +13 -0
  442. package/dist/collection/components/ic-popover-menu/test/a11y/ic-popover-menu.test.a11y.js.map +1 -0
  443. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.e2e.js +30 -0
  444. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.e2e.js.map +1 -0
  445. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.spec.js +381 -0
  446. package/dist/collection/components/ic-popover-menu/test/basic/ic-popover-menu.spec.js.map +1 -0
  447. package/dist/collection/components/ic-radio-group/ic-radio-group.css +486 -0
  448. package/dist/collection/components/ic-radio-group/ic-radio-group.js +363 -0
  449. package/dist/collection/components/ic-radio-group/ic-radio-group.js.map +1 -0
  450. package/dist/collection/components/ic-radio-group/ic-radio-group.types.js +2 -0
  451. package/dist/collection/components/ic-radio-group/ic-radio-group.types.js.map +1 -0
  452. package/dist/collection/components/ic-radio-group/test/a11y/ic-radio-group.test.a11y.js +16 -0
  453. package/dist/collection/components/ic-radio-group/test/a11y/ic-radio-group.test.a11y.js.map +1 -0
  454. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.e2e.js +343 -0
  455. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.e2e.js.map +1 -0
  456. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.spec.js +303 -0
  457. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.spec.js.map +1 -0
  458. package/dist/collection/components/ic-radio-option/ic-radio-option.css +654 -0
  459. package/dist/collection/components/ic-radio-option/ic-radio-option.js +384 -0
  460. package/dist/collection/components/ic-radio-option/ic-radio-option.js.map +1 -0
  461. package/dist/collection/components/ic-search-bar/ic-search-bar.css +560 -0
  462. package/dist/collection/components/ic-search-bar/ic-search-bar.js +1318 -0
  463. package/dist/collection/components/ic-search-bar/ic-search-bar.js.map +1 -0
  464. package/dist/collection/components/ic-search-bar/ic-search-bar.types.js +2 -0
  465. package/dist/collection/components/ic-search-bar/ic-search-bar.types.js.map +1 -0
  466. package/dist/collection/components/ic-search-bar/test/a11y/ic-search-bar.test.a11y.js +11 -0
  467. package/dist/collection/components/ic-search-bar/test/a11y/ic-search-bar.test.a11y.js.map +1 -0
  468. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.e2e.js +1118 -0
  469. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.e2e.js.map +1 -0
  470. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.spec.js +584 -0
  471. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.spec.js.map +1 -0
  472. package/dist/collection/components/ic-section-container/ic-section-container.css +514 -0
  473. package/dist/collection/components/ic-section-container/ic-section-container.js +74 -0
  474. package/dist/collection/components/ic-section-container/ic-section-container.js.map +1 -0
  475. package/dist/collection/components/ic-section-container/test/basic/ic-section-container.spec.js +69 -0
  476. package/dist/collection/components/ic-section-container/test/basic/ic-section-container.spec.js.map +1 -0
  477. package/dist/collection/components/ic-select/assets/Check.svg +3 -0
  478. package/dist/collection/components/ic-select/assets/Clear.svg +3 -0
  479. package/dist/collection/components/ic-select/assets/Expand.svg +3 -0
  480. package/dist/collection/components/ic-select/ic-select.css +670 -0
  481. package/dist/collection/components/ic-select/ic-select.js +1285 -0
  482. package/dist/collection/components/ic-select/ic-select.js.map +1 -0
  483. package/dist/collection/components/ic-select/test/a11y/ic-select.test.a11y.js +28 -0
  484. package/dist/collection/components/ic-select/test/a11y/ic-select.test.a11y.js.map +1 -0
  485. package/dist/collection/components/ic-select/test/basic/ic-select.e2e.js +1768 -0
  486. package/dist/collection/components/ic-select/test/basic/ic-select.e2e.js.map +1 -0
  487. package/dist/collection/components/ic-select/test/basic/ic-select.spec.js +1296 -0
  488. package/dist/collection/components/ic-select/test/basic/ic-select.spec.js.map +1 -0
  489. package/dist/collection/components/ic-side-navigation/ic-side-navigation.css +635 -0
  490. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js +638 -0
  491. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js.map +1 -0
  492. package/dist/collection/components/ic-side-navigation/ic-side-navigation.types.js +2 -0
  493. package/dist/collection/components/ic-side-navigation/ic-side-navigation.types.js.map +1 -0
  494. package/dist/collection/components/ic-side-navigation/test/a11y/ic-side-navigation.test.a11y.js +14 -0
  495. package/dist/collection/components/ic-side-navigation/test/a11y/ic-side-navigation.test.a11y.js.map +1 -0
  496. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation-test-examples.js +411 -0
  497. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation-test-examples.js.map +1 -0
  498. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.e2e.js +432 -0
  499. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.e2e.js.map +1 -0
  500. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.spec.js +470 -0
  501. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.spec.js.map +1 -0
  502. package/dist/collection/components/ic-skeleton/ic-skeleton.css +503 -0
  503. package/dist/collection/components/ic-skeleton/ic-skeleton.js +112 -0
  504. package/dist/collection/components/ic-skeleton/ic-skeleton.js.map +1 -0
  505. package/dist/collection/components/ic-skeleton/ic-skeleton.types.js +2 -0
  506. package/dist/collection/components/ic-skeleton/ic-skeleton.types.js.map +1 -0
  507. package/dist/collection/components/ic-skeleton/test/a11y/ic-skeleton.test.a11y.js +11 -0
  508. package/dist/collection/components/ic-skeleton/test/a11y/ic-skeleton.test.a11y.js.map +1 -0
  509. package/dist/collection/components/ic-skeleton/test/basic/ic-skeleton.spec.js +89 -0
  510. package/dist/collection/components/ic-skeleton/test/basic/ic-skeleton.spec.js.map +1 -0
  511. package/dist/collection/components/ic-status-tag/ic-status-tag.css +504 -0
  512. package/dist/collection/components/ic-status-tag/ic-status-tag.js +138 -0
  513. package/dist/collection/components/ic-status-tag/ic-status-tag.js.map +1 -0
  514. package/dist/collection/components/ic-status-tag/ic-status-tag.types.js +2 -0
  515. package/dist/collection/components/ic-status-tag/ic-status-tag.types.js.map +1 -0
  516. package/dist/collection/components/ic-status-tag/test/a11y/ic-status-tag.test.a11y.js +11 -0
  517. package/dist/collection/components/ic-status-tag/test/a11y/ic-status-tag.test.a11y.js.map +1 -0
  518. package/dist/collection/components/ic-status-tag/test/basic/ic-status-tag.spec.js +43 -0
  519. package/dist/collection/components/ic-status-tag/test/basic/ic-status-tag.spec.js.map +1 -0
  520. package/dist/collection/components/ic-step/ic-step.css +278 -0
  521. package/dist/collection/components/ic-step/ic-step.js +394 -0
  522. package/dist/collection/components/ic-step/ic-step.js.map +1 -0
  523. package/dist/collection/components/ic-step/ic-step.types.js +2 -0
  524. package/dist/collection/components/ic-step/ic-step.types.js.map +1 -0
  525. package/dist/collection/components/ic-step/test/basic/ic-step.spec.js +176 -0
  526. package/dist/collection/components/ic-step/test/basic/ic-step.spec.js.map +1 -0
  527. package/dist/collection/components/ic-stepper/ic-stepper.css +28 -0
  528. package/dist/collection/components/ic-stepper/ic-stepper.js +317 -0
  529. package/dist/collection/components/ic-stepper/ic-stepper.js.map +1 -0
  530. package/dist/collection/components/ic-stepper/ic-stepper.types.js +2 -0
  531. package/dist/collection/components/ic-stepper/ic-stepper.types.js.map +1 -0
  532. package/dist/collection/components/ic-stepper/test/a11y/ic-stepper.test.a11y.js +36 -0
  533. package/dist/collection/components/ic-stepper/test/a11y/ic-stepper.test.a11y.js.map +1 -0
  534. package/dist/collection/components/ic-stepper/test/basic/ic-stepper-test-examples.js +74 -0
  535. package/dist/collection/components/ic-stepper/test/basic/ic-stepper-test-examples.js.map +1 -0
  536. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.e2e.js +49 -0
  537. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.e2e.js.map +1 -0
  538. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.spec.js +706 -0
  539. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.spec.js.map +1 -0
  540. package/dist/collection/components/ic-switch/ic-switch.css +656 -0
  541. package/dist/collection/components/ic-switch/ic-switch.js +329 -0
  542. package/dist/collection/components/ic-switch/ic-switch.js.map +1 -0
  543. package/dist/collection/components/ic-switch/ic-switch.types.js +2 -0
  544. package/dist/collection/components/ic-switch/ic-switch.types.js.map +1 -0
  545. package/dist/collection/components/ic-switch/test/a11y/ic-switch.test.a11y.js +11 -0
  546. package/dist/collection/components/ic-switch/test/a11y/ic-switch.test.a11y.js.map +1 -0
  547. package/dist/collection/components/ic-switch/test/basic/ic-switch.spec.js +104 -0
  548. package/dist/collection/components/ic-switch/test/basic/ic-switch.spec.js.map +1 -0
  549. package/dist/collection/components/ic-tab/ic-tab.css +521 -0
  550. package/dist/collection/components/ic-tab/ic-tab.js +361 -0
  551. package/dist/collection/components/ic-tab/ic-tab.js.map +1 -0
  552. package/dist/collection/components/ic-tab/ic-tab.types.js +2 -0
  553. package/dist/collection/components/ic-tab/ic-tab.types.js.map +1 -0
  554. package/dist/collection/components/ic-tab/test/basic/ic-tab.e2e.js +32 -0
  555. package/dist/collection/components/ic-tab/test/basic/ic-tab.e2e.js.map +1 -0
  556. package/dist/collection/components/ic-tab/test/basic/ic-tab.spec.js +159 -0
  557. package/dist/collection/components/ic-tab/test/basic/ic-tab.spec.js.map +1 -0
  558. package/dist/collection/components/ic-tab-context/ic-tab-context.js +451 -0
  559. package/dist/collection/components/ic-tab-context/ic-tab-context.js.map +1 -0
  560. package/dist/collection/components/ic-tab-context/test/a11y/ic-tab-context.test.a11y.js +19 -0
  561. package/dist/collection/components/ic-tab-context/test/a11y/ic-tab-context.test.a11y.js.map +1 -0
  562. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.e2e.js +317 -0
  563. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.e2e.js.map +1 -0
  564. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.spec.js +390 -0
  565. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.spec.js.map +1 -0
  566. package/dist/collection/components/ic-tab-group/ic-tab-group.css +25 -0
  567. package/dist/collection/components/ic-tab-group/ic-tab-group.js +124 -0
  568. package/dist/collection/components/ic-tab-group/ic-tab-group.js.map +1 -0
  569. package/dist/collection/components/ic-tab-panel/ic-tab-panel.css +7 -0
  570. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js +196 -0
  571. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js.map +1 -0
  572. package/dist/collection/components/ic-tab-panel/test/basic/ic-tab-panel.spec.js +65 -0
  573. package/dist/collection/components/ic-tab-panel/test/basic/ic-tab-panel.spec.js.map +1 -0
  574. package/dist/collection/components/ic-text-field/ic-text-field.css +558 -0
  575. package/dist/collection/components/ic-text-field/ic-text-field.js +1107 -0
  576. package/dist/collection/components/ic-text-field/ic-text-field.js.map +1 -0
  577. package/dist/collection/components/ic-text-field/ic-text-field.types.js +2 -0
  578. package/dist/collection/components/ic-text-field/ic-text-field.types.js.map +1 -0
  579. package/dist/collection/components/ic-text-field/test/a11y/ic-text-field.test.a11y.js +33 -0
  580. package/dist/collection/components/ic-text-field/test/a11y/ic-text-field.test.a11y.js.map +1 -0
  581. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.e2e.js +98 -0
  582. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.e2e.js.map +1 -0
  583. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.input.spec.js +236 -0
  584. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.input.spec.js.map +1 -0
  585. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.textarea.spec.js +310 -0
  586. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.textarea.spec.js.map +1 -0
  587. package/dist/collection/components/ic-theme/ic-theme.js +106 -0
  588. package/dist/collection/components/ic-theme/ic-theme.js.map +1 -0
  589. package/dist/collection/components/ic-theme/test/basic/ic-theme.e2e.js +72 -0
  590. package/dist/collection/components/ic-theme/test/basic/ic-theme.e2e.js.map +1 -0
  591. package/dist/collection/components/ic-theme/test/basic/ic-theme.spec.js +77 -0
  592. package/dist/collection/components/ic-theme/test/basic/ic-theme.spec.js.map +1 -0
  593. package/dist/collection/components/ic-toast/ic-toast.css +602 -0
  594. package/dist/collection/components/ic-toast/ic-toast.js +386 -0
  595. package/dist/collection/components/ic-toast/ic-toast.js.map +1 -0
  596. package/dist/collection/components/ic-toast/ic-toast.types.js +2 -0
  597. package/dist/collection/components/ic-toast/ic-toast.types.js.map +1 -0
  598. package/dist/collection/components/ic-toast/test/a11y/ic-toast.test.a11y.js +16 -0
  599. package/dist/collection/components/ic-toast/test/a11y/ic-toast.test.a11y.js.map +1 -0
  600. package/dist/collection/components/ic-toast/test/basic/ic-toast.e2e.js +82 -0
  601. package/dist/collection/components/ic-toast/test/basic/ic-toast.e2e.js.map +1 -0
  602. package/dist/collection/components/ic-toast/test/basic/ic-toast.spec.js +278 -0
  603. package/dist/collection/components/ic-toast/test/basic/ic-toast.spec.js.map +1 -0
  604. package/dist/collection/components/ic-toast-region/ic-toast-region.js +81 -0
  605. package/dist/collection/components/ic-toast-region/ic-toast-region.js.map +1 -0
  606. package/dist/collection/components/ic-toast-region/test/basic/ic-toast-region.spec.js +62 -0
  607. package/dist/collection/components/ic-toast-region/test/basic/ic-toast-region.spec.js.map +1 -0
  608. package/dist/collection/components/ic-tooltip/ic-tooltip.css +563 -0
  609. package/dist/collection/components/ic-tooltip/ic-tooltip.js +294 -0
  610. package/dist/collection/components/ic-tooltip/ic-tooltip.js.map +1 -0
  611. package/dist/collection/components/ic-tooltip/ic-tooltip.types.js +2 -0
  612. package/dist/collection/components/ic-tooltip/ic-tooltip.types.js.map +1 -0
  613. package/dist/collection/components/ic-tooltip/test/a11y/ic-tooltip.test.a11y.js +15 -0
  614. package/dist/collection/components/ic-tooltip/test/a11y/ic-tooltip.test.a11y.js.map +1 -0
  615. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.e2e.js +115 -0
  616. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.e2e.js.map +1 -0
  617. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.spec.js +128 -0
  618. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.spec.js.map +1 -0
  619. package/dist/collection/components/ic-top-navigation/ic-top-navigation.css +737 -0
  620. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js +439 -0
  621. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js.map +1 -0
  622. package/dist/collection/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.js +30 -0
  623. package/dist/collection/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.js.map +1 -0
  624. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.e2e.js +61 -0
  625. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.e2e.js.map +1 -0
  626. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.mobile.e2e.js +242 -0
  627. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.mobile.e2e.js.map +1 -0
  628. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.spec.js +299 -0
  629. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.spec.js.map +1 -0
  630. package/dist/collection/components/ic-typography/ic-typography.css +627 -0
  631. package/dist/collection/components/ic-typography/ic-typography.js +271 -0
  632. package/dist/collection/components/ic-typography/ic-typography.js.map +1 -0
  633. package/dist/collection/components/ic-typography/test/a11y/ic-typography.test.a11y.js +11 -0
  634. package/dist/collection/components/ic-typography/test/a11y/ic-typography.test.a11y.js.map +1 -0
  635. package/dist/collection/components/ic-typography/test/basic/ic-typography.e2e.js +39 -0
  636. package/dist/collection/components/ic-typography/test/basic/ic-typography.e2e.js.map +1 -0
  637. package/dist/collection/components/ic-typography/test/basic/ic-typography.spec.js +324 -0
  638. package/dist/collection/components/ic-typography/test/basic/ic-typography.spec.js.map +1 -0
  639. package/dist/collection/index.js +2 -0
  640. package/dist/collection/index.js.map +1 -0
  641. package/dist/collection/normalize.css +440 -0
  642. package/dist/collection/testspec.setup.js +63 -0
  643. package/dist/collection/testspec.setup.js.map +1 -0
  644. package/dist/collection/utils/constants.js +81 -0
  645. package/dist/collection/utils/constants.js.map +1 -0
  646. package/dist/collection/utils/helpers.js +433 -0
  647. package/dist/collection/utils/helpers.js.map +1 -0
  648. package/dist/collection/utils/testa11y.helpers.js +8 -0
  649. package/dist/collection/utils/testa11y.helpers.js.map +1 -0
  650. package/dist/collection/utils/types.js +13 -0
  651. package/dist/collection/utils/types.js.map +1 -0
  652. package/dist/components/OpenInNew.js +5 -0
  653. package/dist/components/OpenInNew.js.map +1 -0
  654. package/dist/components/check-icon.js +8 -0
  655. package/dist/components/check-icon.js.map +1 -0
  656. package/dist/components/chevron-icon.js +8 -0
  657. package/dist/components/chevron-icon.js.map +1 -0
  658. package/dist/components/close-icon.js +10 -0
  659. package/dist/components/close-icon.js.map +1 -0
  660. package/dist/components/helpers.js +552 -0
  661. package/dist/components/helpers.js.map +1 -0
  662. package/dist/components/ic-alert.d.ts +11 -0
  663. package/dist/components/ic-alert.js +8 -0
  664. package/dist/components/ic-alert.js.map +1 -0
  665. package/dist/components/ic-alert2.js +117 -0
  666. package/dist/components/ic-alert2.js.map +1 -0
  667. package/dist/components/ic-back-to-top.d.ts +11 -0
  668. package/dist/components/ic-back-to-top.js +169 -0
  669. package/dist/components/ic-back-to-top.js.map +1 -0
  670. package/dist/components/ic-breadcrumb-group.d.ts +11 -0
  671. package/dist/components/ic-breadcrumb-group.js +218 -0
  672. package/dist/components/ic-breadcrumb-group.js.map +1 -0
  673. package/dist/components/ic-breadcrumb.d.ts +11 -0
  674. package/dist/components/ic-breadcrumb.js +8 -0
  675. package/dist/components/ic-breadcrumb.js.map +1 -0
  676. package/dist/components/ic-breadcrumb2.js +96 -0
  677. package/dist/components/ic-breadcrumb2.js.map +1 -0
  678. package/dist/components/ic-button.d.ts +11 -0
  679. package/dist/components/ic-button.js +8 -0
  680. package/dist/components/ic-button.js.map +1 -0
  681. package/dist/components/ic-button2.js +284 -0
  682. package/dist/components/ic-button2.js.map +1 -0
  683. package/dist/components/ic-card.d.ts +11 -0
  684. package/dist/components/ic-card.js +183 -0
  685. package/dist/components/ic-card.js.map +1 -0
  686. package/dist/components/ic-checkbox-group.d.ts +11 -0
  687. package/dist/components/ic-checkbox-group.js +111 -0
  688. package/dist/components/ic-checkbox-group.js.map +1 -0
  689. package/dist/components/ic-checkbox.d.ts +11 -0
  690. package/dist/components/ic-checkbox.js +147 -0
  691. package/dist/components/ic-checkbox.js.map +1 -0
  692. package/dist/components/ic-chip.d.ts +11 -0
  693. package/dist/components/ic-chip.js +114 -0
  694. package/dist/components/ic-chip.js.map +1 -0
  695. package/dist/components/ic-classification-banner.d.ts +11 -0
  696. package/dist/components/ic-classification-banner.js +68 -0
  697. package/dist/components/ic-classification-banner.js.map +1 -0
  698. package/dist/components/ic-data-entity.d.ts +11 -0
  699. package/dist/components/ic-data-entity.js +54 -0
  700. package/dist/components/ic-data-entity.js.map +1 -0
  701. package/dist/components/ic-data-row.d.ts +11 -0
  702. package/dist/components/ic-data-row.js +116 -0
  703. package/dist/components/ic-data-row.js.map +1 -0
  704. package/dist/components/ic-dialog.d.ts +11 -0
  705. package/dist/components/ic-dialog.js +356 -0
  706. package/dist/components/ic-dialog.js.map +1 -0
  707. package/dist/components/ic-divider.d.ts +11 -0
  708. package/dist/components/ic-divider.js +8 -0
  709. package/dist/components/ic-divider.js.map +1 -0
  710. package/dist/components/ic-divider2.js +42 -0
  711. package/dist/components/ic-divider2.js.map +1 -0
  712. package/dist/components/ic-footer-link-group.d.ts +11 -0
  713. package/dist/components/ic-footer-link-group.js +102 -0
  714. package/dist/components/ic-footer-link-group.js.map +1 -0
  715. package/dist/components/ic-footer-link.d.ts +11 -0
  716. package/dist/components/ic-footer-link.js +90 -0
  717. package/dist/components/ic-footer-link.js.map +1 -0
  718. package/dist/components/ic-footer.d.ts +11 -0
  719. package/dist/components/ic-footer.js +125 -0
  720. package/dist/components/ic-footer.js.map +1 -0
  721. package/dist/components/ic-hero.d.ts +11 -0
  722. package/dist/components/ic-hero.js +115 -0
  723. package/dist/components/ic-hero.js.map +1 -0
  724. package/dist/components/ic-horizontal-scroll.d.ts +11 -0
  725. package/dist/components/ic-horizontal-scroll.js +8 -0
  726. package/dist/components/ic-horizontal-scroll.js.map +1 -0
  727. package/dist/components/ic-horizontal-scroll2.js +218 -0
  728. package/dist/components/ic-horizontal-scroll2.js.map +1 -0
  729. package/dist/components/ic-input-component-container.d.ts +11 -0
  730. package/dist/components/ic-input-component-container.js +8 -0
  731. package/dist/components/ic-input-component-container.js.map +1 -0
  732. package/dist/components/ic-input-component-container2.js +71 -0
  733. package/dist/components/ic-input-component-container2.js.map +1 -0
  734. package/dist/components/ic-input-container.d.ts +11 -0
  735. package/dist/components/ic-input-container.js +8 -0
  736. package/dist/components/ic-input-container.js.map +1 -0
  737. package/dist/components/ic-input-container2.js +40 -0
  738. package/dist/components/ic-input-container2.js.map +1 -0
  739. package/dist/components/ic-input-label.d.ts +11 -0
  740. package/dist/components/ic-input-label.js +8 -0
  741. package/dist/components/ic-input-label.js.map +1 -0
  742. package/dist/components/ic-input-label2.js +74 -0
  743. package/dist/components/ic-input-label2.js.map +1 -0
  744. package/dist/components/ic-input-validation.d.ts +11 -0
  745. package/dist/components/ic-input-validation.js +8 -0
  746. package/dist/components/ic-input-validation.js.map +1 -0
  747. package/dist/components/ic-input-validation2.js +67 -0
  748. package/dist/components/ic-input-validation2.js.map +1 -0
  749. package/dist/components/ic-link.d.ts +11 -0
  750. package/dist/components/ic-link.js +8 -0
  751. package/dist/components/ic-link.js.map +1 -0
  752. package/dist/components/ic-link2.js +97 -0
  753. package/dist/components/ic-link2.js.map +1 -0
  754. package/dist/components/ic-loading-indicator.d.ts +11 -0
  755. package/dist/components/ic-loading-indicator.js +8 -0
  756. package/dist/components/ic-loading-indicator.js.map +1 -0
  757. package/dist/components/ic-loading-indicator2.js +226 -0
  758. package/dist/components/ic-loading-indicator2.js.map +1 -0
  759. package/dist/components/ic-menu-group.d.ts +11 -0
  760. package/dist/components/ic-menu-group.js +46 -0
  761. package/dist/components/ic-menu-group.js.map +1 -0
  762. package/dist/components/ic-menu-item.d.ts +11 -0
  763. package/dist/components/ic-menu-item.js +8 -0
  764. package/dist/components/ic-menu-item.js.map +1 -0
  765. package/dist/components/ic-menu-item2.js +169 -0
  766. package/dist/components/ic-menu-item2.js.map +1 -0
  767. package/dist/components/ic-menu.d.ts +11 -0
  768. package/dist/components/ic-menu.js +8 -0
  769. package/dist/components/ic-menu.js.map +1 -0
  770. package/dist/components/ic-menu2.js +692 -0
  771. package/dist/components/ic-menu2.js.map +1 -0
  772. package/dist/components/ic-navigation-button.d.ts +11 -0
  773. package/dist/components/ic-navigation-button.js +137 -0
  774. package/dist/components/ic-navigation-button.js.map +1 -0
  775. package/dist/components/ic-navigation-group.d.ts +11 -0
  776. package/dist/components/ic-navigation-group.js +319 -0
  777. package/dist/components/ic-navigation-group.js.map +1 -0
  778. package/dist/components/ic-navigation-item.d.ts +11 -0
  779. package/dist/components/ic-navigation-item.js +200 -0
  780. package/dist/components/ic-navigation-item.js.map +1 -0
  781. package/dist/components/ic-navigation-menu.d.ts +11 -0
  782. package/dist/components/ic-navigation-menu.js +8 -0
  783. package/dist/components/ic-navigation-menu.js.map +1 -0
  784. package/dist/components/ic-navigation-menu2.js +161 -0
  785. package/dist/components/ic-navigation-menu2.js.map +1 -0
  786. package/dist/components/ic-page-header.d.ts +11 -0
  787. package/dist/components/ic-page-header.js +166 -0
  788. package/dist/components/ic-page-header.js.map +1 -0
  789. package/dist/components/ic-pagination-bar.d.ts +11 -0
  790. package/dist/components/ic-pagination-bar.js +8 -0
  791. package/dist/components/ic-pagination-bar.js.map +1 -0
  792. package/dist/components/ic-pagination-bar2.js +378 -0
  793. package/dist/components/ic-pagination-bar2.js.map +1 -0
  794. package/dist/components/ic-pagination-item.d.ts +11 -0
  795. package/dist/components/ic-pagination-item.js +8 -0
  796. package/dist/components/ic-pagination-item.js.map +1 -0
  797. package/dist/components/ic-pagination-item2.js +81 -0
  798. package/dist/components/ic-pagination-item2.js.map +1 -0
  799. package/dist/components/ic-pagination.d.ts +11 -0
  800. package/dist/components/ic-pagination.js +8 -0
  801. package/dist/components/ic-pagination.js.map +1 -0
  802. package/dist/components/ic-pagination2.js +285 -0
  803. package/dist/components/ic-pagination2.js.map +1 -0
  804. package/dist/components/ic-popover-menu.d.ts +11 -0
  805. package/dist/components/ic-popover-menu.js +290 -0
  806. package/dist/components/ic-popover-menu.js.map +1 -0
  807. package/dist/components/ic-radio-group.d.ts +11 -0
  808. package/dist/components/ic-radio-group.js +174 -0
  809. package/dist/components/ic-radio-group.js.map +1 -0
  810. package/dist/components/ic-radio-option.d.ts +11 -0
  811. package/dist/components/ic-radio-option.js +171 -0
  812. package/dist/components/ic-radio-option.js.map +1 -0
  813. package/dist/components/ic-search-bar.d.ts +11 -0
  814. package/dist/components/ic-search-bar.js +604 -0
  815. package/dist/components/ic-search-bar.js.map +1 -0
  816. package/dist/components/ic-section-container.d.ts +11 -0
  817. package/dist/components/ic-section-container.js +8 -0
  818. package/dist/components/ic-section-container.js.map +1 -0
  819. package/dist/components/ic-section-container2.js +43 -0
  820. package/dist/components/ic-section-container2.js.map +1 -0
  821. package/dist/components/ic-select.d.ts +11 -0
  822. package/dist/components/ic-select.js +8 -0
  823. package/dist/components/ic-select.js.map +1 -0
  824. package/dist/components/ic-select2.js +728 -0
  825. package/dist/components/ic-select2.js.map +1 -0
  826. package/dist/components/ic-side-navigation.d.ts +11 -0
  827. package/dist/components/ic-side-navigation.js +496 -0
  828. package/dist/components/ic-side-navigation.js.map +1 -0
  829. package/dist/components/ic-skeleton.d.ts +11 -0
  830. package/dist/components/ic-skeleton.js +80 -0
  831. package/dist/components/ic-skeleton.js.map +1 -0
  832. package/dist/components/ic-status-tag.d.ts +11 -0
  833. package/dist/components/ic-status-tag.js +61 -0
  834. package/dist/components/ic-status-tag.js.map +1 -0
  835. package/dist/components/ic-step.d.ts +11 -0
  836. package/dist/components/ic-step.js +179 -0
  837. package/dist/components/ic-step.js.map +1 -0
  838. package/dist/components/ic-stepper.d.ts +11 -0
  839. package/dist/components/ic-stepper.js +246 -0
  840. package/dist/components/ic-stepper.js.map +1 -0
  841. package/dist/components/ic-switch.d.ts +11 -0
  842. package/dist/components/ic-switch.js +124 -0
  843. package/dist/components/ic-switch.js.map +1 -0
  844. package/dist/components/ic-tab-context.d.ts +11 -0
  845. package/dist/components/ic-tab-context.js +289 -0
  846. package/dist/components/ic-tab-context.js.map +1 -0
  847. package/dist/components/ic-tab-group.d.ts +11 -0
  848. package/dist/components/ic-tab-group.js +87 -0
  849. package/dist/components/ic-tab-group.js.map +1 -0
  850. package/dist/components/ic-tab-panel.d.ts +11 -0
  851. package/dist/components/ic-tab-panel.js +64 -0
  852. package/dist/components/ic-tab-panel.js.map +1 -0
  853. package/dist/components/ic-tab.d.ts +11 -0
  854. package/dist/components/ic-tab.js +131 -0
  855. package/dist/components/ic-tab.js.map +1 -0
  856. package/dist/components/ic-text-field.d.ts +11 -0
  857. package/dist/components/ic-text-field.js +8 -0
  858. package/dist/components/ic-text-field.js.map +1 -0
  859. package/dist/components/ic-text-field2.js +325 -0
  860. package/dist/components/ic-text-field2.js.map +1 -0
  861. package/dist/components/ic-theme.d.ts +11 -0
  862. package/dist/components/ic-theme.js +77 -0
  863. package/dist/components/ic-theme.js.map +1 -0
  864. package/dist/components/ic-toast-region.d.ts +11 -0
  865. package/dist/components/ic-toast-region.js +63 -0
  866. package/dist/components/ic-toast-region.js.map +1 -0
  867. package/dist/components/ic-toast.d.ts +11 -0
  868. package/dist/components/ic-toast.js +218 -0
  869. package/dist/components/ic-toast.js.map +1 -0
  870. package/dist/components/ic-tooltip.d.ts +11 -0
  871. package/dist/components/ic-tooltip.js +8 -0
  872. package/dist/components/ic-tooltip.js.map +1 -0
  873. package/dist/components/ic-tooltip2.js +1970 -0
  874. package/dist/components/ic-tooltip2.js.map +1 -0
  875. package/dist/components/ic-top-navigation.d.ts +11 -0
  876. package/dist/components/ic-top-navigation.js +290 -0
  877. package/dist/components/ic-top-navigation.js.map +1 -0
  878. package/dist/components/ic-typography.d.ts +11 -0
  879. package/dist/components/ic-typography.js +8 -0
  880. package/dist/components/ic-typography.js.map +1 -0
  881. package/dist/components/ic-typography2.js +149 -0
  882. package/dist/components/ic-typography2.js.map +1 -0
  883. package/dist/components/ic-unstable-data-table.d.ts +11 -0
  884. package/dist/components/ic-unstable-data-table.js +397 -0
  885. package/dist/components/ic-unstable-data-table.js.map +1 -0
  886. package/dist/components/index.d.ts +27 -0
  887. package/dist/components/index.js +3 -0
  888. package/dist/components/index.js.map +1 -0
  889. package/dist/components/types.js +16 -0
  890. package/dist/components/types.js.map +1 -0
  891. package/dist/core/core.css +101 -0
  892. package/dist/core/core.esm.js +2 -0
  893. package/dist/core/core.esm.js.map +1 -0
  894. package/dist/core/index.esm.js +2 -0
  895. package/dist/core/index.esm.js.map +1 -0
  896. package/dist/core/normalize.css +440 -0
  897. package/dist/core/p-019688bf.entry.js +2 -0
  898. package/dist/core/p-019688bf.entry.js.map +1 -0
  899. package/dist/core/p-0584ebc5.entry.js +2 -0
  900. package/dist/core/p-0584ebc5.entry.js.map +1 -0
  901. package/dist/core/p-06321d19.js +2 -0
  902. package/dist/core/p-06321d19.js.map +1 -0
  903. package/dist/core/p-095d3352.entry.js +2 -0
  904. package/dist/core/p-095d3352.entry.js.map +1 -0
  905. package/dist/core/p-10fd8931.entry.js +2 -0
  906. package/dist/core/p-10fd8931.entry.js.map +1 -0
  907. package/dist/core/p-11833706.entry.js +2 -0
  908. package/dist/core/p-11833706.entry.js.map +1 -0
  909. package/dist/core/p-1af8f256.js +3 -0
  910. package/dist/core/p-1af8f256.js.map +1 -0
  911. package/dist/core/p-1b5f5bf2.entry.js +2 -0
  912. package/dist/core/p-1b5f5bf2.entry.js.map +1 -0
  913. package/dist/core/p-1e0eb83a.entry.js +2 -0
  914. package/dist/core/p-1e0eb83a.entry.js.map +1 -0
  915. package/dist/core/p-2138a75e.entry.js +2 -0
  916. package/dist/core/p-2138a75e.entry.js.map +1 -0
  917. package/dist/core/p-29d35210.entry.js +2 -0
  918. package/dist/core/p-29d35210.entry.js.map +1 -0
  919. package/dist/core/p-2c6f2aad.entry.js +2 -0
  920. package/dist/core/p-2c6f2aad.entry.js.map +1 -0
  921. package/dist/core/p-35b9f898.entry.js +2 -0
  922. package/dist/core/p-35b9f898.entry.js.map +1 -0
  923. package/dist/core/p-3b686a68.entry.js +2 -0
  924. package/dist/core/p-3b686a68.entry.js.map +1 -0
  925. package/dist/core/p-4208e336.entry.js +2 -0
  926. package/dist/core/p-4208e336.entry.js.map +1 -0
  927. package/dist/core/p-44512ebe.js +2 -0
  928. package/dist/core/p-44512ebe.js.map +1 -0
  929. package/dist/core/p-4ddbc685.entry.js +2 -0
  930. package/dist/core/p-4ddbc685.entry.js.map +1 -0
  931. package/dist/core/p-4efac9a5.entry.js +2 -0
  932. package/dist/core/p-4efac9a5.entry.js.map +1 -0
  933. package/dist/core/p-5278461f.entry.js +2 -0
  934. package/dist/core/p-5278461f.entry.js.map +1 -0
  935. package/dist/core/p-55278403.entry.js +2 -0
  936. package/dist/core/p-55278403.entry.js.map +1 -0
  937. package/dist/core/p-57839a76.entry.js +2 -0
  938. package/dist/core/p-57839a76.entry.js.map +1 -0
  939. package/dist/core/p-5914df44.entry.js +2 -0
  940. package/dist/core/p-5914df44.entry.js.map +1 -0
  941. package/dist/core/p-5d89cfab.entry.js +2 -0
  942. package/dist/core/p-5d89cfab.entry.js.map +1 -0
  943. package/dist/core/p-5f6b0c72.entry.js +2 -0
  944. package/dist/core/p-5f6b0c72.entry.js.map +1 -0
  945. package/dist/core/p-633cb50b.entry.js +2 -0
  946. package/dist/core/p-633cb50b.entry.js.map +1 -0
  947. package/dist/core/p-6f57b13c.js +2 -0
  948. package/dist/core/p-6f57b13c.js.map +1 -0
  949. package/dist/core/p-7232b2f0.entry.js +2 -0
  950. package/dist/core/p-7232b2f0.entry.js.map +1 -0
  951. package/dist/core/p-7adfd23a.entry.js +2 -0
  952. package/dist/core/p-7adfd23a.entry.js.map +1 -0
  953. package/dist/core/p-7b1dea48.entry.js +2 -0
  954. package/dist/core/p-7b1dea48.entry.js.map +1 -0
  955. package/dist/core/p-7b475a6c.entry.js +2 -0
  956. package/dist/core/p-7b475a6c.entry.js.map +1 -0
  957. package/dist/core/p-7c0dcd00.js +2 -0
  958. package/dist/core/p-7c0dcd00.js.map +1 -0
  959. package/dist/core/p-7dda131b.entry.js +2 -0
  960. package/dist/core/p-7dda131b.entry.js.map +1 -0
  961. package/dist/core/p-80c4fdfb.entry.js +2 -0
  962. package/dist/core/p-80c4fdfb.entry.js.map +1 -0
  963. package/dist/core/p-83adbb69.entry.js +2 -0
  964. package/dist/core/p-83adbb69.entry.js.map +1 -0
  965. package/dist/core/p-8ae9fdd1.entry.js +2 -0
  966. package/dist/core/p-8ae9fdd1.entry.js.map +1 -0
  967. package/dist/core/p-8c7f4343.js +2 -0
  968. package/dist/core/p-8c7f4343.js.map +1 -0
  969. package/dist/core/p-8d4f7027.js +2 -0
  970. package/dist/core/p-8d4f7027.js.map +1 -0
  971. package/dist/core/p-92a9c0f7.entry.js +2 -0
  972. package/dist/core/p-92a9c0f7.entry.js.map +1 -0
  973. package/dist/core/p-a3b86ed0.entry.js +2 -0
  974. package/dist/core/p-a3b86ed0.entry.js.map +1 -0
  975. package/dist/core/p-a9e4e5f8.entry.js +2 -0
  976. package/dist/core/p-a9e4e5f8.entry.js.map +1 -0
  977. package/dist/core/p-ad3102a5.entry.js +2 -0
  978. package/dist/core/p-ad3102a5.entry.js.map +1 -0
  979. package/dist/core/p-b36723c5.entry.js +2 -0
  980. package/dist/core/p-b36723c5.entry.js.map +1 -0
  981. package/dist/core/p-b5c0b75c.js +2 -0
  982. package/dist/core/p-b5c0b75c.js.map +1 -0
  983. package/dist/core/p-b6e9eab9.entry.js +2 -0
  984. package/dist/core/p-b6e9eab9.entry.js.map +1 -0
  985. package/dist/core/p-b7d521e9.entry.js +2 -0
  986. package/dist/core/p-b7d521e9.entry.js.map +1 -0
  987. package/dist/core/p-b9c3598b.entry.js +2 -0
  988. package/dist/core/p-b9c3598b.entry.js.map +1 -0
  989. package/dist/core/p-bdb10987.entry.js +2 -0
  990. package/dist/core/p-bdb10987.entry.js.map +1 -0
  991. package/dist/core/p-c571e57c.entry.js +2 -0
  992. package/dist/core/p-c571e57c.entry.js.map +1 -0
  993. package/dist/core/p-cc15dfdc.entry.js +2 -0
  994. package/dist/core/p-cc15dfdc.entry.js.map +1 -0
  995. package/dist/core/p-cc2b961d.entry.js +2 -0
  996. package/dist/core/p-cc2b961d.entry.js.map +1 -0
  997. package/dist/core/p-d0fccb05.entry.js +2 -0
  998. package/dist/core/p-d0fccb05.entry.js.map +1 -0
  999. package/dist/core/p-d19b9d1b.entry.js +2 -0
  1000. package/dist/core/p-d19b9d1b.entry.js.map +1 -0
  1001. package/dist/core/p-d77c0936.entry.js +2 -0
  1002. package/dist/core/p-d77c0936.entry.js.map +1 -0
  1003. package/dist/core/p-df0b02b4.entry.js +2 -0
  1004. package/dist/core/p-df0b02b4.entry.js.map +1 -0
  1005. package/dist/core/p-e948ffe5.entry.js +2 -0
  1006. package/dist/core/p-e948ffe5.entry.js.map +1 -0
  1007. package/dist/core/p-ed9bc07a.entry.js +2 -0
  1008. package/dist/core/p-ed9bc07a.entry.js.map +1 -0
  1009. package/dist/core/p-f0fd1444.entry.js +2 -0
  1010. package/dist/core/p-f0fd1444.entry.js.map +1 -0
  1011. package/dist/core/p-f91432bf.entry.js +2 -0
  1012. package/dist/core/p-f91432bf.entry.js.map +1 -0
  1013. package/dist/core/p-fdcf4f5d.entry.js +2 -0
  1014. package/dist/core/p-fdcf4f5d.entry.js.map +1 -0
  1015. package/dist/core/p-fef750a3.entry.js +2 -0
  1016. package/dist/core/p-fef750a3.entry.js.map +1 -0
  1017. package/dist/esm/OpenInNew-67a881e0.js +5 -0
  1018. package/dist/esm/OpenInNew-67a881e0.js.map +1 -0
  1019. package/dist/esm/check-icon-abb210ec.js +8 -0
  1020. package/dist/esm/check-icon-abb210ec.js.map +1 -0
  1021. package/dist/esm/chevron-icon-7927f709.js +8 -0
  1022. package/dist/esm/chevron-icon-7927f709.js.map +1 -0
  1023. package/dist/esm/close-icon-2f02b42a.js +10 -0
  1024. package/dist/esm/close-icon-2f02b42a.js.map +1 -0
  1025. package/dist/esm/core.js +23 -0
  1026. package/dist/esm/core.js.map +1 -0
  1027. package/dist/esm/helpers-8617aaa0.js +552 -0
  1028. package/dist/esm/helpers-8617aaa0.js.map +1 -0
  1029. package/dist/esm/ic-alert.entry.js +69 -0
  1030. package/dist/esm/ic-alert.entry.js.map +1 -0
  1031. package/dist/esm/ic-back-to-top.entry.js +141 -0
  1032. package/dist/esm/ic-back-to-top.entry.js.map +1 -0
  1033. package/dist/esm/ic-breadcrumb-group.entry.js +184 -0
  1034. package/dist/esm/ic-breadcrumb-group.entry.js.map +1 -0
  1035. package/dist/esm/ic-breadcrumb.entry.js +70 -0
  1036. package/dist/esm/ic-breadcrumb.entry.js.map +1 -0
  1037. package/dist/esm/ic-button_3.entry.js +554 -0
  1038. package/dist/esm/ic-button_3.entry.js.map +1 -0
  1039. package/dist/esm/ic-card.entry.js +122 -0
  1040. package/dist/esm/ic-card.entry.js.map +1 -0
  1041. package/dist/esm/ic-checkbox-group.entry.js +65 -0
  1042. package/dist/esm/ic-checkbox-group.entry.js.map +1 -0
  1043. package/dist/esm/ic-checkbox.entry.js +110 -0
  1044. package/dist/esm/ic-checkbox.entry.js.map +1 -0
  1045. package/dist/esm/ic-chip.entry.js +76 -0
  1046. package/dist/esm/ic-chip.entry.js.map +1 -0
  1047. package/dist/esm/ic-classification-banner.entry.js +38 -0
  1048. package/dist/esm/ic-classification-banner.entry.js.map +1 -0
  1049. package/dist/esm/ic-data-entity.entry.js +27 -0
  1050. package/dist/esm/ic-data-entity.entry.js.map +1 -0
  1051. package/dist/esm/ic-data-row.entry.js +87 -0
  1052. package/dist/esm/ic-data-row.entry.js.map +1 -0
  1053. package/dist/esm/ic-dialog.entry.js +291 -0
  1054. package/dist/esm/ic-dialog.entry.js.map +1 -0
  1055. package/dist/esm/ic-divider.entry.js +26 -0
  1056. package/dist/esm/ic-divider.entry.js.map +1 -0
  1057. package/dist/esm/ic-footer-link-group.entry.js +67 -0
  1058. package/dist/esm/ic-footer-link-group.entry.js.map +1 -0
  1059. package/dist/esm/ic-footer-link.entry.js +63 -0
  1060. package/dist/esm/ic-footer-link.entry.js.map +1 -0
  1061. package/dist/esm/ic-footer.entry.js +86 -0
  1062. package/dist/esm/ic-footer.entry.js.map +1 -0
  1063. package/dist/esm/ic-hero.entry.js +71 -0
  1064. package/dist/esm/ic-hero.entry.js.map +1 -0
  1065. package/dist/esm/ic-horizontal-scroll.entry.js +173 -0
  1066. package/dist/esm/ic-horizontal-scroll.entry.js.map +1 -0
  1067. package/dist/esm/ic-input-component-container_3.entry.js +693 -0
  1068. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -0
  1069. package/dist/esm/ic-input-label_2.entry.js +80 -0
  1070. package/dist/esm/ic-input-label_2.entry.js.map +1 -0
  1071. package/dist/esm/ic-link.entry.js +72 -0
  1072. package/dist/esm/ic-link.entry.js.map +1 -0
  1073. package/dist/esm/ic-menu-group.entry.js +20 -0
  1074. package/dist/esm/ic-menu-group.entry.js.map +1 -0
  1075. package/dist/esm/ic-menu-item.entry.js +118 -0
  1076. package/dist/esm/ic-menu-item.entry.js.map +1 -0
  1077. package/dist/esm/ic-navigation-button.entry.js +84 -0
  1078. package/dist/esm/ic-navigation-button.entry.js.map +1 -0
  1079. package/dist/esm/ic-navigation-group.entry.js +285 -0
  1080. package/dist/esm/ic-navigation-group.entry.js.map +1 -0
  1081. package/dist/esm/ic-navigation-item.entry.js +150 -0
  1082. package/dist/esm/ic-navigation-item.entry.js.map +1 -0
  1083. package/dist/esm/ic-navigation-menu.entry.js +120 -0
  1084. package/dist/esm/ic-navigation-menu.entry.js.map +1 -0
  1085. package/dist/esm/ic-page-header.entry.js +101 -0
  1086. package/dist/esm/ic-page-header.entry.js.map +1 -0
  1087. package/dist/esm/ic-pagination-bar.entry.js +266 -0
  1088. package/dist/esm/ic-pagination-bar.entry.js.map +1 -0
  1089. package/dist/esm/ic-pagination_4.entry.js +1108 -0
  1090. package/dist/esm/ic-pagination_4.entry.js.map +1 -0
  1091. package/dist/esm/ic-popover-menu.entry.js +233 -0
  1092. package/dist/esm/ic-popover-menu.entry.js.map +1 -0
  1093. package/dist/esm/ic-radio-group.entry.js +126 -0
  1094. package/dist/esm/ic-radio-group.entry.js.map +1 -0
  1095. package/dist/esm/ic-radio-option.entry.js +137 -0
  1096. package/dist/esm/ic-radio-option.entry.js.map +1 -0
  1097. package/dist/esm/ic-search-bar.entry.js +489 -0
  1098. package/dist/esm/ic-search-bar.entry.js.map +1 -0
  1099. package/dist/esm/ic-section-container.entry.js +25 -0
  1100. package/dist/esm/ic-section-container.entry.js.map +1 -0
  1101. package/dist/esm/ic-side-navigation.entry.js +431 -0
  1102. package/dist/esm/ic-side-navigation.entry.js.map +1 -0
  1103. package/dist/esm/ic-skeleton.entry.js +55 -0
  1104. package/dist/esm/ic-skeleton.entry.js.map +1 -0
  1105. package/dist/esm/ic-status-tag.entry.js +32 -0
  1106. package/dist/esm/ic-status-tag.entry.js.map +1 -0
  1107. package/dist/esm/ic-step.entry.js +136 -0
  1108. package/dist/esm/ic-step.entry.js.map +1 -0
  1109. package/dist/esm/ic-stepper.entry.js +217 -0
  1110. package/dist/esm/ic-stepper.entry.js.map +1 -0
  1111. package/dist/esm/ic-switch.entry.js +82 -0
  1112. package/dist/esm/ic-switch.entry.js.map +1 -0
  1113. package/dist/esm/ic-tab-context.entry.js +265 -0
  1114. package/dist/esm/ic-tab-context.entry.js.map +1 -0
  1115. package/dist/esm/ic-tab-group.entry.js +34 -0
  1116. package/dist/esm/ic-tab-group.entry.js.map +1 -0
  1117. package/dist/esm/ic-tab-panel.entry.js +40 -0
  1118. package/dist/esm/ic-tab-panel.entry.js.map +1 -0
  1119. package/dist/esm/ic-tab.entry.js +99 -0
  1120. package/dist/esm/ic-tab.entry.js.map +1 -0
  1121. package/dist/esm/ic-theme.entry.js +58 -0
  1122. package/dist/esm/ic-theme.entry.js.map +1 -0
  1123. package/dist/esm/ic-toast-region.entry.js +44 -0
  1124. package/dist/esm/ic-toast-region.entry.js.map +1 -0
  1125. package/dist/esm/ic-toast.entry.js +165 -0
  1126. package/dist/esm/ic-toast.entry.js.map +1 -0
  1127. package/dist/esm/ic-top-navigation.entry.js +213 -0
  1128. package/dist/esm/ic-top-navigation.entry.js.map +1 -0
  1129. package/dist/esm/ic-typography.entry.js +124 -0
  1130. package/dist/esm/ic-typography.entry.js.map +1 -0
  1131. package/dist/esm/ic-unstable-data-table.entry.js +267 -0
  1132. package/dist/esm/ic-unstable-data-table.entry.js.map +1 -0
  1133. package/dist/esm/index-36ab8165.js +2659 -0
  1134. package/dist/esm/index-36ab8165.js.map +1 -0
  1135. package/dist/esm/index.js +3 -0
  1136. package/dist/esm/index.js.map +1 -0
  1137. package/dist/esm/loader.js +20 -0
  1138. package/dist/esm/loader.js.map +1 -0
  1139. package/dist/esm/polyfills/core-js.js +11 -0
  1140. package/dist/esm/polyfills/css-shim.js +1 -0
  1141. package/dist/esm/polyfills/dom.js +79 -0
  1142. package/dist/esm/polyfills/es5-html-element.js +1 -0
  1143. package/dist/esm/polyfills/index.js +34 -0
  1144. package/dist/esm/polyfills/system.js +6 -0
  1145. package/dist/esm/popper-15e448b4.js +1794 -0
  1146. package/dist/esm/popper-15e448b4.js.map +1 -0
  1147. package/dist/esm/types-dd515332.js +16 -0
  1148. package/dist/esm/types-dd515332.js.map +1 -0
  1149. package/dist/index.cjs.js +1 -0
  1150. package/dist/index.js +1 -0
  1151. package/dist/types/components/ic-alert/ic-alert.d.ts +48 -0
  1152. package/dist/types/components/ic-alert/test/a11y/ic-alert.test.a11y.d.ts +1 -0
  1153. package/dist/types/components/ic-back-to-top/ic-back-to-top.d.ts +25 -0
  1154. package/dist/types/components/ic-back-to-top/test/a11y/ic-back-to-top.test.a11y.d.ts +1 -0
  1155. package/dist/types/components/ic-breadcrumb/ic-breadcrumb.d.ts +30 -0
  1156. package/dist/types/components/ic-breadcrumb/ic-breadcrumb.types.d.ts +1 -0
  1157. package/dist/types/components/ic-breadcrumb-group/ic-breadcrumb-group.d.ts +40 -0
  1158. package/dist/types/components/ic-breadcrumb-group/test/a11y/ic-breadcrumb-group.test.a11y.d.ts +1 -0
  1159. package/dist/types/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group-test-examples.d.ts +2 -0
  1160. package/dist/types/components/ic-button/ic-button.d.ts +132 -0
  1161. package/dist/types/components/ic-button/ic-button.types.d.ts +3 -0
  1162. package/dist/types/components/ic-button/test/a11y/ic-button.test.a11y.d.ts +1 -0
  1163. package/dist/types/components/ic-card/ic-card.d.ts +83 -0
  1164. package/dist/types/components/ic-card/test/a11y/ic-card.test.a11y.d.ts +1 -0
  1165. package/dist/types/components/ic-checkbox/ic-checkbox.d.ts +72 -0
  1166. package/dist/types/components/ic-checkbox-group/ic-checkbox-group.d.ts +54 -0
  1167. package/dist/types/components/ic-checkbox-group/ic-checkbox-group.types.d.ts +8 -0
  1168. package/dist/types/components/ic-checkbox-group/test/a11y/ic-checkbox-group.test.a11y.d.ts +1 -0
  1169. package/dist/types/components/ic-chip/ic-chip.d.ts +50 -0
  1170. package/dist/types/components/ic-chip/ic-chip.types.d.ts +1 -0
  1171. package/dist/types/components/ic-chip/test/a11y/ic-chip.test.a11y.d.ts +1 -0
  1172. package/dist/types/components/ic-classification-banner/ic-classification-banner.d.ts +24 -0
  1173. package/dist/types/components/ic-classification-banner/ic-classification-banner.types.d.ts +1 -0
  1174. package/dist/types/components/ic-classification-banner/test/a11y/ic-classification-banner.test.a11y.d.ts +1 -0
  1175. package/dist/types/components/ic-data-entity/ic-data-entity.d.ts +12 -0
  1176. package/dist/types/components/ic-data-entity/test/a11y/ic-data-entity.test.a11y.d.ts +1 -0
  1177. package/dist/types/components/ic-data-row/ic-data-row.d.ts +37 -0
  1178. package/dist/types/components/ic-data-row/test/a11y/ic-data-row.test.a11y.d.ts +1 -0
  1179. package/dist/types/components/ic-data-table/ic-data-table.d.ts +97 -0
  1180. package/dist/types/components/ic-data-table/ic-data-table.types.d.ts +15 -0
  1181. package/dist/types/components/ic-data-table/test/a11y/ic-data-table.test.a11y.d.ts +1 -0
  1182. package/dist/types/components/ic-dialog/ic-dialog.d.ts +123 -0
  1183. package/dist/types/components/ic-dialog/test/a11y/ic-dialog.test.a11y.d.ts +1 -0
  1184. package/dist/types/components/ic-divider/ic-divider.d.ts +6 -0
  1185. package/dist/types/components/ic-footer/ic-footer.d.ts +52 -0
  1186. package/dist/types/components/ic-footer/ic-footer.types.d.ts +1 -0
  1187. package/dist/types/components/ic-footer/test/a11y/ic-footer.test.a11y.d.ts +1 -0
  1188. package/dist/types/components/ic-footer-link/ic-footer-link.d.ts +41 -0
  1189. package/dist/types/components/ic-footer-link/test/a11y/ic-footer-link.test.a11y.d.ts +1 -0
  1190. package/dist/types/components/ic-footer-link-group/ic-footer-link-group.d.ts +19 -0
  1191. package/dist/types/components/ic-footer-link-group/test/a11y/ic-footer-link-group.test.a11y.d.ts +1 -0
  1192. package/dist/types/components/ic-hero/ic-hero.d.ts +57 -0
  1193. package/dist/types/components/ic-hero/ic-hero.types.d.ts +1 -0
  1194. package/dist/types/components/ic-hero/test/a11y/ic-hero.test.a11y.d.ts +1 -0
  1195. package/dist/types/components/ic-horizontal-scroll/ic-horizontal-scroll.d.ts +40 -0
  1196. package/dist/types/components/ic-horizontal-scroll/test/a11y/ic-horizontal-scroll.test.a11y.d.ts +1 -0
  1197. package/dist/types/components/ic-input-component-container/ic-input-component-container.d.ts +40 -0
  1198. package/dist/types/components/ic-input-container/ic-input-container.d.ts +11 -0
  1199. package/dist/types/components/ic-input-label/ic-input-label.d.ts +36 -0
  1200. package/dist/types/components/ic-input-validation/ic-input-validation.d.ts +30 -0
  1201. package/dist/types/components/ic-input-validation/ic-input-validation.types.d.ts +1 -0
  1202. package/dist/types/components/ic-link/ic-link.d.ts +50 -0
  1203. package/dist/types/components/ic-link/test/a11y/ic-link.test.a11y.d.ts +1 -0
  1204. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.d.ts +80 -0
  1205. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.types.d.ts +7 -0
  1206. package/dist/types/components/ic-loading-indicator/test/a11y/ic-loading-indicator.test.a11y.d.ts +1 -0
  1207. package/dist/types/components/ic-menu/ic-menu.d.ts +167 -0
  1208. package/dist/types/components/ic-menu/ic-menu.types.d.ts +12 -0
  1209. package/dist/types/components/ic-menu-group/ic-menu-group.d.ts +8 -0
  1210. package/dist/types/components/ic-menu-item/ic-menu-item.d.ts +74 -0
  1211. package/dist/types/components/ic-menu-item/ic-menu-item.types.d.ts +1 -0
  1212. package/dist/types/components/ic-navigation-button/ic-navigation-button.d.ts +53 -0
  1213. package/dist/types/components/ic-navigation-button/ic-navigation-button.types.d.ts +1 -0
  1214. package/dist/types/components/ic-navigation-group/ic-navigation-group.d.ts +63 -0
  1215. package/dist/types/components/ic-navigation-group/test/a11y/ic-navigation-group.test.a11y.d.ts +1 -0
  1216. package/dist/types/components/ic-navigation-item/ic-navigation-item.d.ts +85 -0
  1217. package/dist/types/components/ic-navigation-item/test/a11y/ic-navigation-item.test.a11y.d.ts +1 -0
  1218. package/dist/types/components/ic-navigation-menu/ic-navigation-menu.d.ts +36 -0
  1219. package/dist/types/components/ic-page-header/ic-page-header.d.ts +57 -0
  1220. package/dist/types/components/ic-page-header/test/a11y/ic-page-header.test.a11y.d.ts +1 -0
  1221. package/dist/types/components/ic-pagination/ic-pagination.d.ts +82 -0
  1222. package/dist/types/components/ic-pagination/ic-pagination.types.d.ts +6 -0
  1223. package/dist/types/components/ic-pagination/test/a11y/ic-pagination.test.a11y.d.ts +1 -0
  1224. package/dist/types/components/ic-pagination-bar/ic-pagination-bar.d.ts +103 -0
  1225. package/dist/types/components/ic-pagination-bar/test/a11y/ic-pagination-bar.test.a11y.d.ts +1 -0
  1226. package/dist/types/components/ic-pagination-item/ic-pagination-item.d.ts +47 -0
  1227. package/dist/types/components/ic-pagination-item/ic-pagination-item.types.d.ts +1 -0
  1228. package/dist/types/components/ic-popover-menu/ic-popover-menu.d.ts +59 -0
  1229. package/dist/types/components/ic-popover-menu/test/a11y/ic-popover-menu.test.a11y.d.ts +1 -0
  1230. package/dist/types/components/ic-radio-group/ic-radio-group.d.ts +60 -0
  1231. package/dist/types/components/ic-radio-group/ic-radio-group.types.d.ts +7 -0
  1232. package/dist/types/components/ic-radio-group/test/a11y/ic-radio-group.test.a11y.d.ts +1 -0
  1233. package/dist/types/components/ic-radio-option/ic-radio-option.d.ts +70 -0
  1234. package/dist/types/components/ic-search-bar/ic-search-bar.d.ts +243 -0
  1235. package/dist/types/components/ic-search-bar/ic-search-bar.types.d.ts +5 -0
  1236. package/dist/types/components/ic-search-bar/test/a11y/ic-search-bar.test.a11y.d.ts +1 -0
  1237. package/dist/types/components/ic-section-container/ic-section-container.d.ts +12 -0
  1238. package/dist/types/components/ic-select/ic-select.d.ts +226 -0
  1239. package/dist/types/components/ic-select/test/a11y/ic-select.test.a11y.d.ts +1 -0
  1240. package/dist/types/components/ic-side-navigation/ic-side-navigation.d.ts +101 -0
  1241. package/dist/types/components/ic-side-navigation/ic-side-navigation.types.d.ts +9 -0
  1242. package/dist/types/components/ic-side-navigation/test/a11y/ic-side-navigation.test.a11y.d.ts +1 -0
  1243. package/dist/types/components/ic-side-navigation/test/basic/ic-side-navigation-test-examples.d.ts +6 -0
  1244. package/dist/types/components/ic-skeleton/ic-skeleton.d.ts +18 -0
  1245. package/dist/types/components/ic-skeleton/ic-skeleton.types.d.ts +1 -0
  1246. package/dist/types/components/ic-skeleton/test/a11y/ic-skeleton.test.a11y.d.ts +1 -0
  1247. package/dist/types/components/ic-status-tag/ic-status-tag.d.ts +25 -0
  1248. package/dist/types/components/ic-status-tag/ic-status-tag.types.d.ts +2 -0
  1249. package/dist/types/components/ic-status-tag/test/a11y/ic-status-tag.test.a11y.d.ts +1 -0
  1250. package/dist/types/components/ic-step/ic-step.d.ts +54 -0
  1251. package/dist/types/components/ic-step/ic-step.types.d.ts +3 -0
  1252. package/dist/types/components/ic-stepper/ic-stepper.d.ts +43 -0
  1253. package/dist/types/components/ic-stepper/ic-stepper.types.d.ts +1 -0
  1254. package/dist/types/components/ic-stepper/test/a11y/ic-stepper.test.a11y.d.ts +1 -0
  1255. package/dist/types/components/ic-stepper/test/basic/ic-stepper-test-examples.d.ts +4 -0
  1256. package/dist/types/components/ic-switch/ic-switch.d.ts +75 -0
  1257. package/dist/types/components/ic-switch/ic-switch.types.d.ts +4 -0
  1258. package/dist/types/components/ic-switch/test/a11y/ic-switch.test.a11y.d.ts +1 -0
  1259. package/dist/types/components/ic-tab/ic-tab.d.ts +59 -0
  1260. package/dist/types/components/ic-tab/ic-tab.types.d.ts +8 -0
  1261. package/dist/types/components/ic-tab-context/ic-tab-context.d.ts +64 -0
  1262. package/dist/types/components/ic-tab-context/test/a11y/ic-tab-context.test.a11y.d.ts +1 -0
  1263. package/dist/types/components/ic-tab-group/ic-tab-group.d.ts +23 -0
  1264. package/dist/types/components/ic-tab-panel/ic-tab-panel.d.ts +37 -0
  1265. package/dist/types/components/ic-text-field/ic-text-field.d.ts +217 -0
  1266. package/dist/types/components/ic-text-field/ic-text-field.types.d.ts +3 -0
  1267. package/dist/types/components/ic-text-field/test/a11y/ic-text-field.test.a11y.d.ts +1 -0
  1268. package/dist/types/components/ic-theme/ic-theme.d.ts +18 -0
  1269. package/dist/types/components/ic-toast/ic-toast.d.ts +66 -0
  1270. package/dist/types/components/ic-toast/ic-toast.types.d.ts +1 -0
  1271. package/dist/types/components/ic-toast/test/a11y/ic-toast.test.a11y.d.ts +1 -0
  1272. package/dist/types/components/ic-toast-region/ic-toast-region.d.ts +12 -0
  1273. package/dist/types/components/ic-tooltip/ic-tooltip.d.ts +50 -0
  1274. package/dist/types/components/ic-tooltip/ic-tooltip.types.d.ts +1 -0
  1275. package/dist/types/components/ic-tooltip/test/a11y/ic-tooltip.test.a11y.d.ts +1 -0
  1276. package/dist/types/components/ic-top-navigation/ic-top-navigation.d.ts +84 -0
  1277. package/dist/types/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.d.ts +1 -0
  1278. package/dist/types/components/ic-typography/ic-typography.d.ts +56 -0
  1279. package/dist/types/components/ic-typography/test/a11y/ic-typography.test.a11y.d.ts +1 -0
  1280. package/dist/types/components.d.ts +4709 -0
  1281. package/dist/types/index.d.ts +1 -0
  1282. package/dist/types/interface.d.ts +14 -0
  1283. package/dist/types/stencil-public-runtime.d.ts +1640 -0
  1284. package/dist/types/testspec.setup.d.ts +15 -0
  1285. package/dist/types/utils/constants.d.ts +38 -0
  1286. package/dist/types/utils/helpers.d.ts +123 -0
  1287. package/dist/types/utils/testa11y.helpers.d.ts +2 -0
  1288. package/dist/types/utils/types.d.ts +65 -0
  1289. package/hydrate/index.d.ts +218 -0
  1290. package/hydrate/index.js +18605 -0
  1291. package/hydrate/package.json +6 -0
  1292. package/loader/cdn.js +3 -0
  1293. package/loader/index.cjs.js +3 -0
  1294. package/loader/index.d.ts +21 -0
  1295. package/loader/index.es2017.js +3 -0
  1296. package/loader/index.js +4 -0
  1297. package/loader/package.json +11 -0
  1298. package/package.json +81 -0
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icInputComponentContainerCss","InputComponentContainer","render","small","validationStatus","disabled","readonly","multiLine","fullWidth","dark","validationInline","this","hasValidationStatus","h","Host","class","isSlotUsed","host","name","IcInformationStatus","Success","innerHTML","successIcon","icInputContainerCss","InputContainer","icMenuCss","Menu","firstRender","hasPreviouslyBlurred","hasTimedOut","isLoading","isSearchBar","isSearchableSelect","preventClickOpen","ungroupedOptions","handleClearListener","optionHighlighted","handleSubmitSearch","highlightedOptionIndex","options","findIndex","option","value","setInputValue","handleMenuChange","open","focusInput","menuStateChange","emit","inputEl","focus","setNextOptionValue","selectedOptionIndex","menuOptionSelect","optionId","getOptionId","setPreviousOptionValue","length","getParentEl","parent","tagName","getAttribute","undefined","arrowBehaviour","event","preventDefault","setMenuOptions","setHighlightedOption","highlightedIndex","menuOptions","timedOut","autoSetInputValueKeyboardOpen","keyboardNav","key","target","id","manSetInputValueKeyboardOpen","index","_a","Array","from","querySelectorAll","menuOptionId","preventIncorrectTabOrder","focusFromSearchKeypress","stopImmediatePropagation","parentEl","setFocus","searchMode","handleOptionClick","label","dataset","handleRetry","retryButtonClicked","handleRetryKeyDown","ev","keyPressed","handleBlur","relatedTarget","menu","contains","handleMouseDown","handleMenuKeyDown","activationType","autoSetValueOnMenuKeyDown","emitMenuKeyPress","isNavKey","menuKeyPress","cancelBubble","handleMenuKeyUp","shiftKey","menuId","getOptionAriaLabel","parentOption","ariaLabel","description","getSortedOptions","sorted","sort","optionA","optionB","recommended","isManualMode","scrollToSelected","selectedOption","querySelector","elTop","offsetTop","offsetHeight","scrollTop","loadUngroupedOptions","map","children","push","ungroupedOptionsSet","setMenuScrollbar","optionsHeight","forEach","clientHeight","classList","add","handleTimeoutBlur","timeoutBlur","optionContent","Fragment","loading","size","variant","toLowerCase","Check","displayOption","initialOptionsListRender","timeout","role","tabindex","onClick","onBlur","onMouseDown","xmlns","viewBox","fill","d","onKeyDown","watchOptionsHandler","newOptions","some","opt","watchValueHandler","menuValueChange","connectedCallback","disconnectedCallback","popperInstance","destroy","removeEventListener","componentWillLoad","addEventListener","_b","componentDidLoad","disableFilter","onComponentRequiredPropUndefined","prop","propName","inputLabel","componentDidUpdate","inputValueInOptions","optionHighlightedIsSet","autoFocusOnSelected","highlightedEl","componentDidRender","adjust","dialogEl","closest","onDialog","menuTop","getBoundingClientRect","top","menuHeight","height","dialogHeight","bottom","createPopper","anchorEl","placement","modifiers","offset","fallbackPlacements","rootBoundary","update","async","ref","el","onKeyUp","childOption"],"sources":["./src/components/ic-input-component-container/ic-input-component-container.css?tag=ic-input-component-container","./src/components/ic-input-component-container/ic-input-component-container.tsx","./src/components/ic-input-container/ic-input-container.css?tag=ic-input-container","./src/components/ic-input-container/ic-input-container.tsx","./src/components/ic-menu/ic-menu.css?tag=ic-menu&encapsulation=scoped","./src/components/ic-menu/ic-menu.tsx"],"sourcesContent":["ic-input-component-container {\n /**\n * @prop --border-color: Border colour of the input component container\n */\n\n display: flex;\n border: var(--ic-space-1px) solid\n var(--border-color, var(--ic-architectural-400));\n border-radius: var(--ic-border-radius);\n transition: var(--ic-easing-transition-slow);\n height: 2.5rem;\n width: var(--input-width, 20rem);\n padding: var(--ic-space-1px);\n background-color: var(--ic-architectural-white);\n box-sizing: border-box;\n fill: var(--ic-architectural-400);\n outline: none;\n}\n\nic-input-component-container.fullwidth {\n width: 100%;\n}\n\nic-input-component-container.disabled,\nic-input-component-container.disabled:hover {\n border: var(--ic-space-1px) dashed var(--ic-architectural-200);\n}\n\nic-input-component-container.readonly,\nic-input-component-container.readonly:hover {\n border: none;\n padding: 0;\n}\n\nic-input-component-container.error {\n border: var(--ic-error-border-default);\n padding: 0;\n}\n\nic-input-component-container.error:hover {\n border: var(--ic-error-border-hover);\n}\n\nic-input-component-container.error:focus-within {\n border: var(--ic-error-border-pressed);\n}\n\nic-input-component-container.warning {\n border: var(--ic-warning-border-default);\n padding: 0;\n}\n\nic-input-component-container.warning:hover {\n border: var(--ic-warning-border-hover);\n}\n\nic-input-component-container.warning:focus-within {\n border: var(--ic-warning-border-pressed);\n}\n\nic-input-component-container.success {\n border: var(--ic-success-border-default);\n padding: 0;\n}\n\nic-input-component-container.success:hover {\n border: var(--ic-success-border-hover);\n}\n\nic-input-component-container.success:focus-within {\n border: var(--ic-success-border-pressed);\n}\n\nic-input-component-container.small {\n height: var(--ic-space-xl);\n}\n\nic-input-component-container.multiline {\n height: auto;\n}\n\nic-input-component-container .icon-container {\n margin-top: var(--ic-space-xxs);\n margin-left: 0.438rem;\n display: flex;\n align-items: center;\n}\n\nic-input-component-container.multiline .icon-container,\nic-input-component-container.multiline.small .icon-container {\n margin-top: 0.375rem;\n display: block;\n}\n\nic-input-component-container.readonly .icon-container {\n margin-left: -0.313rem;\n}\n\nic-input-component-container.disabled ::placeholder {\n display: none;\n}\n\nic-input-component-container .inline-success {\n margin: var(--ic-space-xs) 0.375rem;\n display: flex;\n align-items: center;\n}\n\nic-input-component-container.dark:hover {\n --border-color: var(--ic-architectural-400);\n}\n\nic-input-component-container .inline-success > svg {\n fill: var(--ic-status-success);\n height: 1.25rem;\n width: 1.25rem;\n}\n\nic-input-component-container:hover {\n border: var(--ic-border-hover);\n color: var(--ic-action-dark-hover);\n}\n\nic-input-component-container:focus {\n border: var(--ic-border-pressed);\n}\n\n.focus-indicator {\n display: flex;\n width: 100%;\n margin: -0.125rem;\n padding: 0.125rem;\n border-radius: var(--ic-border-radius);\n transition: var(--ic-easing-transition-fast);\n}\n\n.focus-indicator:focus-within,\n.focus-indicator-enabled {\n box-shadow: var(--ic-border-focus);\n}\n\n.focus-indicator.dark:focus-within {\n box-shadow: var(--ic-border-focus);\n}\n\n@media (forced-colors: active) {\n /* Styles here only apply to Forced Colors Mode */\n ic-input-component-container,\n .focus-indicator {\n transition: none;\n }\n\n ic-input-component-container:focus-within {\n border: var(--ic-space-1px) solid Highlight;\n outline: 0.125rem solid Highlight;\n }\n\n ic-input-component-container.disabled,\n ic-input-component-container.disabled:hover {\n border: var(--ic-space-1px) dashed GrayText;\n }\n}\n","import { Component, Element, Host, Prop, h } from \"@stencil/core\";\n\nimport {\n IcInformationStatus,\n IcInformationStatusOrEmpty,\n} from \"../../utils/types\";\nimport successIcon from \"../../assets/success-icon.svg\";\nimport { isSlotUsed } from \"../../utils/helpers\";\n\n/**\n * @slot left-icon - Content will be placed to the left of the input.\n */\n@Component({\n tag: \"ic-input-component-container\",\n styleUrl: \"ic-input-component-container.css\",\n})\nexport class InputComponentContainer {\n @Element() host: HTMLIcInputComponentContainerElement;\n\n /**\n * If `true`, the dark variant of the input component container will be displayed.\n */\n @Prop() dark?: boolean = false;\n\n /**\n * If `true`, the disabled state will be set.\n */\n @Prop() disabled: boolean = false;\n\n /**\n * If `true`, the input component container will fill the width of the container it is in.\n */\n @Prop() fullWidth: boolean = false;\n\n /**\n * If `true`, the input component container will allow for multiple lines.\n */\n @Prop() multiLine: boolean = false;\n\n /**\n * If `true`, the readonly state will be set.\n */\n @Prop() readonly: boolean = false;\n\n /**\n * If `true`, the small styling will be applied to the input component container.\n */\n @Prop() small: boolean = false;\n\n /**\n * If `true`, the validation will display inline.\n */\n @Prop() validationInline: boolean = false;\n\n /**\n * The validation status of the input component container - e.g. 'error' | 'warning' | 'success'.\n */\n @Prop() validationStatus: IcInformationStatusOrEmpty = \"\";\n\n render() {\n const {\n small,\n validationStatus,\n disabled,\n readonly,\n multiLine,\n fullWidth,\n dark,\n validationInline,\n } = this;\n const hasValidationStatus =\n this.validationStatus !== \"\" && !this.disabled && !this.readonly\n ? true\n : false;\n return (\n <Host\n class={{\n [\"small\"]: small,\n [validationStatus]: hasValidationStatus,\n [\"disabled\"]: disabled,\n [\"readonly\"]: readonly,\n [\"multiline\"]: multiLine,\n [\"fullwidth\"]: fullWidth,\n [\"dark\"]: dark,\n }}\n >\n <div\n class={{\n \"focus-indicator\": true,\n dark: dark,\n }}\n >\n {isSlotUsed(this.host, \"left-icon\") && (\n <div\n class={{\n [\"icon-container\"]: true,\n }}\n >\n <slot name=\"left-icon\" />\n </div>\n )}\n <slot></slot>\n\n {validationInline &&\n validationStatus === IcInformationStatus.Success && (\n <span\n class={{\n [\"inline-success\"]: true,\n }}\n innerHTML={successIcon}\n />\n )}\n </div>\n </Host>\n );\n }\n}\n","ic-input-container .component-container {\n display: flex;\n flex-direction: column;\n}\n","import { Component, Host, Prop, h } from \"@stencil/core\";\n\n@Component({\n tag: \"ic-input-container\",\n styleUrl: \"ic-input-container.css\",\n})\nexport class InputContainer {\n /**\n * If `true`, the disabled state will be set.\n */\n @Prop() disabled?: boolean = false;\n\n /**\n * If `true`, the readonly state will be set.\n */\n @Prop() readonly?: boolean = false;\n\n render() {\n return (\n <Host>\n <div\n class={{\n [\"component-container\"]: true,\n [\"disabled\"]: this.disabled,\n [\"readonly\"]: this.readonly,\n }}\n >\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n","@import \"../../global/normalize.css\";\n\n/**\n * @prop --ic-z-index-menu: z-index of menu\n */\n\n@media (prefers-reduced-motion: no-preference) {\n :host(.open) .menu {\n transition: max-height var(--ic-transition-duration-slow);\n }\n}\n\n:host {\n border-radius: var(--ic-border-radius);\n max-height: 0;\n width: var(--input-width, 20rem);\n color: var(--ic-color-primary-text);\n background-color: var(--ic-architectural-white);\n position: relative;\n z-index: var(--ic-z-index-menu);\n box-sizing: border-box;\n box-shadow: var(--ic-elevation-overlay);\n}\n\n:host(:not(.no-focus):focus-within) {\n box-shadow: var(--ic-border-focus);\n}\n\n#retry-button::part(button) {\n height: var(--ic-space-lg);\n}\n\n.small #retry-button::part(button) {\n height: var(--ic-space-md);\n}\n\n:host(.on-dialog) {\n inset: auto !important;\n}\n\n:host(.on-dialog-fix-translate) {\n transform: translate(0, 80px) !important;\n}\n\n.menu {\n text-decoration: none;\n list-style-type: none;\n border: var(--ic-space-1px) solid var(--ic-architectural-400);\n border-radius: var(--ic-border-radius);\n background-color: var(--ic-architectural-white);\n visibility: hidden;\n max-height: 0;\n overflow-y: hidden;\n}\n\n.menu-scroll {\n overflow-y: auto;\n}\n\n.menu:focus-visible {\n outline: none;\n}\n\n:host(.open) {\n max-height: none;\n display: block;\n}\n\n:host(.open) .menu {\n visibility: visible;\n max-height: 20.125rem;\n}\n\n:host(.full-width) {\n width: 100%;\n}\n\n.option {\n padding: 0.5rem 0.438rem;\n cursor: pointer;\n display: flex;\n align-items: center;\n}\n\n.option:not(.loading-option) {\n justify-content: space-between;\n}\n\n:host(.small) .option {\n padding: 0.25rem 0.438rem;\n}\n\n.option:last-child {\n border-radius: 0 0 var(--ic-space-1px) var(--ic-space-1px);\n}\n\n.option:first-child {\n border-radius: var(--ic-space-1px) var(--ic-space-1px) 0 0;\n}\n\n.option:not(.disabled-option):hover {\n background-color: var(--ic-action-dark-bg-hover);\n}\n\n.option:not(.disabled-option):active {\n background-color: var(--ic-action-dark-bg-active);\n}\n\n.option:focus-visible {\n outline: var(--ic-hc-focus-outline);\n}\n\n.option:not(.disabled-option) .option-description {\n color: var(--ic-color-secondary-text);\n}\n\n.option-text-container {\n pointer-events: none;\n}\n\n.option.loading-option .option-text-container {\n margin-left: 0.625rem;\n color: var(--ic-color-secondary-text);\n}\n\n.error-icon-svg {\n height: var(--ic-space-md);\n width: var(--ic-space-md);\n fill: var(--ic-status-error);\n align-self: center;\n display: flex;\n margin-right: calc(var(--ic-space-xxs) * 1.2);\n}\n\n.loading-error-info {\n display: flex;\n}\n\n.check-icon {\n height: var(--ic-space-lg);\n width: var(--ic-space-lg);\n margin-left: 0.5rem;\n pointer-events: none;\n}\n\n.focused-option .check-icon * {\n fill: currentcolor;\n}\n\n.option-group-title {\n padding: 1.5rem 0.438rem 0.5rem;\n color: var(--ic-color-tertiary-text);\n}\n\n:host(.small) .option-group-title {\n padding: 0.75rem 0.438rem 0.25rem;\n}\n\n.last-recommended-option {\n border-bottom: var(--ic-border-default);\n}\n\n.disabled-option {\n color: var(--ic-architectural-200);\n cursor: default;\n pointer-events: none;\n}\n\n.focused-option,\n.focused-option .option-description {\n background-color: var(--ic-focus-blue) !important;\n color: var(--ic-color-white-text) !important;\n}\n\n:host(.no-results) li {\n cursor: no-drop;\n}\n\n:host(.no-results) li:hover {\n background-color: transparent;\n}\n\n@media (forced-colors: active) {\n .focused-option:focus {\n outline: none;\n border: 0.125rem solid transparent;\n }\n}\n","import {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Prop,\n Method,\n State,\n Watch,\n Fragment,\n} from \"@stencil/core\";\nimport { createPopper, Instance as PopperInstance } from \"@popperjs/core\";\n\nimport {\n IcActivationTypes,\n IcMenuOption,\n IcValueEventDetail,\n} from \"../../utils/types\";\nimport Check from \"../../assets/check-icon.svg\";\nimport { onComponentRequiredPropUndefined } from \"../../utils/helpers\";\nimport {\n IcOptionSelectEventDetail,\n IcMenuChangeEventDetail,\n IcMenuOptionIdEventDetail,\n} from \"./ic-menu.types\";\nimport { IcSearchBarSearchModes } from \"../ic-search-bar/ic-search-bar.types\";\n\n@Component({\n tag: \"ic-menu\",\n styleUrl: \"ic-menu.css\",\n scoped: true,\n})\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport class Menu {\n private firstRender: boolean = true;\n private hasPreviouslyBlurred: boolean = false;\n private hasTimedOut: boolean = false;\n private isLoading: boolean = false;\n private isSearchBar: boolean = false;\n private isSearchableSelect: boolean = false;\n private menu: HTMLUListElement;\n private popperInstance: PopperInstance;\n // Prevents menu re-opening immediately after it is closed on blur when clicking input.\n private preventClickOpen: boolean = false;\n private ungroupedOptions: IcMenuOption[] = [];\n\n @Element() host: HTMLIcMenuElement;\n\n @State() focusFromSearchKeypress: boolean = false;\n @State() initialOptionsListRender: boolean = false;\n @State() keyboardNav: boolean = false;\n @State() optionHighlighted: string;\n @State() preventIncorrectTabOrder: boolean = false;\n\n /**\n * Determines whether options manually set as values (by pressing 'Enter') when they receive focus using keyboard navigation.\n */\n @Prop() activationType?: IcActivationTypes = \"automatic\";\n\n /**\n * The reference to an anchor element the menu will position itself from when rendered.\n */\n @Prop() anchorEl!: HTMLElement;\n\n /**\n * @internal If `true`, autofocus will be applied on selected item when menu is open.\n */\n @Prop() autoFocusOnSelected: boolean = true;\n\n /**\n * If `true`, the menu will fill the width of the container.\n */\n @Prop() fullWidth: boolean = false;\n\n /**\n * The reference to the input element.\n */\n @Prop() inputEl!: HTMLElement;\n\n /**\n * The label for the input element.\n */\n @Prop() inputLabel!: string;\n\n /**\n * The ID of the menu.\n */\n @Prop() menuId!: string;\n\n /**\n * If `true`, the menu will be displayed open.\n */\n @Prop({ reflect: true }) open!: boolean;\n\n /**\n * @internal - The parent element if ic-menu is nested inside another component.\n */\n @Prop() parentEl?: HTMLElement;\n\n /**\n * Specify the mode search bar uses to search. `navigation` allows for quick lookups of a set of values, `query` allows for more general searches.\n */\n @Prop() searchMode?: IcSearchBarSearchModes = \"navigation\";\n\n /**\n * If `true`, the small styling will be applied to the menu.\n */\n @Prop({ reflect: true }) small?: boolean = false;\n\n /**\n * The possible menu selection options.\n */\n @Prop() options!: IcMenuOption[];\n\n @Watch(\"options\")\n watchOptionsHandler(newOptions: IcMenuOption[]): void {\n this.hasTimedOut = newOptions.some((opt) => opt.timedOut);\n this.isLoading = newOptions.some((opt) => opt.loading);\n this.ungroupedOptions = [];\n this.loadUngroupedOptions();\n }\n\n /**\n * The value of the currently selected option.\n */\n @Prop({ mutable: true }) value!: string;\n\n @Watch(\"value\")\n watchValueHandler(): void {\n this.menuValueChange.emit({ value: this.value });\n }\n\n /**\n * @internal Emitted when key is pressed while menu is open\n */\n @Event() menuKeyPress: EventEmitter<{ isNavKey: boolean; key: string }>;\n\n /**\n * @internal Emitted when an option has been highlighted\n */\n @Event() menuOptionId: EventEmitter<IcMenuOptionIdEventDetail>;\n\n /**\n * @internal Emitted when an option is selected.\n */\n @Event() menuOptionSelect!: EventEmitter<IcOptionSelectEventDetail>;\n\n /**\n * @internal Emitted when state of menu changes (i.e. open or close).\n */\n @Event() menuStateChange!: EventEmitter<IcMenuChangeEventDetail>;\n\n /**\n * @internal Emitted when menu value changes.\n */\n @Event() menuValueChange: EventEmitter<IcValueEventDetail>;\n\n /**\n * @internal Emitted when the retry button is clicked\n */\n @Event() retryButtonClicked: EventEmitter<IcValueEventDetail>;\n\n /**\n * @internal Emitted when the timeout menu loses focus\n */\n @Event() timeoutBlur: EventEmitter<{ ev: FocusEvent }>;\n\n /**\n * @internal Emitted when the ungrouped options have been set.\n */\n @Event() ungroupedOptionsSet: EventEmitter<{ options: IcMenuOption[] }>;\n\n connectedCallback(): void {\n this.getParentEl(this.parentEl);\n\n if (this.isSearchBar) {\n if (this.searchMode === \"navigation\") this.setHighlightedOption(0);\n this.initialOptionsListRender = true;\n }\n }\n\n disconnectedCallback(): void {\n if (this.popperInstance !== undefined) {\n this.popperInstance.destroy();\n }\n this.parentEl.removeEventListener(\"icClear\", this.handleClearListener);\n this.parentEl.removeEventListener(\n \"icSubmitSearch\",\n this.handleSubmitSearch\n );\n }\n\n componentWillLoad(): void {\n this.loadUngroupedOptions();\n this.parentEl.addEventListener(\"icClear\", this.handleClearListener);\n this.parentEl.addEventListener(\"icSubmitSearch\", this.handleSubmitSearch);\n this.hasTimedOut = this.options?.some((opt) => opt.timedOut);\n this.isLoading = this.options?.some((opt) => opt.loading);\n }\n\n componentDidLoad(): void {\n if (\n this.isSearchBar &&\n (this.parentEl as HTMLIcSearchBarElement).disableFilter\n ) {\n this.focusFromSearchKeypress = true;\n }\n\n onComponentRequiredPropUndefined(\n [\n { prop: this.open, propName: \"open\" },\n { prop: this.options, propName: \"options\" },\n { prop: this.menuId, propName: \"menu-id\" },\n { prop: this.inputLabel, propName: \"input-label\" },\n //NOTE: no check for value, input-el or anchor-el as otherwise get console errors on first load of select component\n ],\n \"Menu\"\n );\n }\n\n componentDidUpdate(): void {\n const inputValueInOptions: boolean = this.options.some(\n (option) => option.value === this.value\n );\n\n const optionHighlightedIsSet =\n this.optionHighlighted !== null &&\n this.optionHighlighted !== undefined &&\n this.optionHighlighted !== \"\";\n\n if (this.open && this.options.length !== 0) {\n if (\n this.value &&\n this.keyboardNav &&\n inputValueInOptions &&\n this.autoFocusOnSelected &&\n !this.isSearchableSelect\n ) {\n this.scrollToSelected(this.menu);\n } else if (\n this.inputEl.tagName !== \"IC-TEXT-FIELD\" &&\n this.inputEl.tagName !== \"INPUT\"\n ) {\n this.menu.focus();\n } else if (\n optionHighlightedIsSet &&\n !this.focusFromSearchKeypress &&\n !this.preventIncorrectTabOrder\n ) {\n const highlightedEl = this.host.querySelector(\n `li[data-value=\"${this.optionHighlighted}\"]`\n ) as HTMLElement;\n\n if (highlightedEl) {\n highlightedEl.focus();\n }\n }\n }\n }\n\n componentDidRender(): void {\n if (this.firstRender && this.open) {\n this.firstRender = false;\n let adjust = false;\n\n const dialogEl = this.parentEl.closest(\"ic-dialog\");\n\n const onDialog = dialogEl !== null;\n if (onDialog) {\n this.host.classList.add(\"on-dialog\");\n if (dialogEl.getAttribute(\"data-overflow\") === \"false\") {\n const menuTop = this.host.getBoundingClientRect().top;\n const menuHeight = this.host.getBoundingClientRect().height;\n const dialogHeight = dialogEl.getBoundingClientRect().bottom;\n if (menuTop + menuHeight > dialogHeight) {\n adjust = true;\n }\n }\n if (adjust === false) {\n this.host.classList.add(\"on-dialog-fix-translate\");\n }\n }\n\n if (adjust) {\n this.popperInstance = createPopper(this.anchorEl, this.host, {\n placement: \"top\",\n });\n } else {\n this.popperInstance = createPopper(this.anchorEl, this.host, {\n placement: \"bottom\",\n modifiers: [\n {\n name: \"offset\",\n options: {\n offset: [0, 7],\n },\n },\n {\n name: \"flip\",\n options: {\n fallbackPlacements: [\"top\"],\n rootBoundary: \"viewport\",\n },\n },\n ],\n });\n }\n } else if (this.open) {\n this.popperInstance.update();\n }\n\n if (this.open && !!this.options.length) {\n this.setMenuScrollbar();\n }\n }\n\n /**\n * @internal If menu is opened with the mouse, emit menuStateChange custom event.\n */\n @Method()\n async handleClickOpen(): Promise<void> {\n if (!this.preventClickOpen) {\n this.menuStateChange.emit({ open: !this.open });\n this.keyboardNav = false;\n }\n this.preventClickOpen = false;\n }\n\n /**\n * Used alongside activationType\n * If menu is opened via keyboard navigation (i.e. Enter, ArrowUp or ArrowDown), emit optionSelect custom event.\n * @param {KeyboardEvent} event - keyboard event\n */\n @Method()\n async handleKeyboardOpen(event: KeyboardEvent): Promise<void> {\n this.keyboardNav = false;\n\n if (this.activationType === \"automatic\") {\n this.autoSetInputValueKeyboardOpen(event);\n } else {\n this.manSetInputValueKeyboardOpen(event);\n }\n }\n\n /**\n * @internal Used to highlight the first option in the menu.\n */\n @Method()\n async handleSetFirstOption(): Promise<void> {\n this.setHighlightedOption(0);\n }\n\n private handleClearListener = (): void => {\n this.optionHighlighted = \"\";\n };\n\n private handleSubmitSearch = (): void => {\n const highlightedOptionIndex = this.options.findIndex(\n (option) => option.value === this.optionHighlighted\n );\n\n this.setInputValue(highlightedOptionIndex);\n };\n\n private handleMenuChange = (open: boolean, focusInput?: boolean): void => {\n this.menuStateChange.emit({ open, focusInput });\n\n if (!open && focusInput !== false) {\n this.inputEl.focus();\n this.preventClickOpen = false;\n }\n };\n\n private setNextOptionValue = (selectedOptionIndex: number): void => {\n if (this.ungroupedOptions[selectedOptionIndex + 1]) {\n this.menuOptionSelect.emit({\n value: this.ungroupedOptions[selectedOptionIndex + 1].value,\n optionId: this.getOptionId(\n this.ungroupedOptions[selectedOptionIndex + 1].value\n ),\n });\n } else {\n this.menuOptionSelect.emit({\n value: this.ungroupedOptions[0].value,\n optionId: this.getOptionId(this.ungroupedOptions[0].value),\n });\n }\n };\n\n private setPreviousOptionValue = (selectedOptionIndex: number): void => {\n if (this.ungroupedOptions[selectedOptionIndex - 1]) {\n this.menuOptionSelect.emit({\n value: this.ungroupedOptions[selectedOptionIndex - 1].value,\n optionId: this.getOptionId(\n this.ungroupedOptions[selectedOptionIndex - 1].value\n ),\n });\n } else {\n this.menuOptionSelect.emit({\n value: this.ungroupedOptions[this.ungroupedOptions.length - 1].value,\n optionId: this.getOptionId(\n this.ungroupedOptions[this.ungroupedOptions.length - 1].value\n ),\n });\n }\n };\n\n private getParentEl = (parent: HTMLElement) => {\n if (parent.tagName === \"IC-SEARCH-BAR\") {\n this.isSearchBar = true;\n } else if (\n parent.tagName === \"IC-SELECT\" &&\n parent.getAttribute(\"searchable\") !== null &&\n parent.getAttribute(\"searchable\") !== undefined\n ) {\n this.isSearchableSelect = true;\n }\n };\n\n private arrowBehaviour = (event: KeyboardEvent): void => {\n event.preventDefault();\n this.handleMenuChange(true);\n };\n\n private setMenuOptions = () =>\n this.isSearchBar ? this.options : this.ungroupedOptions;\n\n private setHighlightedOption = (highlightedIndex: number): void => {\n const menuOptions = this.setMenuOptions();\n\n menuOptions[highlightedIndex] &&\n !menuOptions[highlightedIndex].timedOut &&\n (this.optionHighlighted =\n menuOptions[highlightedIndex].value || undefined);\n };\n\n private autoSetInputValueKeyboardOpen = (event: KeyboardEvent) => {\n const selectedOptionIndex = this.ungroupedOptions.findIndex(\n (option) => option.value === this.value\n );\n\n this.keyboardNav = false;\n\n switch (event.key) {\n case \"ArrowDown\":\n this.keyboardNav = true;\n this.arrowBehaviour(event);\n this.setNextOptionValue(selectedOptionIndex);\n break;\n case \"ArrowUp\":\n this.keyboardNav = true;\n this.arrowBehaviour(event);\n this.setPreviousOptionValue(selectedOptionIndex);\n break;\n case \" \":\n case \"Enter\":\n if ((event.target as HTMLElement).id !== \"clear-button\") {\n this.handleMenuChange(true);\n }\n break;\n }\n };\n\n private manSetInputValueKeyboardOpen = (event: KeyboardEvent) => {\n const menuOptions = this.setMenuOptions();\n\n this.keyboardNav = false;\n\n const highlightedOptionIndex = menuOptions.findIndex(\n (option) => option.value === this.optionHighlighted\n );\n\n const getOptionId = (index: number): string =>\n Array.from(this.host.querySelectorAll(\"li\"))[index]?.id;\n\n switch (event.key) {\n case \"ArrowDown\":\n this.keyboardNav = true;\n this.arrowBehaviour(event);\n if (highlightedOptionIndex < menuOptions.length - 1) {\n this.setHighlightedOption(highlightedOptionIndex + 1);\n this.menuOptionId.emit({\n optionId: getOptionId(highlightedOptionIndex + 1),\n });\n } else {\n this.setHighlightedOption(0);\n this.menuOptionId.emit({\n optionId: getOptionId(0),\n });\n }\n this.preventIncorrectTabOrder = false;\n this.focusFromSearchKeypress = false;\n break;\n case \"ArrowUp\":\n this.keyboardNav = true;\n this.arrowBehaviour(event);\n if (\n highlightedOptionIndex <= 0 ||\n highlightedOptionIndex > menuOptions.length + 1\n ) {\n this.setHighlightedOption(menuOptions.length - 1);\n this.menuOptionId.emit({\n optionId: getOptionId(menuOptions.length - 1),\n });\n } else {\n this.setHighlightedOption(highlightedOptionIndex - 1);\n this.menuOptionId.emit({\n optionId: getOptionId(highlightedOptionIndex - 1),\n });\n }\n this.preventIncorrectTabOrder = false;\n this.focusFromSearchKeypress = false;\n break;\n case \"Home\":\n this.keyboardNav = true;\n event.preventDefault();\n this.arrowBehaviour(event);\n this.setHighlightedOption(0);\n this.menuOptionId.emit({\n optionId: getOptionId(0),\n });\n break;\n case \"End\":\n this.keyboardNav = true;\n event.preventDefault();\n this.arrowBehaviour(event);\n this.setHighlightedOption(menuOptions.length - 1);\n this.menuOptionId.emit({\n optionId: getOptionId(menuOptions.length - 1),\n });\n break;\n case \"Enter\":\n event.preventDefault();\n this.setInputValue(highlightedOptionIndex);\n this.value = menuOptions[highlightedOptionIndex]?.value;\n break;\n case \"Escape\":\n if (this.open) {\n event.stopImmediatePropagation();\n }\n this.handleMenuChange(false);\n this.menuOptionId.emit({ optionId: undefined });\n break;\n case \"Shift\":\n case \"Tab\":\n if (this.isSearchBar) {\n this.keyboardNav = true;\n }\n this.preventIncorrectTabOrder = true;\n break;\n case \"Backspace\":\n if (this.isSearchBar) {\n (this.parentEl as HTMLIcSearchBarElement).setFocus();\n if (this.searchMode === \"navigation\") this.setHighlightedOption(0);\n } else if (this.isSearchableSelect) {\n (this.parentEl as HTMLIcSelectElement).setFocus();\n }\n this.focusFromSearchKeypress = true;\n break;\n default:\n if (event.key !== \"Tab\") {\n if (this.isSearchBar) {\n (this.parentEl as HTMLIcSearchBarElement).setFocus();\n if (this.searchMode === \"navigation\") this.setHighlightedOption(0);\n } else if (this.isSearchableSelect) {\n (this.parentEl as HTMLIcSelectElement).setFocus();\n }\n this.focusFromSearchKeypress = true;\n }\n break;\n }\n };\n\n private setInputValue = (highlightedOptionIndex: number) => {\n const menuOptions = this.setMenuOptions();\n\n if (menuOptions[highlightedOptionIndex]) {\n this.menuOptionSelect.emit({\n value: menuOptions[highlightedOptionIndex]?.value,\n });\n this.optionHighlighted = undefined;\n this.menuOptionId.emit({ optionId: undefined });\n }\n if (!this.hasTimedOut) this.handleMenuChange(false);\n else (this.parentEl as HTMLIcSearchBarElement).setFocus();\n };\n\n private handleOptionClick = (event: Event): void => {\n const { value, label } = (event.target as HTMLLIElement).dataset;\n this.menuOptionSelect.emit({ value, label });\n this.handleMenuChange(false);\n };\n\n private handleRetry = (): void => {\n this.retryButtonClicked.emit({ value: this.value });\n };\n\n private handleRetryKeyDown = (ev: KeyboardEvent): void => {\n if (ev.key === \"Enter\" || ev.key === \" \") {\n ev.preventDefault();\n this.retryButtonClicked.emit({ value: this.value, keyPressed: ev.key });\n }\n };\n\n private handleBlur = (event: FocusEvent): void => {\n if (event.relatedTarget !== this.inputEl) {\n if (!this.menu.contains(event.relatedTarget as HTMLElement)) {\n this.handleMenuChange(false, this.hasPreviouslyBlurred);\n }\n } else {\n this.handleMenuChange(false);\n this.preventClickOpen = true;\n }\n if (!this.isSearchBar) this.hasPreviouslyBlurred = !!event.relatedTarget;\n };\n\n private handleMouseDown = (event: Event): void => {\n event.preventDefault();\n };\n\n private handleMenuKeyDown = (event: KeyboardEvent) => {\n if (this.activationType === \"automatic\") {\n this.autoSetValueOnMenuKeyDown(event);\n } else if (this.activationType === \"manual\" && this.isSearchableSelect) {\n this.manSetInputValueKeyboardOpen(event);\n }\n };\n\n private emitMenuKeyPress = (isNavKey: boolean, key: string) => {\n this.menuKeyPress.emit({ isNavKey: isNavKey, key: key });\n };\n\n private autoSetValueOnMenuKeyDown = (event: KeyboardEvent): void => {\n event.cancelBubble = true;\n const selectedOptionIndex = this.ungroupedOptions.findIndex(\n (option) => option.value === this.value\n );\n\n const isSearchableSelect = this.inputEl.tagName === \"INPUT\";\n\n this.keyboardNav = false;\n\n switch (event.key) {\n case \" \":\n event.preventDefault();\n break;\n case \"ArrowUp\":\n if (!this.hasTimedOut) {\n event.preventDefault();\n this.setPreviousOptionValue(selectedOptionIndex);\n this.keyboardNav = true;\n }\n break;\n case \"ArrowDown\":\n if (!this.hasTimedOut) {\n event.preventDefault();\n this.setNextOptionValue(selectedOptionIndex);\n this.keyboardNav = true;\n }\n break;\n case \"Home\":\n this.menuOptionSelect.emit({\n value: this.ungroupedOptions[0].value,\n });\n this.keyboardNav = true;\n break;\n case \"End\":\n this.menuOptionSelect.emit({\n value: this.ungroupedOptions[this.ungroupedOptions.length - 1].value,\n });\n this.keyboardNav = true;\n break;\n case \"Enter\":\n !this.hasTimedOut && this.handleMenuChange(false);\n break;\n case \"Escape\":\n this.handleMenuChange(false);\n break;\n case \"Backspace\":\n if (isSearchableSelect) {\n this.inputEl.focus();\n }\n break;\n case \"Shift\":\n break;\n default:\n if (isSearchableSelect && event.key !== \"Tab\" && !this.hasTimedOut) {\n this.inputEl.focus();\n }\n if (event.key.length === 1) {\n this.keyboardNav = true;\n }\n break;\n }\n this.emitMenuKeyPress(this.keyboardNav, event.key);\n };\n\n private handleMenuKeyUp = (event: KeyboardEvent): void => {\n if (event.key === \"Tab\" && event.shiftKey) {\n this.preventClickOpen = false;\n }\n };\n\n private getOptionId = (value: string): string => {\n return `${this.menuId}-${value}`;\n };\n\n private getOptionAriaLabel = (\n option: IcMenuOption,\n parentOption: IcMenuOption\n ): string => {\n let ariaLabel = option.label;\n\n if (option.description) {\n ariaLabel = `${ariaLabel}, ${option.description}`;\n }\n\n if (parentOption) {\n return `${ariaLabel}, ${parentOption.label} group`;\n } else {\n return ariaLabel;\n }\n };\n\n private getSortedOptions = (options: IcMenuOption[]): IcMenuOption[] => {\n let sorted: IcMenuOption[] = [];\n if (options.sort) {\n sorted = options.sort((optionA, optionB) =>\n optionA.recommended && !optionB.recommended ? -1 : 0\n );\n }\n return sorted;\n };\n\n private isManualMode = this.activationType === \"manual\";\n\n private scrollToSelected = (menu: HTMLUListElement) => {\n const selectedOption = menu.querySelector(\n \".option[aria-selected]\"\n ) as HTMLElement;\n\n if (selectedOption) {\n const elTop = selectedOption.offsetTop + selectedOption.offsetHeight;\n if (\n elTop > menu.scrollTop + menu.offsetHeight ||\n elTop < menu.scrollTop + menu.offsetHeight\n ) {\n menu.scrollTop = selectedOption.offsetTop;\n }\n selectedOption.focus();\n }\n };\n\n private loadUngroupedOptions = () => {\n if (this.options.length > 0 && this.options.map) {\n this.options.map((option) => {\n if (option.children) {\n option.children.map(\n (option) => !option.disabled && this.ungroupedOptions.push(option)\n );\n } else if (!option.disabled) {\n this.ungroupedOptions.push(option);\n }\n });\n }\n this.ungroupedOptions = this.getSortedOptions(this.ungroupedOptions);\n this.ungroupedOptionsSet.emit({ options: this.ungroupedOptions });\n };\n\n private setMenuScrollbar = () => {\n let optionsHeight = 0;\n this.host\n .querySelectorAll(\".option\")\n .forEach((option) => (optionsHeight += option.clientHeight));\n\n if (optionsHeight >= 320) {\n this.menu.classList.add(\"menu-scroll\");\n }\n };\n\n private handleTimeoutBlur = (ev: FocusEvent) => {\n this.timeoutBlur.emit({ ev });\n };\n\n private optionContent = (option: IcMenuOption) => {\n return (\n <Fragment>\n {option.loading && <ic-loading-indicator size=\"icon\" />}\n <div class=\"option-text-container\">\n <ic-typography variant=\"body\" aria-hidden=\"true\">\n <p>{option.label}</p>\n </ic-typography>\n {option.description && (\n <ic-typography\n id={`${this.getOptionId(option?.value)}-description`}\n class=\"option-description\"\n variant=\"caption\"\n aria-hidden=\"true\"\n >\n <p>{option.description}</p>\n </ic-typography>\n )}\n </div>\n {!!option.value &&\n !!this.value &&\n option?.value.toLowerCase() === this.value?.toLowerCase() &&\n this.parentEl.tagName !== \"IC-SEARCH-BAR\" && (\n <span class=\"check-icon\" innerHTML={Check} />\n )}\n </Fragment>\n );\n };\n\n private displayOption = (\n option: IcMenuOption,\n index?: number,\n parentOption?: IcMenuOption\n ): HTMLLIElement => {\n const {\n open,\n value,\n keyboardNav,\n isManualMode,\n initialOptionsListRender,\n optionHighlighted,\n options,\n } = this;\n\n return (\n <li\n id={this.getOptionId(option.value)}\n class={{\n option: true,\n \"focused-option\": isManualMode\n ? (keyboardNav || initialOptionsListRender) &&\n option.value === optionHighlighted\n : keyboardNav && option.value === value,\n \"last-recommended-option\":\n option.recommended &&\n options[index + 1] &&\n !options[index + 1].recommended,\n \"disabled-option\": option.disabled,\n \"loading-option\": option.loading,\n timeout: option.timedOut,\n }}\n role=\"option\"\n tabindex={\n open &&\n (option.value === value || option.value === optionHighlighted) &&\n keyboardNav\n ? \"0\"\n : \"-1\"\n }\n aria-label={this.getOptionAriaLabel(option, parentOption)}\n aria-selected={option.value === value}\n aria-disabled={option.disabled ? \"true\" : \"false\"}\n onClick={!option.timedOut && !option.loading && this.handleOptionClick}\n onBlur={this.handleBlur}\n onMouseDown={this.handleMouseDown}\n data-value={option.value}\n data-label={option.label}\n >\n {option.timedOut ? (\n <Fragment>\n <div class=\"loading-error-info\">\n <svg\n class=\"error-icon-svg\"\n aria-labelledby=\"error-title\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"#000000\"\n >\n <title id=\"error-title\">Error</title>\n <path d=\"M0 0h24v24H0z\" fill=\"none\" />\n <path d=\"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z\" />\n </svg>\n <ic-typography variant=\"label\">{option.label}</ic-typography>\n </div>\n <ic-button\n size=\"small\"\n variant=\"tertiary\"\n onClick={this.handleRetry}\n onKeyDown={this.handleRetryKeyDown}\n onBlur={this.handleTimeoutBlur}\n id=\"retry-button\"\n >\n Retry\n </ic-button>\n </Fragment>\n ) : (\n this.optionContent(option)\n )}\n </li>\n );\n };\n\n render() {\n const {\n inputLabel,\n options,\n menuId,\n value,\n fullWidth,\n hasTimedOut,\n isLoading,\n small,\n open,\n inputEl,\n keyboardNav,\n } = this;\n\n return (\n <Host\n class={{\n \"full-width\": fullWidth,\n \"no-focus\": inputEl?.tagName === \"INPUT\" || hasTimedOut || isLoading,\n small: small,\n open: open,\n }}\n >\n {options.length !== 0 && (\n <ul\n id={menuId}\n class=\"menu\"\n role=\"listbox\"\n aria-label={inputLabel}\n aria-activedescendant={\n value != null && value !== \"\" ? this.getOptionId(value) : \"\"\n }\n tabindex={\n open && !keyboardNav && inputEl?.tagName !== \"INPUT\" ? \"0\" : \"-1\"\n }\n ref={(el) => (this.menu = el)}\n onKeyDown={this.handleMenuKeyDown}\n onKeyUp={this.handleMenuKeyUp}\n onBlur={this.handleBlur}\n >\n {this.getSortedOptions(options).map((option, index) => {\n if (option.children) {\n if (option.children.length > 0) {\n return (\n <div>\n <ic-typography\n class=\"option-group-title\"\n role=\"presentation\"\n variant=\"subtitle-small\"\n >\n <p>{option.label}</p>\n </ic-typography>\n {option.children.map((childOption) =>\n this.displayOption(childOption, index, option)\n )}\n </div>\n );\n } else {\n return null;\n }\n } else {\n return this.displayOption(option, index);\n }\n })}\n </ul>\n )}\n </Host>\n );\n }\n}\n"],"mappings":"qOAAA,MAAMA,EAA+B,knG,MCgBxBC,EAAuB,M,mCAMT,M,cAKG,M,eAKC,M,eAKA,M,cAKD,M,WAKH,M,sBAKW,M,sBAKmB,E,CAEvDC,SACE,MAAMC,MACJA,EAAKC,iBACLA,EAAgBC,SAChBA,EAAQC,SACRA,EAAQC,UACRA,EAASC,UACTA,EAASC,KACTA,EAAIC,iBACJA,GACEC,KACJ,MAAMC,EACJD,KAAKP,mBAAqB,KAAOO,KAAKN,WAAaM,KAAKL,SACpD,KACA,MACN,OACEO,EAACC,EAAI,CACHC,MAAO,CACL,CAAC,SAAUZ,EACXC,CAACA,GAAmBQ,EACpB,CAAC,YAAaP,EACd,CAAC,YAAaC,EACd,CAAC,aAAcC,EACf,CAAC,aAAcC,EACf,CAAC,QAASC,IAGZI,EAAA,OACEE,MAAO,CACL,kBAAmB,KACnBN,KAAMA,IAGPO,EAAWL,KAAKM,KAAM,cACrBJ,EAAA,OACEE,MAAO,CACL,CAAC,kBAAmB,OAGtBF,EAAA,QAAMK,KAAK,eAGfL,EAAA,aAECH,GACCN,IAAqBe,EAAoBC,SACvCP,EAAA,QACEE,MAAO,CACL,CAAC,kBAAmB,MAEtBM,UAAWC,K,uCC7G3B,MAAMC,EAAsB,8E,MCMfC,EAAc,M,uCAII,M,cAKA,K,CAE7BtB,SACE,OACEW,EAACC,EAAI,KACHD,EAAA,OACEE,MAAO,CACL,CAAC,uBAAwB,KACzB,CAAC,YAAaJ,KAAKN,SACnB,CAAC,YAAaM,KAAKL,WAGrBO,EAAA,c,aC3BV,MAAMY,EAAY,ikO,MCmCLC,EAAI,M,6ZACPf,KAAAgB,YAAuB,KACvBhB,KAAAiB,qBAAgC,MAChCjB,KAAAkB,YAAuB,MACvBlB,KAAAmB,UAAqB,MACrBnB,KAAAoB,YAAuB,MACvBpB,KAAAqB,mBAA8B,MAI9BrB,KAAAsB,iBAA4B,MAC5BtB,KAAAuB,iBAAmC,GAoTnCvB,KAAAwB,oBAAsB,KAC5BxB,KAAKyB,kBAAoB,EAAE,EAGrBzB,KAAA0B,mBAAqB,KAC3B,MAAMC,EAAyB3B,KAAK4B,QAAQC,WACzCC,GAAWA,EAAOC,QAAU/B,KAAKyB,oBAGpCzB,KAAKgC,cAAcL,EAAuB,EAGpC3B,KAAAiC,iBAAmB,CAACC,EAAeC,KACzCnC,KAAKoC,gBAAgBC,KAAK,CAAEH,OAAMC,eAElC,IAAKD,GAAQC,IAAe,MAAO,CACjCnC,KAAKsC,QAAQC,QACbvC,KAAKsB,iBAAmB,K,GAIpBtB,KAAAwC,mBAAsBC,IAC5B,GAAIzC,KAAKuB,iBAAiBkB,EAAsB,GAAI,CAClDzC,KAAK0C,iBAAiBL,KAAK,CACzBN,MAAO/B,KAAKuB,iBAAiBkB,EAAsB,GAAGV,MACtDY,SAAU3C,KAAK4C,YACb5C,KAAKuB,iBAAiBkB,EAAsB,GAAGV,Q,KAG9C,CACL/B,KAAK0C,iBAAiBL,KAAK,CACzBN,MAAO/B,KAAKuB,iBAAiB,GAAGQ,MAChCY,SAAU3C,KAAK4C,YAAY5C,KAAKuB,iBAAiB,GAAGQ,Q,GAKlD/B,KAAA6C,uBAA0BJ,IAChC,GAAIzC,KAAKuB,iBAAiBkB,EAAsB,GAAI,CAClDzC,KAAK0C,iBAAiBL,KAAK,CACzBN,MAAO/B,KAAKuB,iBAAiBkB,EAAsB,GAAGV,MACtDY,SAAU3C,KAAK4C,YACb5C,KAAKuB,iBAAiBkB,EAAsB,GAAGV,Q,KAG9C,CACL/B,KAAK0C,iBAAiBL,KAAK,CACzBN,MAAO/B,KAAKuB,iBAAiBvB,KAAKuB,iBAAiBuB,OAAS,GAAGf,MAC/DY,SAAU3C,KAAK4C,YACb5C,KAAKuB,iBAAiBvB,KAAKuB,iBAAiBuB,OAAS,GAAGf,Q,GAMxD/B,KAAA+C,YAAeC,IACrB,GAAIA,EAAOC,UAAY,gBAAiB,CACtCjD,KAAKoB,YAAc,I,MACd,GACL4B,EAAOC,UAAY,aACnBD,EAAOE,aAAa,gBAAkB,MACtCF,EAAOE,aAAa,gBAAkBC,UACtC,CACAnD,KAAKqB,mBAAqB,I,GAItBrB,KAAAoD,eAAkBC,IACxBA,EAAMC,iBACNtD,KAAKiC,iBAAiB,KAAK,EAGrBjC,KAAAuD,eAAiB,IACvBvD,KAAKoB,YAAcpB,KAAK4B,QAAU5B,KAAKuB,iBAEjCvB,KAAAwD,qBAAwBC,IAC9B,MAAMC,EAAc1D,KAAKuD,iBAEzBG,EAAYD,KACTC,EAAYD,GAAkBE,WAC9B3D,KAAKyB,kBACJiC,EAAYD,GAAkB1B,OAASoB,UAAU,EAG/CnD,KAAA4D,8BAAiCP,IACvC,MAAMZ,EAAsBzC,KAAKuB,iBAAiBM,WAC/CC,GAAWA,EAAOC,QAAU/B,KAAK+B,QAGpC/B,KAAK6D,YAAc,MAEnB,OAAQR,EAAMS,KACZ,IAAK,YACH9D,KAAK6D,YAAc,KACnB7D,KAAKoD,eAAeC,GACpBrD,KAAKwC,mBAAmBC,GACxB,MACF,IAAK,UACHzC,KAAK6D,YAAc,KACnB7D,KAAKoD,eAAeC,GACpBrD,KAAK6C,uBAAuBJ,GAC5B,MACF,IAAK,IACL,IAAK,QACH,GAAKY,EAAMU,OAAuBC,KAAO,eAAgB,CACvDhE,KAAKiC,iBAAiB,K,CAExB,M,EAIEjC,KAAAiE,6BAAgCZ,I,MACtC,MAAMK,EAAc1D,KAAKuD,iBAEzBvD,KAAK6D,YAAc,MAEnB,MAAMlC,EAAyB+B,EAAY7B,WACxCC,GAAWA,EAAOC,QAAU/B,KAAKyB,oBAGpC,MAAMmB,EAAesB,IAAa,IAAAC,EAChC,OAAAA,EAAAC,MAAMC,KAAKrE,KAAKM,KAAKgE,iBAAiB,OAAOJ,MAAM,MAAAC,SAAA,SAAAA,EAAEH,EAAE,EAEzD,OAAQX,EAAMS,KACZ,IAAK,YACH9D,KAAK6D,YAAc,KACnB7D,KAAKoD,eAAeC,GACpB,GAAI1B,EAAyB+B,EAAYZ,OAAS,EAAG,CACnD9C,KAAKwD,qBAAqB7B,EAAyB,GACnD3B,KAAKuE,aAAalC,KAAK,CACrBM,SAAUC,EAAYjB,EAAyB,I,KAE5C,CACL3B,KAAKwD,qBAAqB,GAC1BxD,KAAKuE,aAAalC,KAAK,CACrBM,SAAUC,EAAY,I,CAG1B5C,KAAKwE,yBAA2B,MAChCxE,KAAKyE,wBAA0B,MAC/B,MACF,IAAK,UACHzE,KAAK6D,YAAc,KACnB7D,KAAKoD,eAAeC,GACpB,GACE1B,GAA0B,GAC1BA,EAAyB+B,EAAYZ,OAAS,EAC9C,CACA9C,KAAKwD,qBAAqBE,EAAYZ,OAAS,GAC/C9C,KAAKuE,aAAalC,KAAK,CACrBM,SAAUC,EAAYc,EAAYZ,OAAS,I,KAExC,CACL9C,KAAKwD,qBAAqB7B,EAAyB,GACnD3B,KAAKuE,aAAalC,KAAK,CACrBM,SAAUC,EAAYjB,EAAyB,I,CAGnD3B,KAAKwE,yBAA2B,MAChCxE,KAAKyE,wBAA0B,MAC/B,MACF,IAAK,OACHzE,KAAK6D,YAAc,KACnBR,EAAMC,iBACNtD,KAAKoD,eAAeC,GACpBrD,KAAKwD,qBAAqB,GAC1BxD,KAAKuE,aAAalC,KAAK,CACrBM,SAAUC,EAAY,KAExB,MACF,IAAK,MACH5C,KAAK6D,YAAc,KACnBR,EAAMC,iBACNtD,KAAKoD,eAAeC,GACpBrD,KAAKwD,qBAAqBE,EAAYZ,OAAS,GAC/C9C,KAAKuE,aAAalC,KAAK,CACrBM,SAAUC,EAAYc,EAAYZ,OAAS,KAE7C,MACF,IAAK,QACHO,EAAMC,iBACNtD,KAAKgC,cAAcL,GACnB3B,KAAK+B,OAAQoC,EAAAT,EAAY/B,MAAuB,MAAAwC,SAAA,SAAAA,EAAEpC,MAClD,MACF,IAAK,SACH,GAAI/B,KAAKkC,KAAM,CACbmB,EAAMqB,0B,CAER1E,KAAKiC,iBAAiB,OACtBjC,KAAKuE,aAAalC,KAAK,CAAEM,SAAUQ,YACnC,MACF,IAAK,QACL,IAAK,MACH,GAAInD,KAAKoB,YAAa,CACpBpB,KAAK6D,YAAc,I,CAErB7D,KAAKwE,yBAA2B,KAChC,MACF,IAAK,YACH,GAAIxE,KAAKoB,YAAa,CACnBpB,KAAK2E,SAAoCC,WAC1C,GAAI5E,KAAK6E,aAAe,aAAc7E,KAAKwD,qBAAqB,E,MAC3D,GAAIxD,KAAKqB,mBAAoB,CACjCrB,KAAK2E,SAAiCC,U,CAEzC5E,KAAKyE,wBAA0B,KAC/B,MACF,QACE,GAAIpB,EAAMS,MAAQ,MAAO,CACvB,GAAI9D,KAAKoB,YAAa,CACnBpB,KAAK2E,SAAoCC,WAC1C,GAAI5E,KAAK6E,aAAe,aAAc7E,KAAKwD,qBAAqB,E,MAC3D,GAAIxD,KAAKqB,mBAAoB,CACjCrB,KAAK2E,SAAiCC,U,CAEzC5E,KAAKyE,wBAA0B,I,CAEjC,M,EAIEzE,KAAAgC,cAAiBL,I,MACvB,MAAM+B,EAAc1D,KAAKuD,iBAEzB,GAAIG,EAAY/B,GAAyB,CACvC3B,KAAK0C,iBAAiBL,KAAK,CACzBN,OAAOoC,EAAAT,EAAY/B,MAAuB,MAAAwC,SAAA,SAAAA,EAAEpC,QAE9C/B,KAAKyB,kBAAoB0B,UACzBnD,KAAKuE,aAAalC,KAAK,CAAEM,SAAUQ,W,CAErC,IAAKnD,KAAKkB,YAAalB,KAAKiC,iBAAiB,YACvCjC,KAAK2E,SAAoCC,UAAU,EAGnD5E,KAAA8E,kBAAqBzB,IAC3B,MAAMtB,MAAEA,EAAKgD,MAAEA,GAAW1B,EAAMU,OAAyBiB,QACzDhF,KAAK0C,iBAAiBL,KAAK,CAAEN,QAAOgD,UACpC/E,KAAKiC,iBAAiB,MAAM,EAGtBjC,KAAAiF,YAAc,KACpBjF,KAAKkF,mBAAmB7C,KAAK,CAAEN,MAAO/B,KAAK+B,OAAQ,EAG7C/B,KAAAmF,mBAAsBC,IAC5B,GAAIA,EAAGtB,MAAQ,SAAWsB,EAAGtB,MAAQ,IAAK,CACxCsB,EAAG9B,iBACHtD,KAAKkF,mBAAmB7C,KAAK,CAAEN,MAAO/B,KAAK+B,MAAOsD,WAAYD,EAAGtB,K,GAI7D9D,KAAAsF,WAAcjC,IACpB,GAAIA,EAAMkC,gBAAkBvF,KAAKsC,QAAS,CACxC,IAAKtC,KAAKwF,KAAKC,SAASpC,EAAMkC,eAA+B,CAC3DvF,KAAKiC,iBAAiB,MAAOjC,KAAKiB,qB,MAE/B,CACLjB,KAAKiC,iBAAiB,OACtBjC,KAAKsB,iBAAmB,I,CAE1B,IAAKtB,KAAKoB,YAAapB,KAAKiB,uBAAyBoC,EAAMkC,aAAa,EAGlEvF,KAAA0F,gBAAmBrC,IACzBA,EAAMC,gBAAgB,EAGhBtD,KAAA2F,kBAAqBtC,IAC3B,GAAIrD,KAAK4F,iBAAmB,YAAa,CACvC5F,KAAK6F,0BAA0BxC,E,MAC1B,GAAIrD,KAAK4F,iBAAmB,UAAY5F,KAAKqB,mBAAoB,CACtErB,KAAKiE,6BAA6BZ,E,GAI9BrD,KAAA8F,iBAAmB,CAACC,EAAmBjC,KAC7C9D,KAAKgG,aAAa3D,KAAK,CAAE0D,SAAUA,EAAUjC,IAAKA,GAAM,EAGlD9D,KAAA6F,0BAA6BxC,IACnCA,EAAM4C,aAAe,KACrB,MAAMxD,EAAsBzC,KAAKuB,iBAAiBM,WAC/CC,GAAWA,EAAOC,QAAU/B,KAAK+B,QAGpC,MAAMV,EAAqBrB,KAAKsC,QAAQW,UAAY,QAEpDjD,KAAK6D,YAAc,MAEnB,OAAQR,EAAMS,KACZ,IAAK,IACHT,EAAMC,iBACN,MACF,IAAK,UACH,IAAKtD,KAAKkB,YAAa,CACrBmC,EAAMC,iBACNtD,KAAK6C,uBAAuBJ,GAC5BzC,KAAK6D,YAAc,I,CAErB,MACF,IAAK,YACH,IAAK7D,KAAKkB,YAAa,CACrBmC,EAAMC,iBACNtD,KAAKwC,mBAAmBC,GACxBzC,KAAK6D,YAAc,I,CAErB,MACF,IAAK,OACH7D,KAAK0C,iBAAiBL,KAAK,CACzBN,MAAO/B,KAAKuB,iBAAiB,GAAGQ,QAElC/B,KAAK6D,YAAc,KACnB,MACF,IAAK,MACH7D,KAAK0C,iBAAiBL,KAAK,CACzBN,MAAO/B,KAAKuB,iBAAiBvB,KAAKuB,iBAAiBuB,OAAS,GAAGf,QAEjE/B,KAAK6D,YAAc,KACnB,MACF,IAAK,SACF7D,KAAKkB,aAAelB,KAAKiC,iBAAiB,OAC3C,MACF,IAAK,SACHjC,KAAKiC,iBAAiB,OACtB,MACF,IAAK,YACH,GAAIZ,EAAoB,CACtBrB,KAAKsC,QAAQC,O,CAEf,MACF,IAAK,QACH,MACF,QACE,GAAIlB,GAAsBgC,EAAMS,MAAQ,QAAU9D,KAAKkB,YAAa,CAClElB,KAAKsC,QAAQC,O,CAEf,GAAIc,EAAMS,IAAIhB,SAAW,EAAG,CAC1B9C,KAAK6D,YAAc,I,CAErB,MAEJ7D,KAAK8F,iBAAiB9F,KAAK6D,YAAaR,EAAMS,IAAI,EAG5C9D,KAAAkG,gBAAmB7C,IACzB,GAAIA,EAAMS,MAAQ,OAAST,EAAM8C,SAAU,CACzCnG,KAAKsB,iBAAmB,K,GAIpBtB,KAAA4C,YAAeb,GACd,GAAG/B,KAAKoG,UAAUrE,IAGnB/B,KAAAqG,mBAAqB,CAC3BvE,EACAwE,KAEA,IAAIC,EAAYzE,EAAOiD,MAEvB,GAAIjD,EAAO0E,YAAa,CACtBD,EAAY,GAAGA,MAAczE,EAAO0E,a,CAGtC,GAAIF,EAAc,CAChB,MAAO,GAAGC,MAAcD,EAAavB,a,KAChC,CACL,OAAOwB,C,GAIHvG,KAAAyG,iBAAoB7E,IAC1B,IAAI8E,EAAyB,GAC7B,GAAI9E,EAAQ+E,KAAM,CAChBD,EAAS9E,EAAQ+E,MAAK,CAACC,EAASC,IAC9BD,EAAQE,cAAgBD,EAAQC,aAAe,EAAI,G,CAGvD,OAAOJ,CAAM,EAGP1G,KAAA+G,aAAe/G,KAAK4F,iBAAmB,SAEvC5F,KAAAgH,iBAAoBxB,IAC1B,MAAMyB,EAAiBzB,EAAK0B,cAC1B,0BAGF,GAAID,EAAgB,CAClB,MAAME,EAAQF,EAAeG,UAAYH,EAAeI,aACxD,GACEF,EAAQ3B,EAAK8B,UAAY9B,EAAK6B,cAC9BF,EAAQ3B,EAAK8B,UAAY9B,EAAK6B,aAC9B,CACA7B,EAAK8B,UAAYL,EAAeG,S,CAElCH,EAAe1E,O,GAIXvC,KAAAuH,qBAAuB,KAC7B,GAAIvH,KAAK4B,QAAQkB,OAAS,GAAK9C,KAAK4B,QAAQ4F,IAAK,CAC/CxH,KAAK4B,QAAQ4F,KAAK1F,IAChB,GAAIA,EAAO2F,SAAU,CACnB3F,EAAO2F,SAASD,KACb1F,IAAYA,EAAOpC,UAAYM,KAAKuB,iBAAiBmG,KAAK5F,I,MAExD,IAAKA,EAAOpC,SAAU,CAC3BM,KAAKuB,iBAAiBmG,KAAK5F,E,KAIjC9B,KAAKuB,iBAAmBvB,KAAKyG,iBAAiBzG,KAAKuB,kBACnDvB,KAAK2H,oBAAoBtF,KAAK,CAAET,QAAS5B,KAAKuB,kBAAmB,EAG3DvB,KAAA4H,iBAAmB,KACzB,IAAIC,EAAgB,EACpB7H,KAAKM,KACFgE,iBAAiB,WACjBwD,SAAShG,GAAY+F,GAAiB/F,EAAOiG,eAEhD,GAAIF,GAAiB,IAAK,CACxB7H,KAAKwF,KAAKwC,UAAUC,IAAI,c,GAIpBjI,KAAAkI,kBAAqB9C,IAC3BpF,KAAKmI,YAAY9F,KAAK,CAAE+C,MAAK,EAGvBpF,KAAAoI,cAAiBtG,I,MACvB,OACE5B,EAACmI,EAAQ,KACNvG,EAAOwG,SAAWpI,EAAA,wBAAsBqI,KAAK,SAC9CrI,EAAA,OAAKE,MAAM,yBACTF,EAAA,iBAAesI,QAAQ,OAAM,cAAa,QACxCtI,EAAA,SAAI4B,EAAOiD,QAEZjD,EAAO0E,aACNtG,EAAA,iBACE8D,GAAI,GAAGhE,KAAK4C,YAAYd,IAAM,MAANA,SAAM,SAANA,EAAQC,qBAChC3B,MAAM,qBACNoI,QAAQ,UAAS,cACL,QAEZtI,EAAA,SAAI4B,EAAO0E,iBAId1E,EAAOC,SACN/B,KAAK+B,QACPD,IAAM,MAANA,SAAM,SAANA,EAAQC,MAAM0G,mBAAkBtE,EAAAnE,KAAK+B,SAAK,MAAAoC,SAAA,SAAAA,EAAEsE,gBAC5CzI,KAAK2E,SAAS1B,UAAY,iBACxB/C,EAAA,QAAME,MAAM,aAAaM,UAAWgI,IAE/B,EAIP1I,KAAA2I,cAAgB,CACtB7G,EACAoC,EACAoC,KAEA,MAAMpE,KACJA,EAAIH,MACJA,EAAK8B,YACLA,EAAWkD,aACXA,EAAY6B,yBACZA,EAAwBnH,kBACxBA,EAAiBG,QACjBA,GACE5B,KAEJ,OACEE,EAAA,MACE8D,GAAIhE,KAAK4C,YAAYd,EAAOC,OAC5B3B,MAAO,CACL0B,OAAQ,KACR,iBAAkBiF,GACblD,GAAe+E,IAChB9G,EAAOC,QAAUN,EACjBoC,GAAe/B,EAAOC,QAAUA,EACpC,0BACED,EAAOgF,aACPlF,EAAQsC,EAAQ,KACftC,EAAQsC,EAAQ,GAAG4C,YACtB,kBAAmBhF,EAAOpC,SAC1B,iBAAkBoC,EAAOwG,QACzBO,QAAS/G,EAAO6B,UAElBmF,KAAK,SACLC,SACE7G,IACCJ,EAAOC,QAAUA,GAASD,EAAOC,QAAUN,IAC5CoC,EACI,IACA,KAAI,aAEE7D,KAAKqG,mBAAmBvE,EAAQwE,GAAa,gBAC1CxE,EAAOC,QAAUA,EAAK,gBACtBD,EAAOpC,SAAW,OAAS,QAC1CsJ,SAAUlH,EAAO6B,WAAa7B,EAAOwG,SAAWtI,KAAK8E,kBACrDmE,OAAQjJ,KAAKsF,WACb4D,YAAalJ,KAAK0F,gBAAe,aACrB5D,EAAOC,MAAK,aACZD,EAAOiD,OAElBjD,EAAO6B,SACNzD,EAACmI,EAAQ,KACPnI,EAAA,OAAKE,MAAM,sBACTF,EAAA,OACEE,MAAM,iBAAgB,kBACN,cAChB+I,MAAM,6BACNC,QAAQ,YACRC,KAAK,WAELnJ,EAAA,SAAO8D,GAAG,eAAa,SACvB9D,EAAA,QAAMoJ,EAAE,gBAAgBD,KAAK,SAC7BnJ,EAAA,QAAMoJ,EAAE,qLAEVpJ,EAAA,iBAAesI,QAAQ,SAAS1G,EAAOiD,QAEzC7E,EAAA,aACEqI,KAAK,QACLC,QAAQ,WACRQ,QAAShJ,KAAKiF,YACdsE,UAAWvJ,KAAKmF,mBAChB8D,OAAQjJ,KAAKkI,kBACblE,GAAG,gBAAc,UAMrBhE,KAAKoI,cAActG,GAElB,E,6BA50BmC,M,8BACC,M,iBACb,M,+DAEa,M,oBAKA,Y,iDAUN,K,eAKV,M,mIA8BiB,a,WAKH,M,4CAQ3C0H,oBAAoBC,GAClBzJ,KAAKkB,YAAcuI,EAAWC,MAAMC,GAAQA,EAAIhG,WAChD3D,KAAKmB,UAAYsI,EAAWC,MAAMC,GAAQA,EAAIrB,UAC9CtI,KAAKuB,iBAAmB,GACxBvB,KAAKuH,sB,CASPqC,oBACE5J,KAAK6J,gBAAgBxH,KAAK,CAAEN,MAAO/B,KAAK+B,O,CA2C1C+H,oBACE9J,KAAK+C,YAAY/C,KAAK2E,UAEtB,GAAI3E,KAAKoB,YAAa,CACpB,GAAIpB,KAAK6E,aAAe,aAAc7E,KAAKwD,qBAAqB,GAChExD,KAAK4I,yBAA2B,I,EAIpCmB,uBACE,GAAI/J,KAAKgK,iBAAmB7G,UAAW,CACrCnD,KAAKgK,eAAeC,S,CAEtBjK,KAAK2E,SAASuF,oBAAoB,UAAWlK,KAAKwB,qBAClDxB,KAAK2E,SAASuF,oBACZ,iBACAlK,KAAK0B,mB,CAITyI,oB,QACEnK,KAAKuH,uBACLvH,KAAK2E,SAASyF,iBAAiB,UAAWpK,KAAKwB,qBAC/CxB,KAAK2E,SAASyF,iBAAiB,iBAAkBpK,KAAK0B,oBACtD1B,KAAKkB,aAAciD,EAAAnE,KAAK4B,WAAO,MAAAuC,SAAA,SAAAA,EAAEuF,MAAMC,GAAQA,EAAIhG,WACnD3D,KAAKmB,WAAYkJ,EAAArK,KAAK4B,WAAO,MAAAyI,SAAA,SAAAA,EAAEX,MAAMC,GAAQA,EAAIrB,S,CAGnDgC,mBACE,GACEtK,KAAKoB,aACJpB,KAAK2E,SAAoC4F,cAC1C,CACAvK,KAAKyE,wBAA0B,I,CAGjC+F,EACE,CACE,CAAEC,KAAMzK,KAAKkC,KAAMwI,SAAU,QAC7B,CAAED,KAAMzK,KAAK4B,QAAS8I,SAAU,WAChC,CAAED,KAAMzK,KAAKoG,OAAQsE,SAAU,WAC/B,CAAED,KAAMzK,KAAK2K,WAAYD,SAAU,gBAGrC,O,CAIJE,qBACE,MAAMC,EAA+B7K,KAAK4B,QAAQ8H,MAC/C5H,GAAWA,EAAOC,QAAU/B,KAAK+B,QAGpC,MAAM+I,EACJ9K,KAAKyB,oBAAsB,MAC3BzB,KAAKyB,oBAAsB0B,WAC3BnD,KAAKyB,oBAAsB,GAE7B,GAAIzB,KAAKkC,MAAQlC,KAAK4B,QAAQkB,SAAW,EAAG,CAC1C,GACE9C,KAAK+B,OACL/B,KAAK6D,aACLgH,GACA7K,KAAK+K,sBACJ/K,KAAKqB,mBACN,CACArB,KAAKgH,iBAAiBhH,KAAKwF,K,MACtB,GACLxF,KAAKsC,QAAQW,UAAY,iBACzBjD,KAAKsC,QAAQW,UAAY,QACzB,CACAjD,KAAKwF,KAAKjD,O,MACL,GACLuI,IACC9K,KAAKyE,0BACLzE,KAAKwE,yBACN,CACA,MAAMwG,EAAgBhL,KAAKM,KAAK4G,cAC9B,kBAAkBlH,KAAKyB,uBAGzB,GAAIuJ,EAAe,CACjBA,EAAczI,O,IAMtB0I,qBACE,GAAIjL,KAAKgB,aAAehB,KAAKkC,KAAM,CACjClC,KAAKgB,YAAc,MACnB,IAAIkK,EAAS,MAEb,MAAMC,EAAWnL,KAAK2E,SAASyG,QAAQ,aAEvC,MAAMC,EAAWF,IAAa,KAC9B,GAAIE,EAAU,CACZrL,KAAKM,KAAK0H,UAAUC,IAAI,aACxB,GAAIkD,EAASjI,aAAa,mBAAqB,QAAS,CACtD,MAAMoI,EAAUtL,KAAKM,KAAKiL,wBAAwBC,IAClD,MAAMC,EAAazL,KAAKM,KAAKiL,wBAAwBG,OACrD,MAAMC,EAAeR,EAASI,wBAAwBK,OACtD,GAAIN,EAAUG,EAAaE,EAAc,CACvCT,EAAS,I,EAGb,GAAIA,IAAW,MAAO,CACpBlL,KAAKM,KAAK0H,UAAUC,IAAI,0B,EAI5B,GAAIiD,EAAQ,CACVlL,KAAKgK,eAAiB6B,EAAa7L,KAAK8L,SAAU9L,KAAKM,KAAM,CAC3DyL,UAAW,O,KAER,CACL/L,KAAKgK,eAAiB6B,EAAa7L,KAAK8L,SAAU9L,KAAKM,KAAM,CAC3DyL,UAAW,SACXC,UAAW,CACT,CACEzL,KAAM,SACNqB,QAAS,CACPqK,OAAQ,CAAC,EAAG,KAGhB,CACE1L,KAAM,OACNqB,QAAS,CACPsK,mBAAoB,CAAC,OACrBC,aAAc,e,OAMnB,GAAInM,KAAKkC,KAAM,CACpBlC,KAAKgK,eAAeoC,Q,CAGtB,GAAIpM,KAAKkC,QAAUlC,KAAK4B,QAAQkB,OAAQ,CACtC9C,KAAK4H,kB,EAQTyE,wBACE,IAAKrM,KAAKsB,iBAAkB,CAC1BtB,KAAKoC,gBAAgBC,KAAK,CAAEH,MAAOlC,KAAKkC,OACxClC,KAAK6D,YAAc,K,CAErB7D,KAAKsB,iBAAmB,K,CAS1B+K,yBAAyBhJ,GACvBrD,KAAK6D,YAAc,MAEnB,GAAI7D,KAAK4F,iBAAmB,YAAa,CACvC5F,KAAK4D,8BAA8BP,E,KAC9B,CACLrD,KAAKiE,6BAA6BZ,E,EAQtCgJ,6BACErM,KAAKwD,qBAAqB,E,CAmiB5BjE,SACE,MAAMoL,WACJA,EAAU/I,QACVA,EAAOwE,OACPA,EAAMrE,MACNA,EAAKlC,UACLA,EAASqB,YACTA,EAAWC,UACXA,EAAS3B,MACTA,EAAK0C,KACLA,EAAII,QACJA,EAAOuB,YACPA,GACE7D,KAEJ,OACEE,EAACC,EAAI,CACHC,MAAO,CACL,aAAcP,EACd,YAAYyC,IAAO,MAAPA,SAAO,SAAPA,EAASW,WAAY,SAAW/B,GAAeC,EAC3D3B,MAAOA,EACP0C,KAAMA,IAGPN,EAAQkB,SAAW,GAClB5C,EAAA,MACE8D,GAAIoC,EACJhG,MAAM,OACN0I,KAAK,UAAS,aACF6B,EAAU,wBAEpB5I,GAAS,MAAQA,IAAU,GAAK/B,KAAK4C,YAAYb,GAAS,GAE5DgH,SACE7G,IAAS2B,IAAevB,IAAO,MAAPA,SAAO,SAAPA,EAASW,WAAY,QAAU,IAAM,KAE/DqJ,IAAMC,GAAQvM,KAAKwF,KAAO+G,EAC1BhD,UAAWvJ,KAAK2F,kBAChB6G,QAASxM,KAAKkG,gBACd+C,OAAQjJ,KAAKsF,YAEZtF,KAAKyG,iBAAiB7E,GAAS4F,KAAI,CAAC1F,EAAQoC,KAC3C,GAAIpC,EAAO2F,SAAU,CACnB,GAAI3F,EAAO2F,SAAS3E,OAAS,EAAG,CAC9B,OACE5C,EAAA,WACEA,EAAA,iBACEE,MAAM,qBACN0I,KAAK,eACLN,QAAQ,kBAERtI,EAAA,SAAI4B,EAAOiD,QAEZjD,EAAO2F,SAASD,KAAKiF,GACpBzM,KAAK2I,cAAc8D,EAAavI,EAAOpC,K,KAIxC,CACL,OAAO,I,MAEJ,CACL,OAAO9B,KAAK2I,cAAc7G,EAAQoC,E"}
@@ -0,0 +1,2 @@
1
+ import{r as t,c as e,h as i,H as o,g as s}from"./p-1af8f256.js";import{r as n,a,i as r,J as c}from"./p-b5c0b75c.js";import{C as l}from"./p-8c7f4343.js";import{C as u}from"./p-06321d19.js";import"./p-6f57b13c.js";const d='/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0;}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px;}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font-style:inherit;vertical-align:baseline}li{list-style:none;padding:0}:host::part(button){color:var(--ic-color-primary-text);padding:calc(var(--ic-space-xxxs) / 2);display:flex;align-items:flex-start;gap:var(--ic-space-xs);border-radius:0;min-height:2.5rem;height:auto}.focus-border{display:flex;align-items:flex-start;gap:var(--ic-space-xs);border-radius:var(--ic-border-radius);margin:calc(var(--ic-space-xxxs) / 2);padding:var(--ic-space-xxs);border:var(--ic-space-xxxs) dashed transparent;--icon-height:auto}:host(.disabled)::part(button){color:var(--ic-architectural-200) !important;pointer-events:none}:host(.disabled) .menu-item-label,:host(.disabled) .shortcut,:host(.disabled) .menu-item-description{color:var(--ic-architectural-200) !important}:host([variant="destructive"])::part(button){color:var(--ic-action-destructive)}:host::part(button):hover{background-color:var(--ic-action-dark-bg-hover)}:host::part(button):focus-visible,:host::part(button):focus{color:var(--ic-color-white-text);background-color:var(--ic-focus-blue);box-shadow:none}:host(.disabled)::part(button):focus-visible,:host(.disabled)::part(button):focus{color:var(--ic-theme-lighten-40) !important}:host([variant="destructive"])::part(button):focus-visible,:host([variant="destructive"])::part(button):focus{background-color:var(--ic-action-destructive)}ic-button:focus-within .menu-item-label,ic-button:focus-within .shortcut,ic-button:focus-within .menu-item-description{color:var(--ic-color-white-text)}:host(.disabled) ic-button:focus-within .focus-border{border-color:var(--ic-architectural-white)}:host(.disabled) ic-button:focus-within .menu-item-label,:host(.disabled) ic-button:focus-within .shortcut,:host(.disabled) ic-button:focus-within .menu-item-description{color:var(--ic-theme-lighten-40) !important}:host::part(button):active{background-color:var(--ic-action-dark-bg-active);color:var(--ic-color-primary-text) !important}:host([variant="destructive"])::part(button):active{background-color:var(--ic-action-dark-bg-active);color:var(--ic-action-destructive) !important}.menu-item-info{display:flex;flex-direction:column;flex:1;align-items:baseline;white-space:pre-line;text-align:left}.menu-labels{display:flex;align-items:baseline;gap:var(--ic-space-xs)}.menu-item-description{color:var(--ic-color-secondary-text)}.shortcut{color:var(--ic-color-tertiary-text);display:flex;flex:min-content}:host([variant="destructive"]) .menu-item-label{text-transform:uppercase;font-weight:600;letter-spacing:0.025em}ic-button:active .menu-item-label{color:var(--ic-color-primary-text)}ic-button:active .menu-item-description{color:var(--ic-color-secondary-text)}ic-button:active .shortcut{color:var(--ic-color-tertiary-text)}:host([variant="destructive"]) ic-button:active .menu-item-label{color:var(--ic-action-destructive) !important}.icon,.check-icon,.submenu-icon,.icon ::slotted(svg),.check-icon svg,.submenu-icon svg{width:var(--ic-space-lg);height:var(--ic-space-lg)}.check-icon.hide{visibility:hidden}@media (forced-colors: active){:host::part(button){border:canvas}:host::part(button):focus-visible{outline:var(--ic-space-xxxs) solid transparent}.focus-border{border-color:canvas}:host(.disabled) ic-button:focus-within .focus-border{border-color:GrayText}:host(.disabled) .menu-item-info,:host(.disabled) .menu-item-label,:host(.disabled) .shortcut,:host(.disabled) .menu-item-description,:host(.disabled) ic-button:focus-within .menu-item-info,:host(.disabled) ic-button:focus-within .menu-item-label,:host(.disabled) ic-button:focus-within .shortcut,:host(.disabled) ic-button:focus-within .menu-item-description{color:GrayText !important}:host(.disabled)::part(button):focus-visible,:host(.disabled)::part(button):focus{outline-color:GrayText !important}}';const h=class{constructor(i){t(this,i);this.childBlur=e(this,"childBlur",7);this.handleMenuItemClick=e(this,"handleMenuItemClick",7);this.triggerPopoverMenuInstance=e(this,"triggerPopoverMenuInstance",7);this.handleClick=t=>{if(this.submenuTriggerFor!==undefined){this.triggerPopoverMenuInstance.emit()}else if(this.variant==="toggle"){t.preventDefault();this.toggleChecked?this.toggleChecked=false:this.toggleChecked=true}this.handleMenuItemClick.emit({label:this.label,hasSubMenu:!!this.el.submenuTriggerFor})};this.getMenuItemAriaLabel=()=>{let t=this.label;if(this.description!==undefined){t=`${t}, ${this.description}`}if(this.keyboardShortcut!==undefined){t=`${t}, ${this.keyboardShortcut}`}if(this.variant==="destructive"){t=`${t}, destructive`}if(this.submenuTriggerFor!==undefined){t=`${t}, triggers submenu`}if(this.el.classList.contains("ic-popover-submenu-back-button")){t="Go back to parent menu"}const e=c(this.el);if(e.tagName==="IC-MENU-GROUP"&&e.label){return`${t}, ${e.label} menu group`}else{return t}};this.toggleChecked=false;this.description=undefined;this.disabled=false;this.href=undefined;this.hreflang=undefined;this.keyboardShortcut=undefined;this.label=undefined;this.referrerpolicy=undefined;this.rel=undefined;this.submenuTriggerFor=undefined;this.target=undefined;this.variant="default"}componentWillLoad(){if(this.submenuTriggerFor!==undefined&&this.variant!=="default"){this.variant="default"}n(this.disabled,this.el)}componentDidLoad(){a([{prop:this.label,propName:"label"}],"Menu Item")}handleHostClick(t){if(this.disabled){t.stopImmediatePropagation()}}render(){const t=t=>t!==undefined?t:null;const e=()=>i("div",{class:"menu-item-info"},i("div",{class:"menu-labels"},i("ic-typography",{class:"menu-item-label"},this.label),this.keyboardShortcut&&i("ic-typography",{variant:"caption",class:"shortcut"},this.keyboardShortcut)),this.description&&i("ic-typography",{class:"menu-item-description",variant:"caption"},this.description));return i(o,{class:{["disabled"]:this.disabled}},i("li",{role:this.variant==="toggle"?"menuitemcheckbox":"menuitem","aria-disabled":`${this.disabled}`,"aria-checked":this.variant==="toggle"&&this.toggleChecked===true?true:this.variant==="toggle"&&this.toggleChecked===false?false:undefined},i("ic-button",{disableTooltip:true,fullWidth:true,variant:"tertiary",onClick:this.handleClick,href:t(this.href),hreflang:t(this.hreflang),target:t(this.target),rel:t(this.rel),referrerpolicy:this.referrerpolicy!==undefined?this.referrerpolicy:null,"aria-disabled":`${this.disabled}`,"aria-label":this.getMenuItemAriaLabel(),"aria-controls":this.submenuTriggerFor!==undefined?`ic-popover-submenu-${this.submenuTriggerFor}`:false,"aria-haspopup":this.submenuTriggerFor!==undefined||this.el.classList.contains("ic-popover-submenu-back-button")?"menu":false,"aria-owns":this.submenuTriggerFor!==undefined?`ic-popover-submenu-${this.submenuTriggerFor}`:false},i("div",{class:"focus-border"},r(this.el,"icon")&&i("span",{class:"icon"},i("slot",{name:"icon"})),i(e,null),this.variant==="toggle"&&i("span",{class:{["check-icon"]:true,["hide"]:!this.toggleChecked},"aria-hidden":"true",innerHTML:l}),this.submenuTriggerFor!==undefined&&i("span",{class:{["submenu-icon"]:true},"aria-hidden":"true",innerHTML:u})))))}static get delegatesFocus(){return true}get el(){return s(this)}};h.style=d;export{h as ic_menu_item};
2
+ //# sourceMappingURL=p-2c6f2aad.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icMenuItemCss","MenuItem","this","handleClick","e","submenuTriggerFor","undefined","triggerPopoverMenuInstance","emit","variant","preventDefault","toggleChecked","handleMenuItemClick","label","hasSubMenu","el","getMenuItemAriaLabel","ariaLabel","description","keyboardShortcut","classList","contains","parentEl","getParentElement","tagName","componentWillLoad","removeDisabledFalse","disabled","componentDidLoad","onComponentRequiredPropUndefined","prop","propName","handleHostClick","stopImmediatePropagation","render","isPropDefined","MenuItemInformation","h","class","Host","role","disableTooltip","fullWidth","onClick","href","hreflang","target","rel","referrerpolicy","isSlotUsed","name","innerHTML","Check","Chevron"],"sources":["./src/components/ic-menu-item/ic-menu-item.css?tag=ic-menu-item&encapsulation=shadow","./src/components/ic-menu-item/ic-menu-item.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\nli {\n list-style: none;\n padding: 0;\n}\n\n:host::part(button) {\n color: var(--ic-color-primary-text);\n padding: calc(var(--ic-space-xxxs) / 2);\n display: flex;\n align-items: flex-start;\n gap: var(--ic-space-xs);\n border-radius: 0;\n min-height: 2.5rem;\n height: auto;\n}\n\n.focus-border {\n display: flex;\n align-items: flex-start;\n gap: var(--ic-space-xs);\n border-radius: var(--ic-border-radius);\n margin: calc(var(--ic-space-xxxs) / 2);\n padding: var(--ic-space-xxs);\n border: var(--ic-space-xxxs) dashed transparent;\n\n --icon-height: auto;\n}\n\n:host(.disabled)::part(button) {\n color: var(--ic-architectural-200) !important;\n pointer-events: none;\n}\n\n:host(.disabled) .menu-item-label,\n:host(.disabled) .shortcut,\n:host(.disabled) .menu-item-description {\n color: var(--ic-architectural-200) !important;\n}\n\n:host([variant=\"destructive\"])::part(button) {\n color: var(--ic-action-destructive);\n}\n\n:host::part(button):hover {\n background-color: var(--ic-action-dark-bg-hover);\n}\n\n:host::part(button):focus-visible,\n:host::part(button):focus {\n color: var(--ic-color-white-text);\n background-color: var(--ic-focus-blue);\n box-shadow: none;\n}\n\n:host(.disabled)::part(button):focus-visible,\n:host(.disabled)::part(button):focus {\n color: var(--ic-theme-lighten-40) !important;\n}\n\n:host([variant=\"destructive\"])::part(button):focus-visible,\n:host([variant=\"destructive\"])::part(button):focus {\n background-color: var(--ic-action-destructive);\n}\n\nic-button:focus-within .menu-item-label,\nic-button:focus-within .shortcut,\nic-button:focus-within .menu-item-description {\n color: var(--ic-color-white-text);\n}\n\n:host(.disabled) ic-button:focus-within .focus-border {\n border-color: var(--ic-architectural-white);\n}\n\n:host(.disabled) ic-button:focus-within .menu-item-label,\n:host(.disabled) ic-button:focus-within .shortcut,\n:host(.disabled) ic-button:focus-within .menu-item-description {\n color: var(--ic-theme-lighten-40) !important;\n}\n\n:host::part(button):active {\n background-color: var(--ic-action-dark-bg-active);\n color: var(--ic-color-primary-text) !important;\n}\n\n:host([variant=\"destructive\"])::part(button):active {\n background-color: var(--ic-action-dark-bg-active);\n color: var(--ic-action-destructive) !important;\n}\n\n.menu-item-info {\n display: flex;\n flex-direction: column;\n flex: 1;\n align-items: baseline;\n white-space: pre-line;\n text-align: left;\n}\n\n.menu-labels {\n display: flex;\n align-items: baseline;\n gap: var(--ic-space-xs);\n}\n\n.menu-item-description {\n color: var(--ic-color-secondary-text);\n}\n\n.shortcut {\n color: var(--ic-color-tertiary-text);\n display: flex;\n flex: min-content;\n}\n\n:host([variant=\"destructive\"]) .menu-item-label {\n text-transform: uppercase;\n font-weight: 600;\n letter-spacing: 0.025em;\n}\n\nic-button:active .menu-item-label {\n color: var(--ic-color-primary-text);\n}\n\nic-button:active .menu-item-description {\n color: var(--ic-color-secondary-text);\n}\n\nic-button:active .shortcut {\n color: var(--ic-color-tertiary-text);\n}\n\n:host([variant=\"destructive\"]) ic-button:active .menu-item-label {\n color: var(--ic-action-destructive) !important;\n}\n\n.icon,\n.check-icon,\n.submenu-icon,\n.icon ::slotted(svg),\n.check-icon svg,\n.submenu-icon svg {\n width: var(--ic-space-lg);\n height: var(--ic-space-lg);\n}\n\n.check-icon.hide {\n visibility: hidden;\n}\n\n/** High Contrast **/\n@media (forced-colors: active) {\n :host::part(button) {\n border: canvas;\n }\n\n :host::part(button):focus-visible {\n outline: var(--ic-space-xxxs) solid transparent;\n }\n\n .focus-border {\n border-color: canvas;\n }\n\n :host(.disabled) ic-button:focus-within .focus-border {\n border-color: GrayText;\n }\n\n :host(.disabled) .menu-item-info,\n :host(.disabled) .menu-item-label,\n :host(.disabled) .shortcut,\n :host(.disabled) .menu-item-description,\n :host(.disabled) ic-button:focus-within .menu-item-info,\n :host(.disabled) ic-button:focus-within .menu-item-label,\n :host(.disabled) ic-button:focus-within .shortcut,\n :host(.disabled) ic-button:focus-within .menu-item-description {\n color: GrayText !important;\n }\n\n :host(.disabled)::part(button):focus-visible,\n :host(.disabled)::part(button):focus {\n outline-color: GrayText !important;\n }\n}\n","import {\n Component,\n Element,\n Host,\n Prop,\n h,\n State,\n Event,\n EventEmitter,\n Listen,\n} from \"@stencil/core\";\nimport {\n getParentElement,\n isSlotUsed,\n onComponentRequiredPropUndefined,\n removeDisabledFalse,\n} from \"../../utils/helpers\";\nimport { IcMenuItemVariants } from \"./ic-menu-item.types\";\nimport Check from \"../../assets/check-icon.svg\";\nimport Chevron from \"../../assets/chevron-icon.svg\";\n\n/**\n * @slot icon - Content will be placed to the left of the menu item label.\n */\n\n@Component({\n tag: \"ic-menu-item\",\n styleUrl: \"ic-menu-item.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class MenuItem {\n @Element() el: HTMLIcMenuItemElement;\n\n @State() toggleChecked: boolean = false;\n\n /**\n * The description displayed in the menu item, below the label.\n */\n @Prop() description?: string;\n\n /**\n * If `true`, the menu item will be in disabled state.\n */\n @Prop() disabled?: boolean = false;\n\n /**\n * The URL that the link points to. This will render the menu item as an \"a\" tag.\n */\n @Prop() href?: string;\n\n /**\n * The human language of the linked URL.\n */\n @Prop() hreflang?: string;\n\n /**\n * The label describing the keyboard shortcut for a menu item's action.\n */\n @Prop() keyboardShortcut?: string;\n\n /**\n * The label to display in the menu item.\n */\n @Prop() label!: string;\n\n /**\n * How much of the referrer to send when following the link.\n */\n @Prop() referrerpolicy?: ReferrerPolicy;\n\n /**\n * The relationship of the linked URL as space-separated link types.\n */\n @Prop() rel?: string;\n\n /**\n * This references the popover menu instance that the menu item is a trigger for. If this prop is set, then the variant will always be default.\n */\n @Prop() submenuTriggerFor?: string;\n\n /**\n * The place to display the linked URL, as the name for a browsing context (a tab, window, or iframe).\n */\n @Prop() target?: string;\n\n /**\n * The variant of the menu item.\n */\n @Prop({ mutable: true, reflect: true }) variant: IcMenuItemVariants =\n \"default\";\n\n /**\n * @internal Emitted when item loses focus.\n */\n @Event() childBlur: EventEmitter<void>;\n\n /**\n * @internal Emitted when the user clicks a menu item.\n */\n @Event() handleMenuItemClick: EventEmitter<{\n label: string;\n hasSubMenu: boolean;\n }>;\n\n /**\n * @internal Emitted when the user clicks a menu item that triggers a popover menu instance.\n */\n @Event() triggerPopoverMenuInstance: EventEmitter<void>;\n\n componentWillLoad(): void {\n // This ensures that trigger menu items are always set to the default variant\n if (this.submenuTriggerFor !== undefined && this.variant !== \"default\") {\n this.variant = \"default\";\n }\n removeDisabledFalse(this.disabled, this.el);\n }\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.label, propName: \"label\" }],\n \"Menu Item\"\n );\n }\n\n @Listen(\"click\", { capture: true })\n handleHostClick(e: Event): void {\n if (this.disabled) {\n e.stopImmediatePropagation();\n }\n }\n\n private handleClick = (e: Event): void => {\n if (this.submenuTriggerFor !== undefined) {\n this.triggerPopoverMenuInstance.emit();\n } else if (this.variant === \"toggle\") {\n e.preventDefault();\n this.toggleChecked\n ? (this.toggleChecked = false)\n : (this.toggleChecked = true);\n }\n this.handleMenuItemClick.emit({\n label: this.label,\n hasSubMenu: !!this.el.submenuTriggerFor,\n });\n };\n\n private getMenuItemAriaLabel = (): string => {\n let ariaLabel = this.label;\n\n if (this.description !== undefined) {\n ariaLabel = `${ariaLabel}, ${this.description}`;\n }\n\n if (this.keyboardShortcut !== undefined) {\n ariaLabel = `${ariaLabel}, ${this.keyboardShortcut}`;\n }\n\n if (this.variant === \"destructive\") {\n ariaLabel = `${ariaLabel}, destructive`;\n }\n\n if (this.submenuTriggerFor !== undefined) {\n ariaLabel = `${ariaLabel}, triggers submenu`;\n }\n\n if (this.el.classList.contains(\"ic-popover-submenu-back-button\")) {\n ariaLabel = \"Go back to parent menu\";\n }\n const parentEl = getParentElement(this.el);\n\n if (\n parentEl.tagName === \"IC-MENU-GROUP\" &&\n (parentEl as HTMLIcMenuGroupElement).label\n ) {\n return `${ariaLabel}, ${\n (parentEl as HTMLIcMenuGroupElement).label\n } menu group`;\n } else {\n return ariaLabel;\n }\n };\n\n render() {\n // A helper function that checks if a prop has been defined\n const isPropDefined = (prop: string) => {\n return prop !== undefined ? prop : null;\n };\n\n // A sub-component to layout the menu information correctly in ic-button\n const MenuItemInformation = () => {\n return (\n <div class=\"menu-item-info\">\n <div class=\"menu-labels\">\n <ic-typography class=\"menu-item-label\">{this.label}</ic-typography>\n {this.keyboardShortcut && (\n <ic-typography variant=\"caption\" class=\"shortcut\">\n {this.keyboardShortcut}\n </ic-typography>\n )}\n </div>\n {this.description && (\n <ic-typography class=\"menu-item-description\" variant=\"caption\">\n {this.description}\n </ic-typography>\n )}\n </div>\n );\n };\n\n return (\n <Host\n class={{\n [\"disabled\"]: this.disabled,\n }}\n >\n <li\n role={this.variant === \"toggle\" ? \"menuitemcheckbox\" : \"menuitem\"}\n aria-disabled={`${this.disabled}`}\n aria-checked={\n this.variant === \"toggle\" && this.toggleChecked === true\n ? true\n : this.variant === \"toggle\" && this.toggleChecked === false\n ? false\n : undefined\n }\n >\n <ic-button\n disableTooltip\n fullWidth\n variant=\"tertiary\"\n onClick={this.handleClick}\n href={isPropDefined(this.href)}\n hreflang={isPropDefined(this.hreflang)}\n target={isPropDefined(this.target)}\n rel={isPropDefined(this.rel)}\n referrerpolicy={\n this.referrerpolicy !== undefined ? this.referrerpolicy : null\n }\n aria-disabled={`${this.disabled}`}\n aria-label={this.getMenuItemAriaLabel()}\n aria-controls={\n this.submenuTriggerFor !== undefined\n ? `ic-popover-submenu-${this.submenuTriggerFor}`\n : false\n }\n aria-haspopup={\n this.submenuTriggerFor !== undefined ||\n this.el.classList.contains(\"ic-popover-submenu-back-button\")\n ? \"menu\"\n : false\n }\n aria-owns={\n this.submenuTriggerFor !== undefined\n ? `ic-popover-submenu-${this.submenuTriggerFor}`\n : false\n }\n >\n <div class=\"focus-border\">\n {isSlotUsed(this.el, \"icon\") && (\n <span class=\"icon\">\n <slot name=\"icon\"></slot>\n </span>\n )}\n <MenuItemInformation />\n {this.variant === \"toggle\" && (\n <span\n class={{\n [\"check-icon\"]: true,\n [\"hide\"]: !this.toggleChecked,\n }}\n aria-hidden=\"true\"\n innerHTML={Check}\n />\n )}\n {this.submenuTriggerFor !== undefined && (\n <span\n class={{ [\"submenu-icon\"]: true }}\n aria-hidden=\"true\"\n innerHTML={Chevron}\n />\n )}\n </div>\n </ic-button>\n </li>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{r as i,c as t,h as a,H as s,g as e}from"./p-1af8f256.js";import{v as n,H as o,i as r}from"./p-b5c0b75c.js";import"./p-6f57b13c.js";const c=":host{display:block;position:fixed;top:0;left:0;width:100%;min-height:100% !important;background:rgb(0 0 0 / 60%);z-index:var(--ic-z-index-navigation-menu)}.popout-modal{position:absolute;inset:0}.popout-menu{position:fixed;top:0;right:0;width:16rem;bottom:0;background-color:var(--ic-architectural-20);color:var(--ic-color-primary-text);box-shadow:var(--ic-elevation-overlay);overflow-y:auto;overflow-x:hidden}:host(.inline) .popout-menu{position:absolute}.menu-close-button-container{position:relative;left:11.875rem;padding:var(--ic-space-md) 0}.nav-group-first{padding-bottom:0}.menu-buttons-container{padding:var(--ic-space-sm) 0;border-bottom:var(--ic-border-light)}.menu-buttons-container-nav-item-above{margin-top:var(--ic-space-md);border-top:var(--ic-border-light)}.menu-status-version-container{display:flex;flex-wrap:wrap;gap:var(--ic-space-xs);margin:var(--ic-space-md) var(--ic-space-md) var(--ic-space-xl)}.menu-status{background-color:var(--ic-architectural-500);color:var(--ic-color-white-text);border-radius:var(--ic-space-md);width:-moz-fit-content;width:fit-content;padding:var(--ic-space-xxs) var(--ic-space-sm)}.menu-version{border-radius:var(--ic-space-md);background-color:var(--ic-architectural-100);padding:var(--ic-space-xxs) var(--ic-space-sm)}.menu-status-text,.menu-version-text{overflow-wrap:break-word}.navigation-landmark-text{position:absolute;width:var(--ic-space-1px);height:var(--ic-space-1px);padding:0;margin:calc(-1 * var(--ic-space-1px));overflow:hidden}";const l=class{constructor(a){i(this,a);this.icNavigationMenuClose=t(this,"icNavigationMenuClose",7);this.closeButton=null;this.hasButtons=false;this.hasNavigation=false;this.lastTabStop=null;this.navGroupFirst=false;this.navItemAboveButtons=false;this.closeMenu=()=>{this.icNavigationMenuClose.emit()};this.focusCloseButton=()=>{if(this.closeButton.focus){this.closeButton.focus()}};this.focusLastTabStop=()=>{let i;if(this.lastTabStop!==null){switch(this.lastTabStop.tagName){case"IC-NAVIGATION-BUTTON":case"IC-NAVIGATION-ITEM":case"IC-NAVIGATION-GROUP":i=this.lastTabStop;i.focus();break;case"A":this.lastTabStop.focus();break}}};this.status="";this.version=""}componentWillLoad(){this.navBarEl=document.querySelector("ic-top-navigation");const i=n(this.el,"navigation");if(i){this.hasNavigation=true;const t=i[i.length-1];if(t.tagName==="IC-NAVIGATION-ITEM"){this.navItemAboveButtons=true}const a=i[0];if(a.tagName==="IC-NAVIGATION-GROUP"){this.navGroupFirst=true}}const t=n(this.el,"buttons");if(t!==null){this.hasButtons=true;this.lastTabStop=t[t.length-1]}else{if(this.hasNavigation){const t=i[i.length-1];const a=o(t,"navigation-item");if(a!==null){this.lastTabStop=a}else{this.lastTabStop=t}}}}componentDidLoad(){this.focusCloseButton()}componentWillRender(){this.hasNavigation=r(this.el,"navigation");this.hasButtons=r(this.el,"buttons")}navItemClickHandler(){this.closeMenu()}handleKeyDown(i){if(i.key==="Tab"){if(i.shiftKey){if(document.activeElement===this.navBarEl){i.preventDefault();this.focusLastTabStop()}}else if(document.activeElement===this.lastTabStop||this.lastTabStop===null){i.preventDefault();this.focusCloseButton()}}else if(i.key==="Escape"){this.closeMenu()}}render(){return a(s,null,a("div",{class:"popout-modal",onClick:this.closeMenu}),a("div",{class:"popout-menu",role:"dialog","aria-modal":"true","aria-label":`${this.hasNavigation?"Navigation":"App"} menu`},a("span",{"aria-hidden":"true",id:"navigation-landmark-text",class:"navigation-landmark-text"},"Main navigation"),a("nav",{"aria-labelledby":"navigation-landmark-text","aria-hidden":this.hasNavigation?"false":"true"},a("div",{class:{["menu-close-button-container"]:true,["nav-group-first"]:this.navGroupFirst}},a("ic-button",{ref:i=>this.closeButton=i,id:"menu-close-button",class:"menu-close-button",variant:"icon",size:"large","aria-label":`Close ${this.hasNavigation?"navigation":"app"} menu`,onClick:this.closeMenu},a("svg",{slot:"icon",width:"14",height:"14",viewBox:"0 0 14 14",fill:"none",xmlns:"http://www.w3.org/2000/svg"},a("path",{d:"M14 1.41L12.59 0L7 5.59L1.41 0L0 1.41L5.59 7L0 12.59L1.41 14L7 8.41L12.59 14L14 12.59L8.41 7L14 1.41Z",fill:"#1759BC"})))),this.hasNavigation&&a("slot",{name:"navigation"})),this.hasButtons&&a("div",{class:{["menu-buttons-container"]:true,["menu-buttons-container-nav-item-above"]:this.navItemAboveButtons}},a("slot",{name:"buttons"})),(this.status!==""||this.version!=="")&&a("div",{class:"menu-status-version-container"},this.status!==""&&a("div",{class:"menu-status"},a("ic-typography",{variant:"label-uppercase","aria-label":"app tag",class:"menu-status-text"},this.status)),this.version!==""&&a("div",{class:"menu-version"},a("ic-typography",{variant:"label",class:"menu-version-text","aria-label":"app version"},this.version)))))}get el(){return e(this)}};l.style=c;export{l as ic_navigation_menu};
2
+ //# sourceMappingURL=p-35b9f898.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icNavigationMenuCss","NavigationMenu","this","closeButton","hasButtons","hasNavigation","lastTabStop","navGroupFirst","navItemAboveButtons","closeMenu","icNavigationMenuClose","emit","focusCloseButton","focus","focusLastTabStop","focusEl","tagName","componentWillLoad","navBarEl","document","querySelector","navigationEls","getSlotContent","el","lastEl","length","firstEl","buttonContent","slotContent","getSlot","componentDidLoad","componentWillRender","isSlotUsed","navItemClickHandler","handleKeyDown","ev","key","shiftKey","activeElement","preventDefault","render","h","Host","class","onClick","role","id","ref","variant","size","slot","width","height","viewBox","fill","xmlns","d","name","status","version"],"sources":["./src/components/ic-navigation-menu/ic-navigation-menu.css?tag=ic-navigation-menu&encapsulation=shadow","./src/components/ic-navigation-menu/ic-navigation-menu.tsx"],"sourcesContent":["/**\n * @prop --ic-z-index-navigation-menu: z-index of navigation menu\n */\n\n:host {\n display: block;\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n min-height: 100% !important;\n background: rgb(0 0 0 / 60%);\n z-index: var(--ic-z-index-navigation-menu);\n}\n\n.popout-modal {\n position: absolute;\n inset: 0;\n}\n\n.popout-menu {\n position: fixed;\n top: 0;\n right: 0;\n width: 16rem;\n bottom: 0;\n background-color: var(--ic-architectural-20);\n color: var(--ic-color-primary-text);\n box-shadow: var(--ic-elevation-overlay);\n overflow-y: auto;\n overflow-x: hidden;\n}\n\n:host(.inline) .popout-menu {\n position: absolute;\n}\n\n.menu-close-button-container {\n position: relative;\n left: 11.875rem;\n padding: var(--ic-space-md) 0;\n}\n\n.nav-group-first {\n padding-bottom: 0;\n}\n\n.menu-buttons-container {\n padding: var(--ic-space-sm) 0;\n border-bottom: var(--ic-border-light);\n}\n\n.menu-buttons-container-nav-item-above {\n margin-top: var(--ic-space-md);\n border-top: var(--ic-border-light);\n}\n\n.menu-status-version-container {\n display: flex;\n flex-wrap: wrap;\n gap: var(--ic-space-xs);\n margin: var(--ic-space-md) var(--ic-space-md) var(--ic-space-xl);\n}\n\n.menu-status {\n background-color: var(--ic-architectural-500);\n color: var(--ic-color-white-text);\n border-radius: var(--ic-space-md);\n width: fit-content;\n padding: var(--ic-space-xxs) var(--ic-space-sm);\n}\n\n.menu-version {\n border-radius: var(--ic-space-md);\n background-color: var(--ic-architectural-100);\n padding: var(--ic-space-xxs) var(--ic-space-sm);\n}\n\n.menu-status-text,\n.menu-version-text {\n overflow-wrap: break-word;\n}\n\n.navigation-landmark-text {\n position: absolute;\n width: var(--ic-space-1px);\n height: var(--ic-space-1px);\n padding: 0;\n margin: calc(-1 * var(--ic-space-1px));\n overflow: hidden;\n}\n","import {\n Component,\n Element,\n Host,\n Prop,\n h,\n Event,\n EventEmitter,\n Listen,\n} from \"@stencil/core\";\n\nimport { getSlot, getSlotContent, isSlotUsed } from \"../../utils/helpers\";\n\n/**\n * @slot navigation - Content will be rendered at top of panel.\n * @slot buttons - Content will be rendered above version info and below navigation.\n */\n@Component({\n tag: \"ic-navigation-menu\",\n styleUrl: \"ic-navigation-menu.css\",\n shadow: true,\n})\nexport class NavigationMenu {\n private closeButton: HTMLIcButtonElement = null;\n private hasButtons: boolean = false;\n private hasNavigation: boolean = false;\n private lastTabStop: HTMLElement = null;\n private navBarEl: HTMLIcTopNavigationElement;\n private navGroupFirst: boolean = false;\n private navItemAboveButtons: boolean = false;\n\n @Element() el: HTMLIcNavigationMenuElement;\n\n /**\n * The status info to display.\n */\n @Prop() status: string = \"\";\n\n /**\n * The version info to display.\n */\n @Prop() version: string = \"\";\n\n /**\n * @internal - Emitted when the menu is closed.\n */\n @Event() icNavigationMenuClose: EventEmitter<void>;\n\n componentWillLoad(): void {\n this.navBarEl = document.querySelector(\"ic-top-navigation\");\n const navigationEls = getSlotContent(this.el, \"navigation\");\n if (navigationEls) {\n this.hasNavigation = true;\n const lastEl = navigationEls[navigationEls.length - 1] as HTMLElement;\n if (lastEl.tagName === \"IC-NAVIGATION-ITEM\") {\n this.navItemAboveButtons = true;\n }\n const firstEl = navigationEls[0] as HTMLElement;\n if (firstEl.tagName === \"IC-NAVIGATION-GROUP\") {\n this.navGroupFirst = true;\n }\n }\n const buttonContent = getSlotContent(this.el, \"buttons\");\n\n if (buttonContent !== null) {\n this.hasButtons = true;\n this.lastTabStop = buttonContent[buttonContent.length - 1] as HTMLElement;\n } else {\n if (this.hasNavigation) {\n const lastEl = navigationEls[navigationEls.length - 1] as HTMLElement;\n //check for slotted content i.e. react router link\n const slotContent = getSlot(lastEl, \"navigation-item\");\n if (slotContent !== null) {\n this.lastTabStop = slotContent as HTMLElement;\n } else {\n this.lastTabStop = lastEl;\n }\n }\n }\n }\n\n componentDidLoad(): void {\n this.focusCloseButton();\n }\n\n componentWillRender(): void {\n this.hasNavigation = isSlotUsed(this.el, \"navigation\");\n this.hasButtons = isSlotUsed(this.el, \"buttons\");\n }\n\n @Listen(\"navItemClicked\")\n navItemClickHandler(): void {\n this.closeMenu();\n }\n\n @Listen(\"keydown\", { target: \"document\" })\n handleKeyDown(ev: KeyboardEvent): void {\n if (ev.key === \"Tab\") {\n if (ev.shiftKey) {\n if (document.activeElement === this.navBarEl) {\n ev.preventDefault();\n this.focusLastTabStop();\n }\n } else if (\n document.activeElement === this.lastTabStop ||\n this.lastTabStop === null\n ) {\n ev.preventDefault();\n this.focusCloseButton();\n }\n } else if (ev.key === \"Escape\") {\n this.closeMenu();\n }\n }\n\n private closeMenu = () => {\n this.icNavigationMenuClose.emit();\n };\n\n private focusCloseButton = () => {\n if (this.closeButton.focus) {\n this.closeButton.focus();\n }\n };\n\n private focusLastTabStop = () => {\n let focusEl;\n if (this.lastTabStop !== null) {\n switch (this.lastTabStop.tagName) {\n case \"IC-NAVIGATION-BUTTON\":\n case \"IC-NAVIGATION-ITEM\":\n case \"IC-NAVIGATION-GROUP\":\n focusEl = this.lastTabStop as HTMLElement;\n focusEl.focus();\n break;\n case \"A\":\n this.lastTabStop.focus();\n break;\n }\n }\n };\n\n render() {\n return (\n <Host>\n <div class=\"popout-modal\" onClick={this.closeMenu}></div>\n <div\n class=\"popout-menu\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-label={`${this.hasNavigation ? \"Navigation\" : \"App\"} menu`}\n >\n <span\n aria-hidden=\"true\"\n id=\"navigation-landmark-text\"\n class=\"navigation-landmark-text\"\n >\n Main navigation\n </span>\n <nav\n aria-labelledby=\"navigation-landmark-text\"\n aria-hidden={this.hasNavigation ? \"false\" : \"true\"}\n >\n <div\n class={{\n [\"menu-close-button-container\"]: true,\n [\"nav-group-first\"]: this.navGroupFirst,\n }}\n >\n <ic-button\n ref={(el) => (this.closeButton = el)}\n id=\"menu-close-button\"\n class=\"menu-close-button\"\n variant=\"icon\"\n size=\"large\"\n aria-label={`Close ${\n this.hasNavigation ? \"navigation\" : \"app\"\n } menu`}\n onClick={this.closeMenu}\n >\n <svg\n slot=\"icon\"\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M14 1.41L12.59 0L7 5.59L1.41 0L0 1.41L5.59 7L0 12.59L1.41 14L7 8.41L12.59 14L14 12.59L8.41 7L14 1.41Z\"\n fill=\"#1759BC\"\n />\n </svg>\n </ic-button>\n </div>\n {this.hasNavigation && <slot name=\"navigation\"></slot>}\n </nav>\n {this.hasButtons && (\n <div\n class={{\n [\"menu-buttons-container\"]: true,\n [\"menu-buttons-container-nav-item-above\"]:\n this.navItemAboveButtons,\n }}\n >\n <slot name=\"buttons\"></slot>\n </div>\n )}\n {(this.status !== \"\" || this.version !== \"\") && (\n <div class=\"menu-status-version-container\">\n {this.status !== \"\" && (\n <div class=\"menu-status\">\n <ic-typography\n variant=\"label-uppercase\"\n aria-label=\"app tag\"\n class=\"menu-status-text\"\n >\n {this.status}\n </ic-typography>\n </div>\n )}\n {this.version !== \"\" && (\n <div class=\"menu-version\">\n <ic-typography\n variant=\"label\"\n class=\"menu-version-text\"\n aria-label=\"app version\"\n >\n {this.version}\n </ic-typography>\n </div>\n )}\n </div>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{r as t,h as e,H as s,g as i}from"./p-1af8f256.js";import{C as a}from"./p-8c7f4343.js";const c=`<svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">\n<path d="M7.99935 4.32666L13.0193 13H2.97935L7.99935 4.32666ZM7.99935 1.66666L0.666016 14.3333H15.3327L7.99935 1.66666ZM8.66602 11H7.33268V12.3333H8.66602V11ZM8.66602 6.99999H7.33268V9.66666H8.66602V6.99999Z" fill="currentColor"/>\n</svg>`;const r=":host{display:flex;flex:auto}.step{display:flex;flex:1 1 0}.step-icon{display:flex;justify-content:center}.step-title,.step-subtitle,.step-status,.next-step{white-space:pre-line}.visually-hidden{position:absolute;left:-625rem;top:auto;width:1px;height:1px;overflow:hidden}:host(.compact){-moz-column-gap:var(--ic-space-sm);column-gap:var(--ic-space-sm);--compact-step-inner-color:var(--ic-status-info);--compact-step-circular-line-width:var(--ic-space-xxs)}:host(.compact) .step{-moz-column-gap:var(--ic-space-sm);column-gap:var(--ic-space-sm)}:host(.compact) .step:not(.current){display:none;opacity:0;visibility:hidden}.compact-step-progress-indicator{margin:var(--ic-space-xs) 0 0}:host(.compact) .step-title-area{display:flex;flex-direction:column;width:14.25rem}.info-line{display:flex;-moz-column-gap:var(--ic-space-xs);column-gap:var(--ic-space-xs)}.step-status{display:flex;color:var(--ic-color-secondary-text);-moz-column-gap:var(--ic-space-xxxs);column-gap:var(--ic-space-xxxs)}.compact-step-completed .step-status{color:var(--ic-status-success)}.compact-step-disabled :is(.step-title,.step-status){color:var(--ic-color-tertiary-text)}.step-num{color:var(--ic-color-secondary-text);white-space:nowrap}:host(.compact) .step-icon{margin:var(--ic-space-xxxs)}:host(.compact) .step-icon svg{width:var(--ic-space-md);height:var(--ic-space-md)}:host(.default) .step{flex-direction:column}:host(.default.last-step){flex-grow:initial}.step-top{display:flex;width:100%;align-items:center;align-self:flex-start;height:2.5rem}:host(.default) .step-icon{border-radius:50%}.step-icon-inner{width:var(--ic-space-xl);height:var(--ic-space-xl);display:flex;justify-content:center;align-items:center;border-radius:50%}:host(.default) .current{color:var(--ic-status-info)}:host(.default) .step-title-area{margin:var(--ic-space-xs) 0;padding-right:var(--ic-space-xs);width:100%}:host(.default) .step-title,.step-subtitle{width:-moz-fit-content;width:fit-content}.step-subtitle{color:var(--ic-color-tertiary-text)}.current .step-subtitle{color:var(--ic-color-primary-text)}:host(.default) .completed{color:var(--ic-status-success)}.active .step-icon-inner{box-shadow:inset var(--ic-architectural-200) 0 0 0 0.125rem}.current .step-icon-inner{background-color:var(--ic-status-info);color:white}.disabled{color:var(--ic-architectural-200)}.disabled .step-icon-inner{border:var(--ic-space-1px) dashed var(--ic-architectural-200);width:calc(var(--ic-space-xl) - var(--ic-space-xxxs));height:calc(var(--ic-space-xl) - var(--ic-space-xxxs))}.disabled .step-title-area{color:var(--ic-color-tertiary-text)}.completed .step-icon-inner{background:var(--ic-status-success);box-shadow:inset var(--ic-status-success) 0 0 0 var(--ic-space-xxxs);border-radius:100%}:host(.default) .current .step-icon{border:var(--ic-space-xxxs) solid var(--ic-status-info);padding:var(--ic-space-xxxs);margin:0 calc(-1 * var(--ic-space-xxxs));}.step-connect{height:var(--ic-space-xxxs);background-color:var(--ic-architectural-200);margin:0 var(--ic-space-xs);border-radius:var(--ic-space-xxs);width:100%}.aligned-full-width.step-connect{min-width:6.25rem;width:100%}.disabled .step-connect{height:0;background-color:rgb(0 0 0 / 0%);border-top:0.125rem dashed var(--ic-architectural-200);border-radius:0}.completed .step-connect{background-color:var(--ic-status-success)}.step-connect-inner{width:70%;display:flex;flex:auto;height:var(--ic-space-xxxs);border-radius:var(--ic-space-xxs);background-color:var(--ic-status-info)}.step-icon-inner .check-icon{padding-top:var(--ic-space-xxs)}.step-icon-inner .check-icon svg{width:var(--ic-space-md);height:auto}.step-icon-inner .check-icon>svg>path{fill:var(--ic-color-white-text)}@media (forced-colors: active){.compact-step-disabled :is(.step-title,.step-status){color:GrayText}.step-connect:not(.disabled .step-connect){border:var(--ic-hc-border)}.active .step-icon-inner,.completed .step-icon-inner,.current .step-icon-inner{forced-color-adjust:none;box-shadow:inset canvastext 0 0 0 0.125rem;background-color:transparent;color:canvastext}:host(.default) .current .step-icon{padding:0;border:none}.disabled,.disabled .step-title-area{color:GrayText}.step-connect-inner,.completed .step-connect{background-color:canvastext}.step-icon-inner .check-icon>svg>path{fill:canvastext}}";const n=class{constructor(e){t(this,e);this.compactStepStyling=undefined;this.current=false;this.lastStep=undefined;this.lastStepNum=undefined;this.nextStepTitle=undefined;this.progress=undefined;this.stepNum=undefined;this.stepStatus=undefined;this.stepSubtitle=undefined;this.stepTitle=undefined;this.variant=undefined;this.stepType="active"}stepTypeChangeHandler(){if(this.variant==="compact"&&this.stepType==="current"){this.current=true}else{this.current=false}}render(){let t="";if(this.stepType==="completed"){t=". Completed step"}else if(this.stepType==="disabled"){t=". Non-required step"}else if(this.stepStatus==="required"){t=". Required step"}else if(this.stepStatus==="optional"){t=". Optional step"}let i;if(this.stepStatus){i=this.stepStatus[0].toUpperCase()+this.stepStatus.slice(1)}let r;if(this.stepType==="disabled"||this.compactStepStyling==="disabled"){r="Not required"}else if(this.compactStepStyling==="completed"){r="Completed"}let n;if(this.stepType==="completed"||this.compactStepStyling==="completed"){n=e("span",{class:"check-icon step-icon","aria-hidden":"true",innerHTML:a})}else if(this.stepType==="disabled"||this.compactStepStyling==="disabled"){n=e("span",{class:"warning-icon step-icon","aria-hidden":"true",innerHTML:c})}const o=e("div",{class:{["step"]:true,["current"]:this.current,[`compact-step-${this.compactStepStyling}`]:!!this.compactStepStyling}},e("ic-loading-indicator",{class:{"compact-step-progress-indicator":true,"not-required":this.stepType==="disabled"||this.compactStepStyling==="disabled"},"aria-hidden":"true",size:"small","inner-label":this.stepNum,progress:this.progress}),e("div",{class:"step-title-area"},e("ic-typography",{variant:"h4",class:"step-title"},this.stepTitle),e("div",{class:"info-line"},e("ic-typography",{variant:"caption",class:"step-num"},`${this.stepNum} of ${this.lastStepNum}`,e("span",{class:"visually-hidden"}," steps")),(this.stepSubtitle||this.stepType==="completed"||this.stepType==="disabled"||this.variant==="compact"&&!!this.compactStepStyling&&this.compactStepStyling!=="active"||!!this.stepStatus)&&e("div",{class:"step-status"},n!==undefined&&n,(this.stepSubtitle||r)&&e("ic-typography",{variant:"caption"},this.stepSubtitle!==null&&this.stepSubtitle!==undefined?this.stepSubtitle:this.stepType==="disabled"||this.variant==="compact"&&this.compactStepStyling==="disabled"||this.stepType==="completed"||this.variant==="compact"&&this.compactStepStyling==="completed"?r:this.stepStatus&&i))),this.lastStep?e("ic-typography",{variant:"subtitle-small",class:"next-step"},"Last step"):this.nextStepTitle!==undefined&&e("ic-typography",{variant:"subtitle-small",class:"next-step"},"Next",e("span",{class:"visually-hidden"}," step is"),":"," ",this.nextStepTitle)));let l;if(this.stepType!=="completed"){l=e("ic-typography",{variant:"subtitle-small"},e("span",{class:"step-icon-inner","aria-hidden":"true"},this.stepNum))}else{l=e("div",{class:"step-icon-inner","aria-hidden":"true"},e("span",{class:"check-icon",innerHTML:a}))}const p=this.stepType==="current"&&e("div",{class:"step-connect-inner"});const d=!this.lastStep&&e("div",{class:{["step-connect"]:true,["aligned-full-width"]:this.el.parentElement.classList.contains("default")&&!this.el.parentElement.classList.contains("aligned-left")}},p);const h=e("div",{class:{["step"]:true,[`${this.stepType}`]:true}},e("div",{class:"step-top"},e("div",{class:"step-icon"},l),d),(this.stepTitle||this.stepSubtitle||this.stepStatus)&&e("div",{class:"step-title-area"},this.stepTitle&&e("ic-typography",{variant:"subtitle-large",class:"step-title"},this.stepTitle),this.stepTitle&&(this.stepSubtitle||this.stepStatus)&&e("ic-typography",{variant:"caption",class:"step-subtitle"},this.stepSubtitle!==null&&this.stepSubtitle!==undefined?this.stepSubtitle:i)));return e(s,{role:"listitem","aria-label":`Step ${this.stepNum}${t}`,"aria-current":(this.current||this.stepType==="current")&&"step",class:{["aligned-full-width"]:this.el.parentElement.classList.contains("default")&&!this.el.parentElement.classList.contains("aligned-left"),[`${this.variant}`]:true}},this.variant==="compact"?o:h)}get el(){return i(this)}static get watchers(){return{stepType:["stepTypeChangeHandler"]}}};n.style=r;export{n as ic_step};
2
+ //# sourceMappingURL=p-3b686a68.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icStepCss","Step","stepTypeChangeHandler","this","variant","stepType","current","render","ariaLabel","stepStatus","toUpperCase","slice","compactStepStyling","statusIcon","h","class","innerHTML","checkIcon","warningIcon","compactStep","size","stepNum","progress","stepTitle","lastStepNum","stepSubtitle","undefined","lastStep","nextStepTitle","icon","partialBar","finalStep","el","parentElement","classList","contains","defaultStep","Host","role"],"sources":["./src/components/ic-step/ic-step.css?tag=ic-step&encapsulation=shadow","./src/components/ic-step/ic-step.tsx"],"sourcesContent":["/* SHARED STYLING */\n:host {\n display: flex;\n flex: auto;\n}\n\n.step {\n display: flex;\n flex: 1 1 0;\n}\n\n.step-icon {\n display: flex;\n justify-content: center;\n}\n\n.step-title,\n.step-subtitle,\n.step-status,\n.next-step {\n white-space: pre-line;\n}\n\n.visually-hidden {\n position: absolute;\n left: -625rem;\n top: auto;\n width: 1px;\n height: 1px;\n overflow: hidden;\n}\n\n/* COMPACT STEP STYLING */\n:host(.compact) {\n column-gap: var(--ic-space-sm);\n\n --compact-step-inner-color: var(--ic-status-info);\n --compact-step-circular-line-width: var(--ic-space-xxs);\n}\n\n:host(.compact) .step {\n column-gap: var(--ic-space-sm);\n}\n\n:host(.compact) .step:not(.current) {\n display: none;\n opacity: 0;\n visibility: hidden;\n}\n\n.compact-step-progress-indicator {\n margin: var(--ic-space-xs) 0 0;\n}\n\n:host(.compact) .step-title-area {\n display: flex;\n flex-direction: column;\n width: 14.25rem;\n}\n\n.info-line {\n display: flex;\n column-gap: var(--ic-space-xs);\n}\n\n.step-status {\n display: flex;\n color: var(--ic-color-secondary-text);\n column-gap: var(--ic-space-xxxs);\n}\n\n.compact-step-completed .step-status {\n color: var(--ic-status-success);\n}\n\n.compact-step-disabled :is(.step-title, .step-status) {\n color: var(--ic-color-tertiary-text);\n}\n\n.step-num {\n color: var(--ic-color-secondary-text);\n white-space: nowrap;\n}\n\n:host(.compact) .step-icon {\n margin: var(--ic-space-xxxs);\n}\n\n:host(.compact) .step-icon svg {\n width: var(--ic-space-md);\n height: var(--ic-space-md);\n}\n\n/* DEFAULT STEP STYLING */\n:host(.default) .step {\n flex-direction: column;\n}\n\n:host(.default.last-step) {\n flex-grow: initial;\n}\n\n.step-top {\n display: flex;\n width: 100%;\n align-items: center;\n align-self: flex-start;\n height: 2.5rem;\n}\n\n:host(.default) .step-icon {\n border-radius: 50%;\n}\n\n.step-icon-inner {\n width: var(--ic-space-xl);\n height: var(--ic-space-xl);\n display: flex;\n justify-content: center;\n align-items: center;\n border-radius: 50%;\n}\n\n:host(.default) .current {\n color: var(--ic-status-info);\n}\n\n:host(.default) .step-title-area {\n margin: var(--ic-space-xs) 0;\n padding-right: var(--ic-space-xs);\n width: 100%;\n}\n\n:host(.default) .step-title,\n.step-subtitle {\n width: fit-content;\n}\n\n.step-subtitle {\n color: var(--ic-color-tertiary-text);\n}\n\n.current .step-subtitle {\n color: var(--ic-color-primary-text);\n}\n\n:host(.default) .completed {\n color: var(--ic-status-success);\n}\n\n.active .step-icon-inner {\n box-shadow: inset var(--ic-architectural-200) 0 0 0 0.125rem;\n}\n\n.current .step-icon-inner {\n background-color: var(--ic-status-info);\n color: white;\n}\n\n.disabled {\n color: var(--ic-architectural-200);\n}\n\n.disabled .step-icon-inner {\n border: var(--ic-space-1px) dashed var(--ic-architectural-200);\n width: calc(var(--ic-space-xl) - var(--ic-space-xxxs));\n height: calc(var(--ic-space-xl) - var(--ic-space-xxxs));\n}\n\n.disabled .step-title-area {\n color: var(--ic-color-tertiary-text);\n}\n\n.completed .step-icon-inner {\n background: var(--ic-status-success);\n box-shadow: inset var(--ic-status-success) 0 0 0 var(--ic-space-xxxs);\n border-radius: 100%;\n}\n\n:host(.default) .current .step-icon {\n border: var(--ic-space-xxxs) solid var(--ic-status-info);\n padding: var(--ic-space-xxxs);\n margin: 0 calc(-1 * var(--ic-space-xxxs));\n\n /* compensating for the circle being bigger than other steps */\n}\n\n.step-connect {\n height: var(--ic-space-xxxs);\n background-color: var(--ic-architectural-200);\n margin: 0 var(--ic-space-xs);\n border-radius: var(--ic-space-xxs);\n width: 100%;\n}\n\n.aligned-full-width.step-connect {\n min-width: 6.25rem;\n width: 100%;\n}\n\n.disabled .step-connect {\n height: 0;\n background-color: rgb(0 0 0 / 0%);\n border-top: 0.125rem dashed var(--ic-architectural-200);\n border-radius: 0;\n}\n\n.completed .step-connect {\n background-color: var(--ic-status-success);\n}\n\n.step-connect-inner {\n width: 70%;\n display: flex;\n flex: auto;\n height: var(--ic-space-xxxs);\n border-radius: var(--ic-space-xxs);\n background-color: var(--ic-status-info);\n}\n\n.step-icon-inner .check-icon {\n padding-top: var(--ic-space-xxs);\n}\n\n.step-icon-inner .check-icon svg {\n width: var(--ic-space-md);\n height: auto;\n}\n\n.step-icon-inner .check-icon > svg > path {\n fill: var(--ic-color-white-text);\n}\n\n/** High Contrast **/\n@media (forced-colors: active) {\n /* COMPACT STEP */\n .compact-step-disabled :is(.step-title, .step-status) {\n color: GrayText;\n }\n\n /* DEFAULT STEP */\n .step-connect:not(.disabled .step-connect) {\n border: var(--ic-hc-border);\n }\n\n .active .step-icon-inner,\n .completed .step-icon-inner,\n .current .step-icon-inner {\n forced-color-adjust: none;\n box-shadow: inset canvastext 0 0 0 0.125rem;\n background-color: transparent;\n color: canvastext;\n }\n\n :host(.default) .current .step-icon {\n padding: 0;\n border: none;\n }\n\n .disabled,\n .disabled .step-title-area {\n color: GrayText;\n }\n\n .step-connect-inner,\n .completed .step-connect {\n background-color: canvastext;\n }\n\n .step-icon-inner .check-icon > svg > path {\n fill: canvastext;\n }\n}\n","import { Component, Host, h, Prop, Element, Watch } from \"@stencil/core\";\nimport checkIcon from \"../../assets/check-icon.svg\";\nimport warningIcon from \"../../assets/warning-icon-outline.svg\";\nimport { IcStepVariants, IcStepStatuses, IcStepTypes } from \"./ic-step.types\";\n\n@Component({\n tag: \"ic-step\",\n styleUrl: \"ic-step.css\",\n shadow: true,\n})\nexport class Step {\n @Element() el: HTMLIcStepElement;\n\n /**\n * @internal If a compact stepper is being used, this sets the styling of the step.\n */\n @Prop() compactStepStyling?: IcStepTypes;\n\n /**\n * @internal If `true`, and a compact stepper is being used, the current step will be the only step in view.\n */\n @Prop({ mutable: true }) current?: boolean = false;\n\n /**\n * @internal If `true`, the step will be marked as being the last one in the series. This is managed by ic-stepper.\n */\n @Prop() lastStep!: boolean;\n\n /**\n * @internal The step number of the final step. This is managed by ic-stepper.\n */\n @Prop() lastStepNum?: number;\n\n /**\n * @internal The name of the next step. This is managed by ic-stepper.\n */\n @Prop() nextStepTitle?: string;\n\n /**\n * @internal The progress of the next step, calculated by dividing the current step number by the total number of steps. This is managed by ic-stepper.\n */\n @Prop() progress?: number;\n\n /**\n * @internal The step number, managed by ic-stepper.\n */\n @Prop() stepNum?: number;\n\n /**\n * The status of the step. Use this prop to display a status message on the step if it is required or optional.\n */\n @Prop() stepStatus?: IcStepStatuses;\n\n /**\n * Additional information about the step. Use this prop to override the default step status messaging displayed when selecting a step type or step status.\n */\n @Prop() stepSubtitle?: string;\n\n /**\n * The title of the step within the stepper.\n */\n @Prop() stepTitle?: string;\n\n /**\n * @internal The variant of the step. This is managed by ic-stepper.\n */\n @Prop() variant!: IcStepVariants;\n\n /**\n * The state of the step within the stepper.\n */\n @Prop() stepType?: IcStepTypes = \"active\";\n\n @Watch(\"stepType\")\n stepTypeChangeHandler(): void {\n if (this.variant === \"compact\" && this.stepType === \"current\") {\n this.current = true;\n } else {\n this.current = false;\n }\n }\n\n render() {\n // ARIA LABEL\n let ariaLabel = \"\";\n\n if (this.stepType === \"completed\") {\n ariaLabel = \". Completed step\";\n } else if (this.stepType === \"disabled\") {\n ariaLabel = \". Non-required step\";\n } else if (this.stepStatus === \"required\") {\n ariaLabel = \". Required step\";\n } else if (this.stepStatus === \"optional\") {\n ariaLabel = \". Optional step\";\n }\n\n // STEP STATUS\n let stepStatus;\n if (this.stepStatus) {\n stepStatus = this.stepStatus[0].toUpperCase() + this.stepStatus.slice(1);\n }\n\n // STEP TYPE\n let stepType;\n if (\n this.stepType === \"disabled\" ||\n this.compactStepStyling === \"disabled\"\n ) {\n stepType = \"Not required\";\n } else if (this.compactStepStyling === \"completed\") {\n stepType = \"Completed\";\n }\n\n // STATUS ICON FOR COMPACT STEP\n let statusIcon;\n if (\n this.stepType === \"completed\" ||\n this.compactStepStyling === \"completed\"\n ) {\n statusIcon = (\n <span\n class=\"check-icon step-icon\"\n aria-hidden=\"true\"\n innerHTML={checkIcon}\n ></span>\n );\n } else if (\n this.stepType === \"disabled\" ||\n this.compactStepStyling === \"disabled\"\n ) {\n statusIcon = (\n <span\n class=\"warning-icon step-icon\"\n aria-hidden=\"true\"\n innerHTML={warningIcon}\n ></span>\n );\n }\n\n // COMPACT STEP COMPONENT\n const compactStep = (\n <div\n class={{\n [\"step\"]: true,\n [\"current\"]: this.current,\n [`compact-step-${this.compactStepStyling}`]:\n !!this.compactStepStyling,\n }}\n >\n <ic-loading-indicator\n class={{\n \"compact-step-progress-indicator\": true,\n \"not-required\":\n this.stepType === \"disabled\" ||\n this.compactStepStyling === \"disabled\",\n }}\n aria-hidden=\"true\"\n size=\"small\"\n inner-label={this.stepNum}\n progress={this.progress}\n ></ic-loading-indicator>\n <div class=\"step-title-area\">\n <ic-typography variant=\"h4\" class=\"step-title\">\n {this.stepTitle}\n </ic-typography>\n <div class=\"info-line\">\n <ic-typography variant=\"caption\" class=\"step-num\">\n {`${this.stepNum} of ${this.lastStepNum}`}\n <span class=\"visually-hidden\"> steps</span>\n </ic-typography>\n {(this.stepSubtitle ||\n this.stepType === \"completed\" ||\n this.stepType === \"disabled\" ||\n (this.variant === \"compact\" &&\n !!this.compactStepStyling &&\n this.compactStepStyling !== \"active\") ||\n !!this.stepStatus) && (\n <div class=\"step-status\">\n {statusIcon !== undefined && statusIcon}\n {(this.stepSubtitle || stepType) && (\n <ic-typography variant=\"caption\">\n {this.stepSubtitle !== null &&\n this.stepSubtitle !== undefined\n ? this.stepSubtitle\n : this.stepType === \"disabled\" ||\n (this.variant === \"compact\" &&\n this.compactStepStyling === \"disabled\") ||\n this.stepType === \"completed\" ||\n (this.variant === \"compact\" &&\n this.compactStepStyling === \"completed\")\n ? stepType\n : this.stepStatus && stepStatus}\n </ic-typography>\n )}\n </div>\n )}\n </div>\n {this.lastStep ? (\n <ic-typography variant=\"subtitle-small\" class=\"next-step\">\n Last step\n </ic-typography>\n ) : (\n this.nextStepTitle !== undefined && (\n <ic-typography variant=\"subtitle-small\" class=\"next-step\">\n Next<span class=\"visually-hidden\"> step is</span>:{\" \"}\n {this.nextStepTitle}\n </ic-typography>\n )\n )}\n </div>\n </div>\n );\n\n // ICON FOR DEFAULT STEP\n let icon;\n if (this.stepType !== \"completed\") {\n icon = (\n <ic-typography variant=\"subtitle-small\">\n <span class=\"step-icon-inner\" aria-hidden=\"true\">\n {this.stepNum}\n </span>\n </ic-typography>\n );\n } else {\n icon = (\n <div class=\"step-icon-inner\" aria-hidden=\"true\">\n <span class=\"check-icon\" innerHTML={checkIcon}></span>\n </div>\n );\n }\n\n // STEP CONNECT FOR DEFAULT STEP\n const partialBar = this.stepType === \"current\" && (\n <div class=\"step-connect-inner\"></div>\n );\n\n const finalStep = !this.lastStep && (\n <div\n class={{\n [\"step-connect\"]: true,\n [\"aligned-full-width\"]:\n this.el.parentElement.classList.contains(\"default\") &&\n !this.el.parentElement.classList.contains(\"aligned-left\"),\n }}\n >\n {partialBar}\n </div>\n );\n\n // DEFAULT STEP COMPONENT\n const defaultStep = (\n <div\n class={{\n [\"step\"]: true,\n [`${this.stepType}`]: true,\n }}\n >\n <div class=\"step-top\">\n <div class=\"step-icon\">{icon}</div>\n {finalStep}\n </div>\n {(this.stepTitle || this.stepSubtitle || this.stepStatus) && (\n <div class=\"step-title-area\">\n {this.stepTitle && (\n <ic-typography variant=\"subtitle-large\" class=\"step-title\">\n {this.stepTitle}\n </ic-typography>\n )}\n {this.stepTitle && (this.stepSubtitle || this.stepStatus) && (\n <ic-typography variant=\"caption\" class=\"step-subtitle\">\n {this.stepSubtitle !== null && this.stepSubtitle !== undefined\n ? this.stepSubtitle\n : stepStatus}\n </ic-typography>\n )}\n </div>\n )}\n </div>\n );\n\n return (\n <Host\n role=\"listitem\"\n aria-label={`Step ${this.stepNum}${ariaLabel}`}\n aria-current={(this.current || this.stepType === \"current\") && \"step\"}\n class={{\n [\"aligned-full-width\"]:\n this.el.parentElement.classList.contains(\"default\") &&\n !this.el.parentElement.classList.contains(\"aligned-left\"),\n [`${this.variant}`]: true,\n }}\n >\n {this.variant === \"compact\" ? compactStep : defaultStep}\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{r as e,h as t,H as i,g as n}from"./p-1af8f256.js";import{l as o,n as s,a,p as r}from"./p-b5c0b75c.js";import{I as l}from"./p-6f57b13c.js";const d='/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0;}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px;}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font-style:inherit;vertical-align:baseline}:host{display:block;margin-right:var(--ic-space-xs);list-style:none}:host(.in-side-menu){margin-right:0}:host::part(button){height:100%}';const p=class{constructor(t){e(this,t);this.inheritedAttributes={};this.initialAppearance=o();this.mode="navbar";this.download=false;this.href=undefined;this.hreflang=undefined;this.label=undefined;this.referrerpolicy=undefined;this.rel=undefined;this.target=undefined}componentWillLoad(){this.inheritedAttributes=s(this.el,[...r,"title"])}componentDidLoad(){a([{prop:this.label,propName:"label"}],"Navigation Button")}navBarMenuOpenHandler(){this.mode="menu"}navBarMenuCloseHandler(){this.mode="navbar"}themeChangeHandler(e){const t=e.detail;this.initialAppearance=t.mode}async setFocus(){if(this.buttonEl){this.buttonEl.focus()}}render(){const{href:e,target:n,rel:o,download:s,referrerpolicy:a}=this;let r="";let d="";let p="icon";let u=this.initialAppearance;let b="large";let c=false;if(this.mode==="menu"){r=this.label;p="tertiary";u=l.Default;b="default";c=true;d="popout-menu-button"}const m={variant:p,appearance:u,size:b,href:e,target:n,rel:o,download:s,referrerpolicy:a,fullWidth:c};return t(i,{class:{["in-side-menu"]:this.mode==="menu"}},t("ic-button",Object.assign({class:d,"aria-label":p=="icon"?this.label:null,ref:e=>this.buttonEl=e},m,this.inheritedAttributes),r,t("slot",{slot:"icon",name:"icon"})))}static get delegatesFocus(){return true}get el(){return n(this)}};p.style=d;export{p as ic_navigation_button};
2
+ //# sourceMappingURL=p-4208e336.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icNavigationButtonCss","NavigationButton","this","inheritedAttributes","getThemeForegroundColor","componentWillLoad","inheritAttributes","el","IC_INHERITED_ARIA","componentDidLoad","onComponentRequiredPropUndefined","prop","label","propName","navBarMenuOpenHandler","mode","navBarMenuCloseHandler","themeChangeHandler","ev","theme","detail","initialAppearance","async","buttonEl","focus","render","href","target","rel","download","referrerpolicy","className","variant","appearance","size","fullWidth","IcThemeForegroundEnum","Default","buttonProps","h","Host","class","Object","assign","ref","slot","name"],"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}\n","import {\n Component,\n Element,\n Host,\n Prop,\n State,\n h,\n Listen,\n Method,\n} from \"@stencil/core\";\n\nimport {\n getThemeForegroundColor,\n inheritAttributes,\n onComponentRequiredPropUndefined,\n} from \"../../utils/helpers\";\nimport { IC_INHERITED_ARIA } from \"../../utils/constants\";\nimport {\n IcTheme,\n IcThemeForeground,\n IcThemeForegroundEnum,\n} from \"../../utils/types\";\nimport { IcNavButtonModes } from \"./ic-navigation-button.types\";\n\n/**\n * @slot icon - Content will be placed to the left of the button label.\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]: unknown } = {};\n\n @Element() el: HTMLIcNavigationButtonElement;\n\n @State() initialAppearance = getThemeForegroundColor();\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 componentWillLoad(): void {\n this.inheritedAttributes = inheritAttributes(this.el, [\n ...IC_INHERITED_ARIA,\n \"title\",\n ]);\n }\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.label, propName: \"label\" }],\n \"Navigation Button\"\n );\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(\"themeChange\", { target: \"document\" })\n themeChangeHandler(ev: CustomEvent): void {\n const theme: IcTheme = ev.detail;\n this.initialAppearance = theme.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 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: IcThemeForeground | IcThemeForegroundEnum.Default =\n this.initialAppearance;\n let size: \"default\" | \"large\" = \"large\";\n let fullWidth = false;\n\n if (this.mode === \"menu\") {\n label = this.label;\n variant = \"tertiary\";\n appearance = IcThemeForegroundEnum.Default;\n size = \"default\";\n fullWidth = true;\n className = \"popout-menu-button\";\n }\n\n const buttonProps = {\n variant,\n appearance,\n size,\n href,\n target,\n rel,\n download,\n referrerpolicy,\n fullWidth,\n };\n\n return (\n <Host class={{ [\"in-side-menu\"]: this.mode === \"menu\" }}>\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 >\n {label}\n <slot slot=\"icon\" name=\"icon\"></slot>\n </ic-button>\n </Host>\n );\n }\n}\n"],"mappings":"iJAAA,MAAMA,EAAwB,4+E,MCmCjBC,EAAgB,M,yBAEnBC,KAAAC,oBAAgD,G,uBAI3BC,I,UAIK,S,cAKI,M,wIAgCtCC,oBACEH,KAAKC,oBAAsBG,EAAkBJ,KAAKK,GAAI,IACjDC,EACH,S,CAIJC,mBACEC,EACE,CAAC,CAAEC,KAAMT,KAAKU,MAAOC,SAAU,UAC/B,oB,CAKJC,wBACEZ,KAAKa,KAAO,M,CAIdC,yBACEd,KAAKa,KAAO,Q,CAIdE,mBAAmBC,GACjB,MAAMC,EAAiBD,EAAGE,OAC1BlB,KAAKmB,kBAAoBF,EAAMJ,I,CAOjCO,iBACE,GAAIpB,KAAKqB,SAAU,CACjBrB,KAAKqB,SAASC,O,EAIlBC,SACE,MAAMC,KAAEA,EAAIC,OAAEA,EAAMC,IAAEA,EAAGC,SAAEA,EAAQC,eAAEA,GAAmB5B,KAExD,IAAIU,EAAQ,GACZ,IAAImB,EAAY,GAChB,IAAIC,EAA+B,OACnC,IAAIC,EACF/B,KAAKmB,kBACP,IAAIa,EAA4B,QAChC,IAAIC,EAAY,MAEhB,GAAIjC,KAAKa,OAAS,OAAQ,CACxBH,EAAQV,KAAKU,MACboB,EAAU,WACVC,EAAaG,EAAsBC,QACnCH,EAAO,UACPC,EAAY,KACZJ,EAAY,oB,CAGd,MAAMO,EAAc,CAClBN,UACAC,aACAC,OACAR,OACAC,SACAC,MACAC,WACAC,iBACAK,aAGF,OACEI,EAACC,EAAI,CAACC,MAAO,CAAE,CAAC,gBAAiBvC,KAAKa,OAAS,SAC7CwB,EAAA,YAAAG,OAAAC,OAAA,CACEF,MAAOV,EAAS,aACJC,GAAW,OAAS9B,KAAKU,MAAQ,KAC7CgC,IAAMrC,GAAQL,KAAKqB,SAAWhB,GAC1B+B,EACApC,KAAKC,qBAERS,EACD2B,EAAA,QAAMM,KAAK,OAAOC,KAAK,U"}
@@ -0,0 +1,2 @@
1
+ const t=`<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">\n <path d="M0 0h24v24H0z" fill="none"/>\n <path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/>\n <title>close icon</title>\n</svg>\n`;export{t as c};
2
+ //# sourceMappingURL=p-44512ebe.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sources":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ import{r as t,h as i,H as a,g as s}from"./p-1af8f256.js";import{a as e,O as r,P as l,Q as n,R as o,N as c}from"./p-b5c0b75c.js";import{a as p}from"./p-6f57b13c.js";const h="ic-input-label{margin-bottom:var(--ic-space-xs)}ic-input-label.with-helper{margin-bottom:var(--ic-space-xxxs)}ic-input-label.readonly{color:var(--ic-color-tertiary-text)}ic-input-label .helpertext{margin-top:var(--ic-space-xxxs)}ic-input-label .helpertext-normal{color:var(--ic-color-secondary-text)}ic-input-label .helpertext-readonly{color:var(--ic-color-tertiary-text)}ic-input-label .readonly-label{color:var(--ic-color-secondary-text)}ic-input-label .error-label{color:var(--ic-status-error)}ic-input-label .dark{color:var(--ic-architectural-white)}";const d=class{constructor(i){t(this,i);this.dark=false;this.disabled=false;this.error=false;this.for=undefined;this.helperText="";this.label=undefined;this.readonly=false;this.required=false}componentDidLoad(){e([{prop:this.label,propName:"label"}],"Input Label")}render(){const{disabled:t,readonly:s,label:e,required:l,helperText:n,error:o,dark:c}=this;const p=l?e+" *":e;const h=s?`${p}`:i("label",{htmlFor:this.for},p);const d=r(this.for);return i(a,{class:{["disabled"]:t,["readonly"]:s,["with-helper"]:n!==""}},i("ic-typography",{variant:"label",class:{["readonly-label"]:s,["error-label"]:o&&!(s||t),["dark"]:c}},h),n!==""&&i("ic-typography",{variant:"caption",class:{["helpertext"]:true,["helpertext-normal"]:!t&&!s,["helpertext-readonly"]:s}},i("span",{id:d},n)))}};d.style=h;const u="ic-input-validation{width:var(--input-width, 20rem);margin-top:var(--ic-space-xs);display:flex}ic-input-validation.fullwidth{width:100%}ic-input-validation span.status-icon{padding-right:var(--ic-space-xxs)}ic-input-validation span.status-icon>svg{height:1.25rem;width:1.25rem}ic-input-validation span.icon-success>svg{fill:var(--ic-status-success)}ic-input-validation span.icon-error>svg{fill:var(--ic-status-error)}ic-input-validation span.icon-warning>svg{fill:var(--ic-status-warning)}ic-input-validation .statustext{flex-grow:1}";const v={[p.Warning]:n,[p.Error]:o,[p.Success]:c};const b=class{constructor(i){t(this,i);this.ariaLiveMode="polite";this.for=undefined;this.fullWidth=false;this.message=undefined;this.status=""}componentDidLoad(){e([{prop:this.message,propName:"message"}],"Input Validation")}render(){const t=this.status!==""?v[this.status]:"";const s=l(this.for);return i(a,{class:{[this.status]:this.status!=="",["fullwidth"]:this.fullWidth}},t!==""&&i("span",{class:{["status-icon"]:true,[`icon-${this.status}`]:true},innerHTML:t}),i("ic-typography",{variant:"caption",class:"statustext"},i("span",{"aria-live":this.ariaLiveMode,id:s},this.message)),i("slot",{name:"validation-message-adornment"}))}get el(){return s(this)}};b.style=u;export{d as ic_input_label,b as ic_input_validation};
2
+ //# sourceMappingURL=p-4ddbc685.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icInputLabelCss","InputLabel","componentDidLoad","onComponentRequiredPropUndefined","prop","this","label","propName","render","disabled","readonly","required","helperText","error","dark","labelText","labelContent","h","htmlFor","for","id","getInputHelperTextID","Host","class","variant","icInputValidationCss","icon","IcInformationStatus","Warning","warningIcon","Error","errorIcon","Success","successIcon","InputValidation","message","displayIcon","status","getInputValidationTextID","fullWidth","innerHTML","ariaLiveMode","name"],"sources":["./src/components/ic-input-label/ic-input-label.css?tag=ic-input-label","./src/components/ic-input-label/ic-input-label.tsx","./src/components/ic-input-validation/ic-input-validation.css?tag=ic-input-validation","./src/components/ic-input-validation/ic-input-validation.tsx"],"sourcesContent":["ic-input-label {\n margin-bottom: var(--ic-space-xs);\n}\n\nic-input-label.with-helper {\n margin-bottom: var(--ic-space-xxxs);\n}\n\nic-input-label.readonly {\n color: var(--ic-color-tertiary-text);\n}\n\nic-input-label .helpertext {\n margin-top: var(--ic-space-xxxs);\n}\n\nic-input-label .helpertext-normal {\n color: var(--ic-color-secondary-text);\n}\n\nic-input-label .helpertext-readonly {\n color: var(--ic-color-tertiary-text);\n}\n\nic-input-label .readonly-label {\n color: var(--ic-color-secondary-text);\n}\n\nic-input-label .error-label {\n color: var(--ic-status-error);\n}\n\nic-input-label .dark {\n color: var(--ic-architectural-white);\n}\n","import { Component, Host, Prop, h } from \"@stencil/core\";\n\nimport {\n getInputHelperTextID,\n onComponentRequiredPropUndefined,\n} from \"../../utils/helpers\";\n\n@Component({\n tag: \"ic-input-label\",\n styleUrl: \"./ic-input-label.css\",\n})\nexport class InputLabel {\n /**\n * If `true`, the dark variant of the input label will be displayed.\n */\n @Prop() dark?: boolean = false;\n\n /**\n * If `true`, the disabled state will be set.\n */\n @Prop() disabled: boolean = false;\n\n /**\n * If `true`, the input label will display with error styling.\n */\n @Prop() error?: boolean = false;\n\n /**\n * The ID of the form element the label is bound to.\n */\n @Prop() for: string;\n\n /**\n * The helper text that will be displayed.\n */\n @Prop() helperText: string = \"\";\n\n /**\n * The text content of the label.\n */\n @Prop() label!: string;\n\n /**\n * If `true`, the readonly state will be set.\n */\n @Prop() readonly: boolean = false;\n\n /**\n * If `true`, the input label will require a value.\n */\n @Prop() required: boolean = false;\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.label, propName: \"label\" }],\n \"Input Label\"\n );\n }\n\n render() {\n const { disabled, readonly, label, required, helperText, error, dark } =\n this;\n const labelText = required ? label + \" *\" : label;\n const labelContent = readonly ? (\n `${labelText}`\n ) : (\n <label htmlFor={this.for}>{labelText}</label>\n );\n\n const id = getInputHelperTextID(this.for);\n\n return (\n <Host\n class={{\n [\"disabled\"]: disabled,\n [\"readonly\"]: readonly,\n [\"with-helper\"]: helperText !== \"\",\n }}\n >\n <ic-typography\n variant=\"label\"\n class={{\n [\"readonly-label\"]: readonly,\n [\"error-label\"]: error && !(readonly || disabled),\n [\"dark\"]: dark,\n }}\n >\n {labelContent}\n </ic-typography>\n\n {helperText !== \"\" && (\n <ic-typography\n variant=\"caption\"\n class={{\n [\"helpertext\"]: true,\n [\"helpertext-normal\"]: !disabled && !readonly,\n [\"helpertext-readonly\"]: readonly,\n }}\n >\n <span id={id}>{helperText}</span>\n </ic-typography>\n )}\n </Host>\n );\n }\n}\n","ic-input-validation {\n width: var(--input-width, 20rem);\n margin-top: var(--ic-space-xs);\n display: flex;\n}\n\nic-input-validation.fullwidth {\n width: 100%;\n}\n\nic-input-validation span.status-icon {\n padding-right: var(--ic-space-xxs);\n}\n\nic-input-validation span.status-icon > svg {\n height: 1.25rem;\n width: 1.25rem;\n}\n\nic-input-validation span.icon-success > svg {\n fill: var(--ic-status-success);\n}\n\nic-input-validation span.icon-error > svg {\n fill: var(--ic-status-error);\n}\n\nic-input-validation span.icon-warning > svg {\n fill: var(--ic-status-warning);\n}\n\nic-input-validation .statustext {\n flex-grow: 1;\n}\n","import { Element, Component, Host, Prop, h } from \"@stencil/core\";\n\nimport {\n IcInformationStatus,\n IcInformationStatusOrEmpty,\n} from \"../../utils/types\";\nimport errorIcon from \"../../assets/error-icon.svg\";\nimport successIcon from \"../../assets/success-icon.svg\";\nimport warningIcon from \"../../assets/warning-icon.svg\";\n\nimport {\n getInputValidationTextID,\n onComponentRequiredPropUndefined,\n} from \"../../utils/helpers\";\nimport { IcAriaLiveModeVariants } from \"./ic-input-validation.types\";\n\nconst icon = {\n [IcInformationStatus.Warning]: warningIcon,\n [IcInformationStatus.Error]: errorIcon,\n [IcInformationStatus.Success]: successIcon,\n};\n\n/**\n * @slot validation-message-adornment - Content will be placed to the right of the validation message.\n */\n@Component({\n tag: \"ic-input-validation\",\n styleUrl: \"ic-input-validation.css\",\n})\nexport class InputValidation {\n @Element() el: HTMLIcInputValidationElement;\n\n /**\n * The ARIA live mode to apply to the message.\n */\n @Prop() ariaLiveMode: IcAriaLiveModeVariants = \"polite\";\n\n /**\n * The ID of the form element the validation is bound to.\n */\n @Prop() for: string;\n\n /**\n * If `true`, the input validation will fill the width of the container.\n */\n @Prop() fullWidth: boolean = false;\n\n /**\n * The validation message to display.\n */\n @Prop() message!: string;\n\n /**\n * The status of the validation - e.g. 'error' | 'warning' | 'success'.\n */\n @Prop() status: IcInformationStatusOrEmpty = \"\";\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.message, propName: \"message\" }],\n \"Input Validation\"\n );\n }\n\n render() {\n const displayIcon = this.status !== \"\" ? icon[this.status] : \"\";\n const id = getInputValidationTextID(this.for);\n return (\n <Host\n class={{\n [this.status]: this.status !== \"\",\n [\"fullwidth\"]: this.fullWidth,\n }}\n >\n {displayIcon !== \"\" && (\n <span\n class={{\n [\"status-icon\"]: true,\n [`icon-${this.status}`]: true,\n }}\n innerHTML={displayIcon}\n />\n )}\n\n <ic-typography variant=\"caption\" class=\"statustext\">\n <span aria-live={this.ariaLiveMode} id={id}>\n {this.message}\n </span>\n </ic-typography>\n\n <slot name=\"validation-message-adornment\"></slot>\n </Host>\n );\n }\n}\n"],"mappings":"oKAAA,MAAMA,EAAkB,6iB,MCWXC,EAAU,M,mCAII,M,cAKG,M,WAKF,M,mCAUG,G,mCAUD,M,cAKA,K,CAE5BC,mBACEC,EACE,CAAC,CAAEC,KAAMC,KAAKC,MAAOC,SAAU,UAC/B,c,CAIJC,SACE,MAAMC,SAAEA,EAAQC,SAAEA,EAAQJ,MAAEA,EAAKK,SAAEA,EAAQC,WAAEA,EAAUC,MAAEA,EAAKC,KAAEA,GAC9DT,KACF,MAAMU,EAAYJ,EAAWL,EAAQ,KAAOA,EAC5C,MAAMU,EAAeN,EAAQ,GACxBK,IAEHE,EAAA,SAAOC,QAASb,KAAKc,KAAMJ,GAG7B,MAAMK,EAAKC,EAAqBhB,KAAKc,KAErC,OACEF,EAACK,EAAI,CACHC,MAAO,CACL,CAAC,YAAad,EACd,CAAC,YAAaC,EACd,CAAC,eAAgBE,IAAe,KAGlCK,EAAA,iBACEO,QAAQ,QACRD,MAAO,CACL,CAAC,kBAAmBb,EACpB,CAAC,eAAgBG,KAAWH,GAAYD,GACxC,CAAC,QAASK,IAGXE,GAGFJ,IAAe,IACdK,EAAA,iBACEO,QAAQ,UACRD,MAAO,CACL,CAAC,cAAe,KAChB,CAAC,sBAAuBd,IAAaC,EACrC,CAAC,uBAAwBA,IAG3BO,EAAA,QAAMG,GAAIA,GAAKR,I,aCnG3B,MAAMa,EAAuB,whBCgB7B,MAAMC,EAAO,CACX,CAACC,EAAoBC,SAAUC,EAC/B,CAACF,EAAoBG,OAAQC,EAC7B,CAACJ,EAAoBK,SAAUC,G,MAUpBC,EAAe,M,2CAMqB,S,kCAUlB,M,mCAUgB,E,CAE7ChC,mBACEC,EACE,CAAC,CAAEC,KAAMC,KAAK8B,QAAS5B,SAAU,YACjC,mB,CAIJC,SACE,MAAM4B,EAAc/B,KAAKgC,SAAW,GAAKX,EAAKrB,KAAKgC,QAAU,GAC7D,MAAMjB,EAAKkB,EAAyBjC,KAAKc,KACzC,OACEF,EAACK,EAAI,CACHC,MAAO,CACL,CAAClB,KAAKgC,QAAShC,KAAKgC,SAAW,GAC/B,CAAC,aAAchC,KAAKkC,YAGrBH,IAAgB,IACfnB,EAAA,QACEM,MAAO,CACL,CAAC,eAAgB,KACjB,CAAC,QAAQlB,KAAKgC,UAAW,MAE3BG,UAAWJ,IAIfnB,EAAA,iBAAeO,QAAQ,UAAUD,MAAM,cACrCN,EAAA,oBAAiBZ,KAAKoC,aAAcrB,GAAIA,GACrCf,KAAK8B,UAIVlB,EAAA,QAAMyB,KAAK,iC"}
@@ -0,0 +1,2 @@
1
+ import{r as t,c as i,h as e,H as s,g as o}from"./p-1af8f256.js";import{c as a}from"./p-44512ebe.js";import{i as n,V as r,a as c,H as d}from"./p-b5c0b75c.js";import{I as l}from"./p-6f57b13c.js";const h='/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0;}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px;}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font-style:inherit;vertical-align:baseline}:host{--bottom-position:var(--ic-space-xl);position:fixed;bottom:var(--bottom-position);left:50%;transform:translate(-50%);animation:fadein var(--ic-transition-duration-slow) ease-in-out;z-index:var(--ic-z-index-toast)}:host(.hidden){display:none;animation:fadeout var(--ic-transition-duration-slow) ease-in-out}.container{max-width:32.5rem;min-width:18rem;box-shadow:var(--ic-elevation-overlay);min-height:3.5rem;background-color:var(--ic-architectural-800);color:var(--ic-color-white-text);display:flex;align-items:center;position:relative;border-radius:var(--ic-border-radius)}.toast-icon-container{height:100%;display:flex;align-items:center}.divider{height:100%;width:var(--ic-space-xs);position:absolute;border-radius:var(--ic-space-xxxs) 0 0 var(--ic-space-xxxs)}.divider-neutral{background-color:var(--ic-status-unknown)}.divider-info{background-color:var(--ic-status-info-contrast)}.divider-warning{background-color:var(--ic-status-warning-contrast)}.divider-error{background-color:var(--ic-status-error-contrast)}.divider-success{background-color:var(--ic-status-success-contrast)}.toast-icon,::slotted(svg){height:var(--ic-space-lg);width:var(--ic-space-lg);margin-left:var(--ic-space-md)}:host([variant="neutral"]) .toast-icon svg,::slotted(svg){fill:var(--ic-status-unknown)}:host([variant="info"]) .toast-icon svg{fill:var(--ic-status-info-contrast)}:host([variant="warning"]) .toast-icon svg{fill:var(--ic-status-warning-contrast)}:host([variant="error"]) .toast-icon svg{fill:var(--ic-status-error-contrast)}:host([variant="success"]) .toast-icon svg{fill:var(--ic-status-success-contrast)}.toast-content{margin-left:var(--ic-space-xs);width:100%}.no-icon{margin-left:var(--ic-space-md)}.toast-message{padding:var(--ic-space-xs) var(--ic-space-xs) var(--ic-space-xs) 0}.toast-action-container{padding-bottom:var(--ic-space-md)}ic-button,.toast-dismiss-timer{padding:var(--ic-space-xs)}@media (max-width: 576px){:host{--bottom-position:var(--ic-space-lg);width:calc(100% - 2 * var(--ic-space-md))}}@media (min-width: 993px){:host{--bottom-position:calc(var(--ic-space-xl) + var(--ic-space-xs))}}@media (forced-colors: active){.container{border:var(--ic-hc-border)}}@keyframes fadein{from{bottom:0;opacity:0}to{bottom:var(--bottom-position);opacity:1}}@keyframes fadeout{from{bottom:var(--bottom-position);opacity:1}to{bottom:0;opacity:0}}';const u=1e3;const m=70;const p=140;const b=class{constructor(e){t(this,e);this.icDismiss=i(this,"icDismiss",7);this.interactiveElements=[];this.dismissAction=()=>{this.icDismiss.emit()};this.handleProgressChange=()=>{this.timerProgress-=u/this.autoDismissTimeout*100};this.timerProgress=100;this.visible=false;this.autoDismissTimeout=5e3;this.dismissButtonAriaLabel="dismiss";this.dismissMode="manual";this.heading=undefined;this.message=undefined;this.neutralIconAriaLabel=undefined;this.variant=undefined}disconnectedCallback(){window.clearTimeout(this.dismissTimeout);window.clearInterval(this.timerRefreshInterval)}componentWillLoad(){var t,i;this.handleLongText(this.heading.length>m,((t=this.message)===null||t===void 0?void 0:t.length)>p);if(this.autoDismissTimeout<5e3)this.autoDismissTimeout=5e3;if(n(this.el,"action"))this.dismissMode="manual";this.isManual=this.dismissMode==="manual";if(n(this.el,"neutral-icon"))this.variant="neutral";if(this.variant==="neutral"){this.neutralVariantLabel=(i=this.neutralIconAriaLabel)!==null&&i!==void 0?i:r[this.variant].ariaLabel}if(this.isManual){this.el.setAttribute("aria-label",this.variant?this.neutralVariantLabel||r[this.variant].ariaLabel:this.heading);(this.variant||this.message)&&this.el.setAttribute("aria-description",this.variant?`${this.heading}${this.message!==undefined?`. ${this.message}`:""}`:this.message)}}componentDidLoad(){c([{prop:this.heading,propName:"heading"}],"Toast");const t=d(this.el,"action");const i=this.el.shadowRoot.querySelector("ic-button");if(t)this.interactiveElements.push(t);if(i)this.interactiveElements.push(i)}handleDismiss(){this.visible=false;clearInterval(this.timerRefreshInterval);this.timerProgress=100}handleKeyboard(t){if(this.isManual&&this.visible){switch(t.key){case"Tab":t.preventDefault();this.findNextInteractiveElement(t.shiftKey).setFocus();break;case"Escape":!t.repeat&&this.dismissAction();t.stopImmediatePropagation();break}}}handleTimer(t){if(!this.isManual){switch(t.type){case"mouseenter":window.clearTimeout(this.dismissTimeout);window.clearInterval(this.timerRefreshInterval);this.timerProgress=100;break;case"mouseleave":this.dismissTimeout=window.setTimeout(this.dismissAction,this.autoDismissTimeout);this.timerRefreshInterval=window.setInterval(this.handleProgressChange,u);break}}}async setVisible(){if(!this.visible)this.visible=true;if(!this.isManual){this.dismissTimeout=window.setTimeout(this.dismissAction,this.autoDismissTimeout);this.timerRefreshInterval=window.setInterval(this.handleProgressChange,u);return null}else{window.setTimeout((()=>this.interactiveElements[0].setFocus()),200);return document.activeElement}}handleLongText(t,i){if(i||t){console.error(`Too many characters in toast ${t?"heading":""}${t&&i?" and ":""}${i?"message":""}. Refer to character limits specified in the prop description`)}}findNextInteractiveElement(t){const i=this.interactiveElements[0];const e=this.interactiveElements[this.interactiveElements.length-1];const s=t?i:e;const o=t?e:i;if(this.isActive(s))return o;let a;const n=this.interactiveElements.some(((t,i)=>{if(!this.isActive(t))return false;a=i;return true}));if(!n)return i;return this.interactiveElements[a+(t?-1:1)]}isActive(t){if(t===this.el)return!!this.el.shadowRoot.activeElement;return document.activeElement===t}render(){const{variant:t,heading:i,message:o,visible:c,isManual:d,dismissButtonAriaLabel:h}=this;return e(s,{class:{["hidden"]:!c},role:d?"dialog":"status"},e("div",{class:"container"},t&&c&&e("div",{class:"toast-icon-container"},e("div",{class:{["divider"]:true,[`divider-${t}`]:true}}),t==="neutral"?e("slot",{name:"neutral-icon"}):e("span",{class:"toast-icon",innerHTML:r[t].icon})),e("div",{class:{["toast-content"]:true,["no-icon"]:t==="neutral"&&!n(this.el,"neutral-icon")}},e("div",{class:"toast-message"},e("ic-typography",{variant:"subtitle-large"},c&&e("h5",null,i)),o&&e("ic-typography",{variant:"body"},c&&e("p",null,o))),n(this.el,"action")&&e("div",{class:"toast-action-container"},e("slot",{name:"action"}))),!d?e("ic-loading-indicator",{class:"toast-dismiss-timer",appearance:"light",size:"icon",progress:this.timerProgress}):e("ic-button",{id:"dismiss-button",innerHTML:a,onClick:this.dismissAction,variant:"icon",appearance:l.Light,"aria-label":h})))}get el(){return o(this)}};b.style=h;export{b as ic_toast};
2
+ //# sourceMappingURL=p-4efac9a5.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icToastCss","AUTO_DISMISS_TIMER_REFRESH_RATE_MS","TOAST_HEADING_CHAR_LIMIT","TOAST_MESSAGE_CHAR_LIMIT","Toast","this","interactiveElements","dismissAction","icDismiss","emit","handleProgressChange","timerProgress","autoDismissTimeout","disconnectedCallback","window","clearTimeout","dismissTimeout","clearInterval","timerRefreshInterval","componentWillLoad","handleLongText","heading","length","_a","message","isSlotUsed","el","dismissMode","isManual","variant","neutralVariantLabel","_b","neutralIconAriaLabel","VARIANT_ICONS","ariaLabel","setAttribute","undefined","componentDidLoad","onComponentRequiredPropUndefined","prop","propName","actionContent","getSlot","dismissButton","shadowRoot","querySelector","push","handleDismiss","visible","handleKeyboard","ev","key","preventDefault","findNextInteractiveElement","shiftKey","setFocus","repeat","stopImmediatePropagation","handleTimer","type","setTimeout","setInterval","async","document","activeElement","headingTooLong","messageTooLong","console","error","isBackwards","first","last","source","target","isActive","currentIndex","found","some","index","targetEl","render","dismissButtonAriaLabel","h","Host","class","role","name","innerHTML","icon","appearance","size","progress","id","closeIcon","onClick","IcThemeForegroundEnum","Light"],"sources":["./src/components/ic-toast/ic-toast.css?tag=ic-toast&encapsulation=shadow","./src/components/ic-toast/ic-toast.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n/**\n * @prop --ic-z-index-toast: z-index of toast\n */\n\n:host {\n --bottom-position: var(--ic-space-xl);\n\n position: fixed;\n bottom: var(--bottom-position);\n left: 50%;\n transform: translate(-50%);\n animation: fadein var(--ic-transition-duration-slow) ease-in-out;\n z-index: var(--ic-z-index-toast);\n}\n\n:host(.hidden) {\n display: none;\n animation: fadeout var(--ic-transition-duration-slow) ease-in-out;\n}\n\n.container {\n max-width: 32.5rem;\n min-width: 18rem;\n box-shadow: var(--ic-elevation-overlay);\n min-height: 3.5rem;\n background-color: var(--ic-architectural-800);\n color: var(--ic-color-white-text);\n display: flex;\n align-items: center;\n position: relative;\n border-radius: var(--ic-border-radius);\n}\n\n.toast-icon-container {\n height: 100%;\n display: flex;\n align-items: center;\n}\n\n.divider {\n height: 100%;\n width: var(--ic-space-xs);\n position: absolute;\n border-radius: var(--ic-space-xxxs) 0 0 var(--ic-space-xxxs);\n}\n\n.divider-neutral {\n background-color: var(--ic-status-unknown);\n}\n\n.divider-info {\n background-color: var(--ic-status-info-contrast);\n}\n\n.divider-warning {\n background-color: var(--ic-status-warning-contrast);\n}\n\n.divider-error {\n background-color: var(--ic-status-error-contrast);\n}\n\n.divider-success {\n background-color: var(--ic-status-success-contrast);\n}\n\n.toast-icon,\n::slotted(svg) {\n height: var(--ic-space-lg);\n width: var(--ic-space-lg);\n margin-left: var(--ic-space-md);\n}\n\n:host([variant=\"neutral\"]) .toast-icon svg,\n::slotted(svg) {\n fill: var(--ic-status-unknown);\n}\n\n:host([variant=\"info\"]) .toast-icon svg {\n fill: var(--ic-status-info-contrast);\n}\n\n:host([variant=\"warning\"]) .toast-icon svg {\n fill: var(--ic-status-warning-contrast);\n}\n\n:host([variant=\"error\"]) .toast-icon svg {\n fill: var(--ic-status-error-contrast);\n}\n\n:host([variant=\"success\"]) .toast-icon svg {\n fill: var(--ic-status-success-contrast);\n}\n\n.toast-content {\n margin-left: var(--ic-space-xs);\n width: 100%;\n}\n\n.no-icon {\n margin-left: var(--ic-space-md);\n}\n\n.toast-message {\n padding: var(--ic-space-xs) var(--ic-space-xs) var(--ic-space-xs) 0;\n}\n\n.toast-action-container {\n padding-bottom: var(--ic-space-md);\n}\n\nic-button,\n.toast-dismiss-timer {\n padding: var(--ic-space-xs);\n}\n\n@media (max-width: 576px) {\n :host {\n --bottom-position: var(--ic-space-lg);\n\n width: calc(100% - 2 * var(--ic-space-md));\n }\n}\n\n@media (min-width: 993px) {\n :host {\n --bottom-position: calc(var(--ic-space-xl) + var(--ic-space-xs));\n }\n}\n\n@media (forced-colors: active) {\n .container {\n border: var(--ic-hc-border);\n }\n}\n\n@keyframes fadein {\n from {\n bottom: 0;\n opacity: 0;\n }\n\n to {\n bottom: var(--bottom-position);\n opacity: 1;\n }\n}\n\n@keyframes fadeout {\n from {\n bottom: var(--bottom-position);\n opacity: 1;\n }\n\n to {\n bottom: 0;\n opacity: 0;\n }\n}\n","import {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Listen,\n Method,\n Prop,\n State,\n} from \"@stencil/core\";\nimport closeIcon from \"../../assets/close-icon.svg\";\nimport { VARIANT_ICONS } from \"../../utils/constants\";\nimport {\n getSlot,\n isSlotUsed,\n onComponentRequiredPropUndefined,\n} from \"../../utils/helpers\";\nimport {\n IcActivationTypes,\n IcStatusVariants,\n IcThemeForegroundEnum,\n} from \"../../utils/types\";\nimport { ActionAreaElementTypes } from \"./ic-toast.types\";\n\nconst AUTO_DISMISS_TIMER_REFRESH_RATE_MS = 1000;\nconst TOAST_HEADING_CHAR_LIMIT = 70;\nconst TOAST_MESSAGE_CHAR_LIMIT = 140;\n\n/**\n * @slot action - IcButton or IcLink is placed below header and message. If used will default toast to manual `dismiss` type.\n * @slot neutral-icon - A custom neutral icon is placed on the left side of the component. If used will default toast to `neutral` variant.\n */\n@Component({\n tag: \"ic-toast\",\n styleUrl: \"ic-toast.css\",\n shadow: true,\n})\nexport class Toast {\n private dismissTimeout: number;\n private interactiveElements: ActionAreaElementTypes[] = [];\n private isManual: boolean;\n private neutralVariantLabel: string;\n private timerRefreshInterval: number;\n\n @Element() el: HTMLIcToastElement;\n\n @State() timerProgress = 100;\n @State() visible = false;\n\n /**\n * If toast dismissMode is set to `automatic`, use this prop to define the time before the toast dismisses (in MILLISECONDS)\n * (NOTE: Has a minimum value of `5000ms`)\n */\n @Prop({ mutable: true }) autoDismissTimeout? = 5000;\n\n /**\n * If toast can be manually dismissed, this prop sets a custom aria-label for the ic-button component\n */\n @Prop() dismissButtonAriaLabel? = \"dismiss\";\n\n /**\n * How the toast will be dismissed. If manual will display a dismiss button.\n */\n @Prop({ mutable: true }) dismissMode?: IcActivationTypes = \"manual\";\n\n /**\n * The title to display at the start of the toast. (NOTE: Should be no more than `70` characters)\n */\n @Prop() heading!: string;\n\n /**\n * The main body message of the toast. (NOTE: Should be no more than `140` characters)\n */\n @Prop() message?: string;\n\n /**\n * Provides a custom alt-text to be announced to screen readers, if slotting a custom neutral icon\n */\n @Prop() neutralIconAriaLabel?: string;\n\n /**\n * The variant of the toast being rendered\n */\n @Prop({ mutable: true }) variant?: IcStatusVariants;\n\n /**\n * Is emitted when the user dismisses the toast\n */\n @Event() icDismiss: EventEmitter<void>;\n\n disconnectedCallback(): void {\n window.clearTimeout(this.dismissTimeout);\n window.clearInterval(this.timerRefreshInterval);\n }\n\n componentWillLoad(): void {\n this.handleLongText(\n this.heading.length > TOAST_HEADING_CHAR_LIMIT,\n this.message?.length > TOAST_MESSAGE_CHAR_LIMIT\n );\n\n if (this.autoDismissTimeout < 5000) this.autoDismissTimeout = 5000;\n\n if (isSlotUsed(this.el, \"action\")) this.dismissMode = \"manual\";\n this.isManual = this.dismissMode === \"manual\";\n\n if (isSlotUsed(this.el, \"neutral-icon\")) this.variant = \"neutral\";\n if (this.variant === \"neutral\") {\n this.neutralVariantLabel =\n this.neutralIconAriaLabel ?? VARIANT_ICONS[this.variant].ariaLabel;\n }\n\n if (this.isManual) {\n this.el.setAttribute(\n \"aria-label\",\n this.variant\n ? this.neutralVariantLabel || VARIANT_ICONS[this.variant].ariaLabel\n : this.heading\n );\n (this.variant || this.message) &&\n this.el.setAttribute(\n \"aria-description\",\n this.variant\n ? `${this.heading}${\n this.message !== undefined ? `. ${this.message}` : \"\"\n }`\n : this.message\n );\n }\n }\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.heading, propName: \"heading\" }],\n \"Toast\"\n );\n const actionContent = getSlot(this.el, \"action\") as ActionAreaElementTypes;\n const dismissButton = this.el.shadowRoot.querySelector(\"ic-button\");\n if (actionContent) this.interactiveElements.push(actionContent);\n if (dismissButton) this.interactiveElements.push(dismissButton);\n }\n\n @Listen(\"icDismiss\", { capture: true })\n handleDismiss(): void {\n this.visible = false;\n clearInterval(this.timerRefreshInterval);\n this.timerProgress = 100;\n }\n\n @Listen(\"keydown\", { target: \"document\" })\n handleKeyboard(ev: KeyboardEvent): void {\n if (this.isManual && this.visible) {\n switch (ev.key) {\n case \"Tab\":\n ev.preventDefault();\n this.findNextInteractiveElement(ev.shiftKey).setFocus();\n break;\n case \"Escape\":\n !ev.repeat && this.dismissAction();\n ev.stopImmediatePropagation();\n break;\n }\n }\n }\n\n @Listen(\"mouseenter\")\n @Listen(\"mouseleave\")\n handleTimer(ev: MouseEvent): void {\n if (!this.isManual) {\n switch (ev.type) {\n case \"mouseenter\":\n window.clearTimeout(this.dismissTimeout);\n window.clearInterval(this.timerRefreshInterval);\n this.timerProgress = 100;\n break;\n case \"mouseleave\":\n this.dismissTimeout = window.setTimeout(\n this.dismissAction,\n this.autoDismissTimeout\n );\n this.timerRefreshInterval = window.setInterval(\n this.handleProgressChange,\n AUTO_DISMISS_TIMER_REFRESH_RATE_MS\n );\n break;\n }\n }\n }\n\n /**\n * Used to display the individual toast\n * @returns The element that previously had focus before the toast appeared\n */\n @Method()\n async setVisible(): Promise<HTMLElement> {\n if (!this.visible) this.visible = true;\n if (!this.isManual) {\n this.dismissTimeout = window.setTimeout(\n this.dismissAction,\n this.autoDismissTimeout\n );\n this.timerRefreshInterval = window.setInterval(\n this.handleProgressChange,\n AUTO_DISMISS_TIMER_REFRESH_RATE_MS\n );\n return null;\n } else {\n window.setTimeout(() => this.interactiveElements[0].setFocus(), 200);\n return document.activeElement as HTMLElement;\n }\n }\n\n private dismissAction = (): void => {\n this.icDismiss.emit();\n };\n\n private handleProgressChange = () => {\n this.timerProgress -=\n (AUTO_DISMISS_TIMER_REFRESH_RATE_MS / this.autoDismissTimeout) * 100;\n };\n\n private handleLongText(\n headingTooLong: boolean,\n messageTooLong?: boolean\n ): void {\n if (messageTooLong || headingTooLong) {\n console.error(\n `Too many characters in toast ${headingTooLong ? \"heading\" : \"\"}${\n headingTooLong && messageTooLong ? \" and \" : \"\"\n }${\n messageTooLong ? \"message\" : \"\"\n }. Refer to character limits specified in the prop description`\n );\n }\n }\n\n private findNextInteractiveElement(\n isBackwards: boolean\n ): ActionAreaElementTypes {\n const first = this.interactiveElements[0];\n const last = this.interactiveElements[this.interactiveElements.length - 1];\n\n const source = isBackwards ? first : last;\n const target = isBackwards ? last : first;\n if (this.isActive(source)) return target;\n\n let currentIndex: number;\n const found = this.interactiveElements.some((el, index) => {\n if (!this.isActive(el)) return false;\n currentIndex = index;\n return true;\n });\n\n if (!found) return first;\n return this.interactiveElements[currentIndex + (isBackwards ? -1 : 1)];\n }\n\n private isActive(targetEl: HTMLElement): boolean {\n if (targetEl === this.el) return !!this.el.shadowRoot.activeElement;\n return document.activeElement === targetEl;\n }\n\n render() {\n const {\n variant,\n heading,\n message,\n visible,\n isManual,\n dismissButtonAriaLabel,\n } = this;\n return (\n <Host\n class={{ [\"hidden\"]: !visible }}\n role={isManual ? \"dialog\" : \"status\"}\n >\n <div class=\"container\">\n {variant && visible && (\n <div class=\"toast-icon-container\">\n <div\n class={{\n [\"divider\"]: true,\n [`divider-${variant}`]: true,\n }}\n ></div>\n {variant === \"neutral\" ? (\n <slot name=\"neutral-icon\" />\n ) : (\n <span\n class=\"toast-icon\"\n innerHTML={VARIANT_ICONS[variant].icon}\n ></span>\n )}\n </div>\n )}\n <div\n class={{\n [\"toast-content\"]: true,\n [\"no-icon\"]:\n variant === \"neutral\" && !isSlotUsed(this.el, \"neutral-icon\"),\n }}\n >\n <div class=\"toast-message\">\n <ic-typography variant=\"subtitle-large\">\n {visible && <h5>{heading}</h5>}\n </ic-typography>\n {message && (\n <ic-typography variant=\"body\">\n {visible && <p>{message}</p>}\n </ic-typography>\n )}\n </div>\n {isSlotUsed(this.el, \"action\") && (\n <div class=\"toast-action-container\">\n <slot name=\"action\" />\n </div>\n )}\n </div>\n {!isManual ? (\n <ic-loading-indicator\n class=\"toast-dismiss-timer\"\n appearance=\"light\"\n size=\"icon\"\n progress={this.timerProgress}\n ></ic-loading-indicator>\n ) : (\n <ic-button\n id=\"dismiss-button\"\n innerHTML={closeIcon}\n onClick={this.dismissAction}\n variant=\"icon\"\n appearance={IcThemeForegroundEnum.Light}\n aria-label={dismissButtonAriaLabel}\n ></ic-button>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{r as t,h as i,H as e,g as o}from"./p-1af8f256.js";import{c as a}from"./p-b5c0b75c.js";import"./p-6f57b13c.js";const r='/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0;}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px;}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font-style:inherit;vertical-align:baseline}:host{display:block;position:relative}:host(.ic-typography-vertical-margins-h1){margin:0 0 var(--ic-space-xl)}:host(.ic-typography-vertical-margins-h2){margin:var(--ic-space-xxl) 0 var(--ic-space-lg)}:host(.ic-typography-vertical-margins-h3){margin:var(--ic-space-xl) 0 var(--ic-space-md)}:host(.ic-typography-vertical-margins-h4){margin:var(--ic-space-lg) 0 var(--ic-space-md)}:host(.ic-typography-vertical-margins-subtitle-large),:host(.ic-typography-vertical-margins-subtitle-small),:host(.ic-typography-vertical-margins-body),:host(.ic-typography-vertical-margins-code-large),:host(.ic-typography-vertical-margins-code-small),:host(.ic-typography-vertical-margins-code-extra-small){margin:0 0 var(--ic-space-md)}:host(.ic-typography-vertical-margins-caption),:host(.ic-typography-vertical-margins-caption-uppercase){margin:0 0 var(--ic-space-xs)}:host(.ic-typography-vertical-margins-h2:first-child),:host(.ic-typography-vertical-margins-h3:first-child),:host(.ic-typography-vertical-margins-h4:first-child){margin-top:0}:host(.ic-typography-h1){font:var(--ic-font-h1) !important}:host(.ic-typography-h2){font:var(--ic-font-h2) !important;letter-spacing:var(--ic-font-letter-spacing-0pt0025)}:host(.ic-typography-h3){font:var(--ic-font-h3)}:host(.ic-typography-h4){font:var(--ic-font-h4) !important;letter-spacing:var(--ic-font-letter-spacing-0pt0015)}:host(.ic-typography-subtitle-large){font:var(--ic-font-subtitle-large) !important;letter-spacing:var(--ic-font-letter-spacing-0pt0015)}:host(.ic-typography-subtitle-small){font:var(--ic-font-subtitle-small) !important;letter-spacing:var(--ic-font-letter-spacing-0pt0015)}:host(.ic-typography-body){font:var(--ic-font-body);letter-spacing:var(--ic-font-letter-spacing-0pt005)}:host(.ic-typography-caption){font:var(--ic-font-caption) !important;letter-spacing:var(--ic-font-letter-spacing-0pt0025)}:host(.ic-typography-caption-uppercase){font:var(--ic-font-caption) !important;letter-spacing:var(--ic-font-letter-spacing-0pt0025);text-transform:uppercase}:host(.ic-typography-label){font:var(--ic-font-label) !important;letter-spacing:var(--ic-font-letter-spacing-0pt025)}:host(.ic-typography-label-uppercase){font:var(--ic-font-label) !important;letter-spacing:var(--ic-font-letter-spacing-0pt025);text-transform:uppercase}:host(.ic-typography-code-large){font:var(--ic-font-code-large);letter-spacing:var(--ic-font-letter-spacing-0pt025)}:host(.ic-typography-code-small){font:var(--ic-font-code-small) !important;letter-spacing:var(--ic-font-letter-spacing-0pt005)}:host(.ic-typography-code-extra-small){font:var(--ic-font-code-extra-small) !important;letter-spacing:var(--ic-font-letter-spacing-0pt025)}:host(.ic-typography-no-wrap){white-space:nowrap}:host ::slotted(h1),:host ::slotted(h2),:host ::slotted(h3),:host ::slotted(h4),:host ::slotted(h5),:host ::slotted(h6),:host ::slotted(p),:host ::slotted(label){font:inherit;letter-spacing:inherit}.trunc-wrapper{display:-webkit-box;-webkit-box-orient:vertical;line-clamp:var(--truncation-max-lines, initial);-webkit-line-clamp:var(--truncation-max-lines, initial);overflow:hidden}.trunc-btn{border:none;background:none;padding:0;color:var(--ic-color-primary-text);text-decoration:underline;font-weight:var(--ic-font-weight-bold);transition:var(--ic-easing-transition-fast)}.trunc-btn:hover,.trunc-btn.focus{outline:none;border-bottom:var(--ic-space-xxs) solid !important;margin-bottom:calc(-1 * var(--ic-space-xxs)) !important;text-decoration:none;cursor:pointer}:host(.strikethrough){text-decoration:line-through}:host(.underline){text-decoration:underline}:host(.underline.strikethrough){text-decoration:line-through underline}:host(.italic){font-style:italic !important}:host(.bold){font-weight:var(--ic-font-weight-bold)}@supports (text-decoration-thickness: 25%){.trunc-btn:hover,.trunc-btn.focus{text-decoration-line:underline;text-decoration-thickness:25%;text-underline-offset:25%;border-bottom:0 !important;margin-bottom:0 !important}}';const s=class{constructor(i){t(this,i);this.focusBtnFromKeyboard=true;this.lastMarkerTop=0;this.lastWidth=0;this.resizeObserver=null;this.truncatedHeight=0;this.toggleExpanded=()=>{this.expanded=!this.expanded};this.checkMaxLines=t=>{const i=Math.floor(t/24);if(i>this.maxLines){this.el.setAttribute("style",`--truncation-max-lines: ${this.maxLines}`);this.truncatedHeight=this.el.clientHeight;this.truncated=true}};this.checkMarkerPosition=(t,i)=>{if(i-t<this.truncatedHeight){this.truncated=false;this.expanded=false}else{this.truncated=true}};this.getElementTop=t=>t.getClientRects?t.getClientRects()[0].top:0;this.runResizeObserver=()=>{this.resizeObserver=new ResizeObserver((()=>{clearTimeout(this.resizeInterval);this.resizeInterval=window.setTimeout(this.resizeObserverCallback,50)}));this.resizeObserver.observe(this.truncWrapperEl)};this.resizeObserverCallback=()=>{if(this.lastWidth===this.el.clientWidth){return}if(this.truncatedHeight===0){this.checkMaxLines(this.el.clientHeight);return}const t=this.getElementTop(this.marker);if(t===this.lastMarkerTop){return}this.checkMarkerPosition(this.getElementTop(this.el),t);this.lastMarkerTop=t;this.lastWidth=this.el.clientWidth};this.truncButtonFocus=()=>{if(this.focusBtnFromKeyboard){this.truncButtonFocussed=true}};this.truncButtonBlur=()=>{this.focusBtnFromKeyboard=true;this.truncButtonFocussed=false};this.truncButtonFocusFromMouse=()=>{this.focusBtnFromKeyboard=false};this.truncated=false;this.truncButtonFocussed=false;this.applyVerticalMargins=false;this.bold=false;this.italic=false;this.maxLines=undefined;this.strikethrough=false;this.underline=false;this.variant="body";this.expanded=false}watchExpandedHandler(){this.el.setAttribute("style",`--truncation-max-lines: ${this.expanded?"initial":this.maxLines}`)}disconnectedCallback(){if(this.resizeObserver!==null){this.resizeObserver.disconnect()}}componentDidLoad(){if(this.variant==="body"&&this.maxLines>0){const t=document.createElement("span");t.style.visibility="hidden";this.el.appendChild(t);this.marker=t;this.lastWidth=this.el.clientWidth;this.checkMaxLines(this.el.clientHeight);a(this.runResizeObserver)}}render(){const{variant:t,applyVerticalMargins:o,maxLines:a,truncated:r,expanded:s,strikethrough:n,underline:c,italic:l,bold:h}=this;return i(e,{class:{[`ic-typography-${t}`]:true,[`ic-typography-vertical-margins-${t}`]:o,["bold"]:h,["italic"]:l,["strikethrough"]:n,["underline"]:c}},t==="body"&&a>0?i("div",{class:"trunc-wrapper",ref:t=>this.truncWrapperEl=t},i("slot",null)):i("slot",null),t==="body"&&a>0&&r&&i("button",{class:{"trunc-btn":true,focus:this.truncButtonFocussed},onFocus:this.truncButtonFocus,onBlur:this.truncButtonBlur,onMouseDown:this.truncButtonFocusFromMouse,onClick:this.toggleExpanded,"aria-hidden":"true"},s?"See less":"See more"))}get el(){return o(this)}static get watchers(){return{expanded:["watchExpandedHandler"]}}};s.style=r;export{s as ic_typography};
2
+ //# sourceMappingURL=p-5278461f.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["icTypographyCss","Typography","this","focusBtnFromKeyboard","lastMarkerTop","lastWidth","resizeObserver","truncatedHeight","toggleExpanded","expanded","checkMaxLines","height","numLines","Math","floor","maxLines","el","setAttribute","clientHeight","truncated","checkMarkerPosition","elTop","markerTop","getElementTop","getClientRects","top","runResizeObserver","ResizeObserver","clearTimeout","resizeInterval","window","setTimeout","resizeObserverCallback","observe","truncWrapperEl","clientWidth","marker","truncButtonFocus","truncButtonFocussed","truncButtonBlur","truncButtonFocusFromMouse","watchExpandedHandler","disconnectedCallback","disconnect","componentDidLoad","variant","document","createElement","style","visibility","appendChild","checkResizeObserver","render","applyVerticalMargins","strikethrough","underline","italic","bold","h","Host","class","ref","focus","onFocus","onBlur","onMouseDown","onClick"],"sources":["./src/components/ic-typography/ic-typography.css?tag=ic-typography&encapsulation=shadow","./src/components/ic-typography/ic-typography.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n:host {\n display: block;\n position: relative;\n}\n\n:host(.ic-typography-vertical-margins-h1) {\n margin: 0 0 var(--ic-space-xl);\n}\n\n:host(.ic-typography-vertical-margins-h2) {\n margin: var(--ic-space-xxl) 0 var(--ic-space-lg);\n}\n\n:host(.ic-typography-vertical-margins-h3) {\n margin: var(--ic-space-xl) 0 var(--ic-space-md);\n}\n\n:host(.ic-typography-vertical-margins-h4) {\n margin: var(--ic-space-lg) 0 var(--ic-space-md);\n}\n\n:host(.ic-typography-vertical-margins-subtitle-large),\n:host(.ic-typography-vertical-margins-subtitle-small),\n:host(.ic-typography-vertical-margins-body),\n:host(.ic-typography-vertical-margins-code-large),\n:host(.ic-typography-vertical-margins-code-small),\n:host(.ic-typography-vertical-margins-code-extra-small) {\n margin: 0 0 var(--ic-space-md);\n}\n\n:host(.ic-typography-vertical-margins-caption),\n:host(.ic-typography-vertical-margins-caption-uppercase) {\n margin: 0 0 var(--ic-space-xs);\n}\n\n:host(.ic-typography-vertical-margins-h2:first-child),\n:host(.ic-typography-vertical-margins-h3:first-child),\n:host(.ic-typography-vertical-margins-h4:first-child) {\n margin-top: 0;\n}\n\n:host(.ic-typography-h1) {\n font: var(--ic-font-h1) !important;\n}\n\n:host(.ic-typography-h2) {\n font: var(--ic-font-h2) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt0025);\n}\n\n:host(.ic-typography-h3) {\n font: var(--ic-font-h3);\n}\n\n:host(.ic-typography-h4) {\n font: var(--ic-font-h4) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt0015);\n}\n\n:host(.ic-typography-subtitle-large) {\n font: var(--ic-font-subtitle-large) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt0015);\n}\n\n:host(.ic-typography-subtitle-small) {\n font: var(--ic-font-subtitle-small) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt0015);\n}\n\n:host(.ic-typography-body) {\n font: var(--ic-font-body);\n letter-spacing: var(--ic-font-letter-spacing-0pt005);\n}\n\n:host(.ic-typography-caption) {\n font: var(--ic-font-caption) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt0025);\n}\n\n:host(.ic-typography-caption-uppercase) {\n font: var(--ic-font-caption) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt0025);\n text-transform: uppercase;\n}\n\n:host(.ic-typography-label) {\n font: var(--ic-font-label) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt025);\n}\n\n:host(.ic-typography-label-uppercase) {\n font: var(--ic-font-label) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt025);\n text-transform: uppercase;\n}\n\n:host(.ic-typography-code-large) {\n font: var(--ic-font-code-large);\n letter-spacing: var(--ic-font-letter-spacing-0pt025);\n}\n\n:host(.ic-typography-code-small) {\n font: var(--ic-font-code-small) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt005);\n}\n\n:host(.ic-typography-code-extra-small) {\n font: var(--ic-font-code-extra-small) !important;\n letter-spacing: var(--ic-font-letter-spacing-0pt025);\n}\n\n:host(.ic-typography-no-wrap) {\n white-space: nowrap;\n}\n\n:host ::slotted(h1),\n:host ::slotted(h2),\n:host ::slotted(h3),\n:host ::slotted(h4),\n:host ::slotted(h5),\n:host ::slotted(h6),\n:host ::slotted(p),\n:host ::slotted(label) {\n font: inherit;\n letter-spacing: inherit;\n}\n\n.trunc-wrapper {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n line-clamp: var(--truncation-max-lines, initial);\n -webkit-line-clamp: var(--truncation-max-lines, initial);\n overflow: hidden;\n}\n\n.trunc-btn {\n border: none;\n background: none;\n padding: 0;\n color: var(--ic-color-primary-text);\n text-decoration: underline;\n font-weight: var(--ic-font-weight-bold);\n transition: var(--ic-easing-transition-fast);\n}\n\n.trunc-btn:hover,\n.trunc-btn.focus {\n outline: none;\n border-bottom: var(--ic-space-xxs) solid !important;\n margin-bottom: calc(-1 * var(--ic-space-xxs)) !important;\n text-decoration: none;\n cursor: pointer;\n}\n\n:host(.strikethrough) {\n text-decoration: line-through;\n}\n\n:host(.underline) {\n text-decoration: underline;\n}\n\n:host(.underline.strikethrough) {\n text-decoration: line-through underline;\n}\n\n:host(.italic) {\n font-style: italic !important;\n}\n\n:host(.bold) {\n font-weight: var(--ic-font-weight-bold);\n}\n\n@supports (text-decoration-thickness: 25%) {\n .trunc-btn:hover,\n .trunc-btn.focus {\n text-decoration-line: underline;\n text-decoration-thickness: 25%;\n text-underline-offset: 25%;\n border-bottom: 0 !important;\n margin-bottom: 0 !important;\n }\n}\n","import { Component, Prop, h, Element, Host, State, Watch } from \"@stencil/core\";\n\nimport { IcTypographyVariants } from \"../../utils/types\";\nimport { checkResizeObserver } from \"../../utils/helpers\";\n\n@Component({\n styleUrl: \"ic-typography.css\",\n tag: \"ic-typography\",\n shadow: true,\n})\nexport class Typography {\n private focusBtnFromKeyboard: boolean = true;\n private lastMarkerTop: number = 0;\n private lastWidth: number = 0;\n private marker: HTMLElement;\n private resizeInterval: number;\n private resizeObserver: ResizeObserver = null;\n private truncatedHeight: number = 0;\n private truncWrapperEl: Element;\n\n @Element() el: HTMLIcTypographyElement;\n\n @State() truncated: boolean = false;\n @State() truncButtonFocussed: boolean = false;\n\n /**\n * If `true`, appropriate top and bottom margins will be applied to the typography.\n */\n @Prop() applyVerticalMargins?: boolean = false;\n\n /**\n * If `true`, the typography will have a bold font weight. Note: This will only take affect on h3, body and code-large variants.\n */\n @Prop() bold?: boolean = false;\n\n /**\n * If `true`, the typography will have an italic font style.\n */\n @Prop() italic?: boolean = false;\n\n /**\n * The number of lines to display before truncating the text, only used for the 'body' variant.\n */\n @Prop() maxLines?: number;\n\n /**\n * If `true`, the typography will have a line through it.\n */\n @Prop() strikethrough?: boolean = false;\n\n /**\n * If `true`, the typography will have a line under it.\n */\n @Prop() underline?: boolean = false;\n\n /**\n * The ICDS typography style to use.\n */\n @Prop() variant?: IcTypographyVariants = \"body\";\n\n @State() expanded: boolean = false;\n\n @Watch(\"expanded\")\n watchExpandedHandler(): void {\n this.el.setAttribute(\n \"style\",\n `--truncation-max-lines: ${this.expanded ? \"initial\" : this.maxLines}`\n );\n }\n\n disconnectedCallback(): void {\n if (this.resizeObserver !== null) {\n this.resizeObserver.disconnect();\n }\n }\n\n componentDidLoad(): void {\n if (this.variant === \"body\" && this.maxLines > 0) {\n const marker = document.createElement(\"span\");\n marker.style.visibility = \"hidden\";\n this.el.appendChild(marker);\n this.marker = marker;\n this.lastWidth = this.el.clientWidth;\n this.checkMaxLines(this.el.clientHeight);\n checkResizeObserver(this.runResizeObserver);\n }\n }\n\n private toggleExpanded = () => {\n this.expanded = !this.expanded;\n };\n\n private checkMaxLines = (height: number) => {\n //24 is the height of a single line\n const numLines = Math.floor(height / 24);\n if (numLines > this.maxLines) {\n this.el.setAttribute(\"style\", `--truncation-max-lines: ${this.maxLines}`);\n this.truncatedHeight = this.el.clientHeight;\n this.truncated = true;\n }\n };\n\n private checkMarkerPosition = (elTop: number, markerTop: number) => {\n if (markerTop - elTop < this.truncatedHeight) {\n this.truncated = false;\n this.expanded = false;\n } else {\n this.truncated = true;\n }\n };\n\n private getElementTop = (el: HTMLElement) => {\n return el.getClientRects ? el.getClientRects()[0].top : 0;\n };\n\n private runResizeObserver = () => {\n this.resizeObserver = new ResizeObserver(() => {\n clearTimeout(this.resizeInterval);\n this.resizeInterval = window.setTimeout(this.resizeObserverCallback, 50);\n });\n this.resizeObserver.observe(this.truncWrapperEl);\n };\n\n private resizeObserverCallback = () => {\n if (this.lastWidth === this.el.clientWidth) {\n return;\n }\n\n if (this.truncatedHeight === 0) {\n this.checkMaxLines(this.el.clientHeight);\n return;\n }\n\n const markerTop = this.getElementTop(this.marker);\n if (markerTop === this.lastMarkerTop) {\n return;\n }\n\n this.checkMarkerPosition(this.getElementTop(this.el), markerTop);\n this.lastMarkerTop = markerTop;\n this.lastWidth = this.el.clientWidth;\n };\n\n private truncButtonFocus = (): void => {\n if (this.focusBtnFromKeyboard) {\n this.truncButtonFocussed = true;\n }\n };\n\n private truncButtonBlur = (): void => {\n this.focusBtnFromKeyboard = true;\n this.truncButtonFocussed = false;\n };\n\n private truncButtonFocusFromMouse = (): void => {\n this.focusBtnFromKeyboard = false;\n };\n\n render() {\n const {\n variant,\n applyVerticalMargins,\n maxLines,\n truncated,\n expanded,\n strikethrough,\n underline,\n italic,\n bold,\n } = this;\n\n return (\n <Host\n class={{\n [`ic-typography-${variant}`]: true,\n [`ic-typography-vertical-margins-${variant}`]: applyVerticalMargins,\n [\"bold\"]: bold,\n [\"italic\"]: italic,\n [\"strikethrough\"]: strikethrough,\n [\"underline\"]: underline,\n }}\n >\n {variant === \"body\" && maxLines > 0 ? (\n <div class=\"trunc-wrapper\" ref={(el) => (this.truncWrapperEl = el)}>\n <slot />\n </div>\n ) : (\n <slot />\n )}\n {variant === \"body\" && maxLines > 0 && truncated && (\n <button\n class={{ \"trunc-btn\": true, focus: this.truncButtonFocussed }}\n onFocus={this.truncButtonFocus}\n onBlur={this.truncButtonBlur}\n onMouseDown={this.truncButtonFocusFromMouse}\n onClick={this.toggleExpanded}\n aria-hidden=\"true\"\n >\n {expanded ? \"See less\" : \"See more\"}\n </button>\n )}\n </Host>\n );\n }\n}\n"],"mappings":"qHAAA,MAAMA,EAAkB,wtM,MCUXC,EAAU,M,yBACbC,KAAAC,qBAAgC,KAChCD,KAAAE,cAAwB,EACxBF,KAAAG,UAAoB,EAGpBH,KAAAI,eAAiC,KACjCJ,KAAAK,gBAA0B,EAuE1BL,KAAAM,eAAiB,KACvBN,KAAKO,UAAYP,KAAKO,QAAQ,EAGxBP,KAAAQ,cAAiBC,IAEvB,MAAMC,EAAWC,KAAKC,MAAMH,EAAS,IACrC,GAAIC,EAAWV,KAAKa,SAAU,CAC5Bb,KAAKc,GAAGC,aAAa,QAAS,2BAA2Bf,KAAKa,YAC9Db,KAAKK,gBAAkBL,KAAKc,GAAGE,aAC/BhB,KAAKiB,UAAY,I,GAIbjB,KAAAkB,oBAAsB,CAACC,EAAeC,KAC5C,GAAIA,EAAYD,EAAQnB,KAAKK,gBAAiB,CAC5CL,KAAKiB,UAAY,MACjBjB,KAAKO,SAAW,K,KACX,CACLP,KAAKiB,UAAY,I,GAIbjB,KAAAqB,cAAiBP,GAChBA,EAAGQ,eAAiBR,EAAGQ,iBAAiB,GAAGC,IAAM,EAGlDvB,KAAAwB,kBAAoB,KAC1BxB,KAAKI,eAAiB,IAAIqB,gBAAe,KACvCC,aAAa1B,KAAK2B,gBAClB3B,KAAK2B,eAAiBC,OAAOC,WAAW7B,KAAK8B,uBAAwB,GAAG,IAE1E9B,KAAKI,eAAe2B,QAAQ/B,KAAKgC,eAAe,EAG1ChC,KAAA8B,uBAAyB,KAC/B,GAAI9B,KAAKG,YAAcH,KAAKc,GAAGmB,YAAa,CAC1C,M,CAGF,GAAIjC,KAAKK,kBAAoB,EAAG,CAC9BL,KAAKQ,cAAcR,KAAKc,GAAGE,cAC3B,M,CAGF,MAAMI,EAAYpB,KAAKqB,cAAcrB,KAAKkC,QAC1C,GAAId,IAAcpB,KAAKE,cAAe,CACpC,M,CAGFF,KAAKkB,oBAAoBlB,KAAKqB,cAAcrB,KAAKc,IAAKM,GACtDpB,KAAKE,cAAgBkB,EACrBpB,KAAKG,UAAYH,KAAKc,GAAGmB,WAAW,EAG9BjC,KAAAmC,iBAAmB,KACzB,GAAInC,KAAKC,qBAAsB,CAC7BD,KAAKoC,oBAAsB,I,GAIvBpC,KAAAqC,gBAAkB,KACxBrC,KAAKC,qBAAuB,KAC5BD,KAAKoC,oBAAsB,KAAK,EAG1BpC,KAAAsC,0BAA4B,KAClCtC,KAAKC,qBAAuB,KAAK,E,eArIL,M,yBACU,M,0BAKC,M,UAKhB,M,YAKE,M,2CAUO,M,eAKJ,M,aAKW,O,cAEZ,K,CAG7BsC,uBACEvC,KAAKc,GAAGC,aACN,QACA,2BAA2Bf,KAAKO,SAAW,UAAYP,KAAKa,W,CAIhE2B,uBACE,GAAIxC,KAAKI,iBAAmB,KAAM,CAChCJ,KAAKI,eAAeqC,Y,EAIxBC,mBACE,GAAI1C,KAAK2C,UAAY,QAAU3C,KAAKa,SAAW,EAAG,CAChD,MAAMqB,EAASU,SAASC,cAAc,QACtCX,EAAOY,MAAMC,WAAa,SAC1B/C,KAAKc,GAAGkC,YAAYd,GACpBlC,KAAKkC,OAASA,EACdlC,KAAKG,UAAYH,KAAKc,GAAGmB,YACzBjC,KAAKQ,cAAcR,KAAKc,GAAGE,cAC3BiC,EAAoBjD,KAAKwB,kB,EA0E7B0B,SACE,MAAMP,QACJA,EAAOQ,qBACPA,EAAoBtC,SACpBA,EAAQI,UACRA,EAASV,SACTA,EAAQ6C,cACRA,EAAaC,UACbA,EAASC,OACTA,EAAMC,KACNA,GACEvD,KAEJ,OACEwD,EAACC,EAAI,CACHC,MAAO,CACL,CAAC,iBAAiBf,KAAY,KAC9B,CAAC,kCAAkCA,KAAYQ,EAC/C,CAAC,QAASI,EACV,CAAC,UAAWD,EACZ,CAAC,iBAAkBF,EACnB,CAAC,aAAcC,IAGhBV,IAAY,QAAU9B,EAAW,EAChC2C,EAAA,OAAKE,MAAM,gBAAgBC,IAAM7C,GAAQd,KAAKgC,eAAiBlB,GAC7D0C,EAAA,cAGFA,EAAA,aAEDb,IAAY,QAAU9B,EAAW,GAAKI,GACrCuC,EAAA,UACEE,MAAO,CAAE,YAAa,KAAME,MAAO5D,KAAKoC,qBACxCyB,QAAS7D,KAAKmC,iBACd2B,OAAQ9D,KAAKqC,gBACb0B,YAAa/D,KAAKsC,0BAClB0B,QAAShE,KAAKM,eAAc,cAChB,QAEXC,EAAW,WAAa,Y"}