@ukic/web-components 2.1.0-beta.1 → 2.1.0-beta.10

Sign up to get free protection for your applications and to get access to all the features.
Files changed (817) hide show
  1. package/README.md +8 -0
  2. package/dist/cjs/OpenInNew-f9958725.js +7 -0
  3. package/dist/cjs/OpenInNew-f9958725.js.map +1 -0
  4. package/dist/cjs/{check-icon-999d9877.js → check-icon-b2f60716.js} +2 -2
  5. package/dist/cjs/check-icon-b2f60716.js.map +1 -0
  6. package/dist/cjs/{chevron-icon-d175fe66.js → chevron-icon-2645d6b0.js} +2 -2
  7. package/dist/cjs/chevron-icon-2645d6b0.js.map +1 -0
  8. package/dist/cjs/core.cjs.js +2 -2
  9. package/dist/cjs/{helpers-8bc3b6d2.js → helpers-6eb26e7a.js} +76 -3
  10. package/dist/cjs/helpers-6eb26e7a.js.map +1 -0
  11. package/dist/cjs/ic-alert.cjs.entry.js +6 -25
  12. package/dist/cjs/ic-alert.cjs.entry.js.map +1 -1
  13. package/dist/cjs/ic-back-to-top.cjs.entry.js +24 -12
  14. package/dist/cjs/ic-back-to-top.cjs.entry.js.map +1 -1
  15. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +2 -2
  16. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js.map +1 -1
  17. package/dist/cjs/ic-breadcrumb.cjs.entry.js +14 -5
  18. package/dist/cjs/ic-breadcrumb.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ic-button_3.cjs.entry.js +39 -29
  20. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  21. package/dist/cjs/ic-card.cjs.entry.js +29 -5
  22. package/dist/cjs/ic-card.cjs.entry.js.map +1 -1
  23. package/dist/cjs/ic-checkbox-group.cjs.entry.js +4 -4
  24. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ic-checkbox.cjs.entry.js +16 -4
  26. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -1
  27. package/dist/cjs/ic-chip.cjs.entry.js +77 -0
  28. package/dist/cjs/ic-chip.cjs.entry.js.map +1 -0
  29. package/dist/cjs/ic-classification-banner.cjs.entry.js +3 -3
  30. package/dist/cjs/ic-classification-banner.cjs.entry.js.map +1 -1
  31. package/dist/cjs/ic-data-entity.cjs.entry.js +2 -2
  32. package/dist/cjs/ic-data-entity.cjs.entry.js.map +1 -1
  33. package/dist/cjs/ic-data-row.cjs.entry.js +14 -12
  34. package/dist/cjs/ic-data-row.cjs.entry.js.map +1 -1
  35. package/dist/cjs/ic-divider.cjs.entry.js +3 -3
  36. package/dist/cjs/ic-divider.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ic-footer-link-group.cjs.entry.js +4 -3
  38. package/dist/cjs/ic-footer-link-group.cjs.entry.js.map +1 -1
  39. package/dist/cjs/ic-footer-link.cjs.entry.js +12 -5
  40. package/dist/cjs/ic-footer-link.cjs.entry.js.map +1 -1
  41. package/dist/cjs/ic-footer.cjs.entry.js +5 -5
  42. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -1
  43. package/dist/cjs/ic-hero.cjs.entry.js +3 -3
  44. package/dist/cjs/ic-hero.cjs.entry.js.map +1 -1
  45. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +158 -0
  46. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js.map +1 -0
  47. package/dist/cjs/ic-input-component-container_3.cjs.entry.js +71 -41
  48. package/dist/cjs/ic-input-component-container_3.cjs.entry.js.map +1 -1
  49. package/dist/cjs/ic-input-label_2.cjs.entry.js +6 -8
  50. package/dist/cjs/ic-input-label_2.cjs.entry.js.map +1 -1
  51. package/dist/cjs/ic-link.cjs.entry.js +14 -8
  52. package/dist/cjs/ic-link.cjs.entry.js.map +1 -1
  53. package/dist/cjs/ic-navigation-button.cjs.entry.js +5 -4
  54. package/dist/cjs/ic-navigation-button.cjs.entry.js.map +1 -1
  55. package/dist/cjs/ic-navigation-group.cjs.entry.js +6 -5
  56. package/dist/cjs/ic-navigation-group.cjs.entry.js.map +1 -1
  57. package/dist/cjs/ic-navigation-item.cjs.entry.js +18 -11
  58. package/dist/cjs/ic-navigation-item.cjs.entry.js.map +1 -1
  59. package/dist/cjs/ic-navigation-menu.cjs.entry.js +8 -8
  60. package/dist/cjs/ic-navigation-menu.cjs.entry.js.map +1 -1
  61. package/dist/cjs/ic-page-header.cjs.entry.js +5 -5
  62. package/dist/cjs/ic-page-header.cjs.entry.js.map +1 -1
  63. package/dist/cjs/ic-radio-group.cjs.entry.js +13 -5
  64. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -1
  65. package/dist/cjs/ic-radio-option.cjs.entry.js +24 -6
  66. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  67. package/dist/cjs/ic-search-bar.cjs.entry.js +53 -41
  68. package/dist/cjs/ic-search-bar.cjs.entry.js.map +1 -1
  69. package/dist/cjs/ic-section-container.cjs.entry.js +2 -2
  70. package/dist/cjs/ic-section-container.cjs.entry.js.map +1 -1
  71. package/dist/cjs/ic-select.cjs.entry.js +206 -59
  72. package/dist/cjs/ic-select.cjs.entry.js.map +1 -1
  73. package/dist/cjs/ic-side-navigation.cjs.entry.js +24 -12
  74. package/dist/cjs/ic-side-navigation.cjs.entry.js.map +1 -1
  75. package/dist/cjs/ic-skeleton.cjs.entry.js +2 -2
  76. package/dist/cjs/ic-skeleton.cjs.entry.js.map +1 -1
  77. package/dist/cjs/ic-status-tag.cjs.entry.js +6 -5
  78. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -1
  79. package/dist/cjs/ic-step.cjs.entry.js +103 -15
  80. package/dist/cjs/ic-step.cjs.entry.js.map +1 -1
  81. package/dist/cjs/ic-stepper.cjs.entry.js +166 -42
  82. package/dist/cjs/ic-stepper.cjs.entry.js.map +1 -1
  83. package/dist/cjs/ic-switch.cjs.entry.js +12 -3
  84. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  85. package/dist/cjs/ic-tab-context.cjs.entry.js +7 -2
  86. package/dist/cjs/ic-tab-context.cjs.entry.js.map +1 -1
  87. package/dist/cjs/ic-tab-group.cjs.entry.js +9 -118
  88. package/dist/cjs/ic-tab-group.cjs.entry.js.map +1 -1
  89. package/dist/cjs/ic-tab-panel.cjs.entry.js +2 -2
  90. package/dist/cjs/ic-tab-panel.cjs.entry.js.map +1 -1
  91. package/dist/cjs/ic-tab.cjs.entry.js +10 -2
  92. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -1
  93. package/dist/cjs/ic-text-field.cjs.entry.js +5 -5
  94. package/dist/cjs/ic-text-field.cjs.entry.js.map +1 -1
  95. package/dist/cjs/ic-theme.cjs.entry.js +4 -4
  96. package/dist/cjs/ic-theme.cjs.entry.js.map +1 -1
  97. package/dist/cjs/ic-toast-region.cjs.entry.js +48 -0
  98. package/dist/cjs/ic-toast-region.cjs.entry.js.map +1 -0
  99. package/dist/cjs/ic-toast.cjs.entry.js +165 -0
  100. package/dist/cjs/ic-toast.cjs.entry.js.map +1 -0
  101. package/dist/cjs/ic-top-navigation.cjs.entry.js +15 -10
  102. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -1
  103. package/dist/cjs/ic-typography.cjs.entry.js +1 -1
  104. package/dist/cjs/ic-typography.cjs.entry.js.map +1 -1
  105. package/dist/cjs/{index-3ef30d9d.js → index-f79a4e53.js} +21 -2
  106. package/dist/cjs/index-f79a4e53.js.map +1 -0
  107. package/dist/cjs/loader.cjs.js +2 -2
  108. package/dist/cjs/types-3eb02246.js.map +1 -1
  109. package/dist/collection/assets/back-icon.svg +1 -1
  110. package/dist/collection/assets/check-icon.svg +1 -1
  111. package/dist/collection/assets/chevron-icon.svg +1 -1
  112. package/dist/collection/assets/dismiss-icon.svg +3 -0
  113. package/dist/collection/assets/error-icon.svg +3 -3
  114. package/dist/collection/assets/info-icon.svg +3 -3
  115. package/dist/collection/assets/neutral-icon.svg +3 -3
  116. package/dist/collection/assets/success-icon.svg +3 -3
  117. package/dist/collection/assets/warning-icon-outline.svg +3 -0
  118. package/dist/collection/assets/warning-icon.svg +3 -3
  119. package/dist/collection/collection-manifest.json +4 -0
  120. package/dist/collection/components/ic-alert/ic-alert.css +13 -13
  121. package/dist/collection/components/ic-alert/ic-alert.js +32 -24
  122. package/dist/collection/components/ic-alert/ic-alert.js.map +1 -1
  123. package/dist/collection/components/ic-back-to-top/assets/ArrowUpward.svg +2 -2
  124. package/dist/collection/components/ic-back-to-top/ic-back-to-top.css +18 -8
  125. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js +18 -7
  126. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js.map +1 -1
  127. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.css +1 -1
  128. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js +33 -4
  129. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js.map +1 -1
  130. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js +2 -2
  131. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js.map +1 -1
  132. package/dist/collection/components/ic-button/ic-button.css +16 -15
  133. package/dist/collection/components/ic-button/ic-button.js +17 -32
  134. package/dist/collection/components/ic-button/ic-button.js.map +1 -1
  135. package/dist/collection/components/ic-card/ic-card.css +62 -18
  136. package/dist/collection/components/ic-card/ic-card.js +103 -16
  137. package/dist/collection/components/ic-card/ic-card.js.map +1 -1
  138. package/dist/collection/components/ic-checkbox/ic-checkbox.css +28 -30
  139. package/dist/collection/components/ic-checkbox/ic-checkbox.js +63 -11
  140. package/dist/collection/components/ic-checkbox/ic-checkbox.js.map +1 -1
  141. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.css +18 -2
  142. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js +11 -11
  143. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js.map +1 -1
  144. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.test.a11y.js +1 -1
  145. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.test.a11y.js.map +1 -1
  146. package/dist/collection/components/ic-chip/ic-chip.css +596 -0
  147. package/dist/collection/components/ic-chip/ic-chip.js +247 -0
  148. package/dist/collection/components/ic-chip/ic-chip.js.map +1 -0
  149. package/dist/collection/components/ic-chip/ic-chip.test.a11y.js +11 -0
  150. package/dist/collection/components/ic-chip/ic-chip.test.a11y.js.map +1 -0
  151. package/dist/collection/components/ic-chip/ic-chip.types.js +2 -0
  152. package/dist/collection/components/ic-chip/ic-chip.types.js.map +1 -0
  153. package/dist/collection/components/ic-classification-banner/ic-classification-banner.css +5 -1
  154. package/dist/collection/components/ic-classification-banner/ic-classification-banner.js +6 -6
  155. package/dist/collection/components/ic-classification-banner/ic-classification-banner.js.map +1 -1
  156. package/dist/collection/components/ic-data-entity/ic-data-entity.css +1 -1
  157. package/dist/collection/components/ic-data-entity/ic-data-entity.js +2 -2
  158. package/dist/collection/components/ic-data-entity/ic-data-entity.js.map +1 -1
  159. package/dist/collection/components/ic-data-row/ic-data-row.css +19 -7
  160. package/dist/collection/components/ic-data-row/ic-data-row.js +14 -12
  161. package/dist/collection/components/ic-data-row/ic-data-row.js.map +1 -1
  162. package/dist/collection/components/ic-divider/ic-divider.css +1 -1
  163. package/dist/collection/components/ic-divider/ic-divider.js +1 -1
  164. package/dist/collection/components/ic-divider/ic-divider.js.map +1 -1
  165. package/dist/collection/components/ic-footer/ic-footer.css +4 -4
  166. package/dist/collection/components/ic-footer/ic-footer.js +19 -16
  167. package/dist/collection/components/ic-footer/ic-footer.js.map +1 -1
  168. package/dist/collection/components/ic-footer-link/ic-footer-link.css +28 -3
  169. package/dist/collection/components/ic-footer-link/ic-footer-link.js +101 -4
  170. package/dist/collection/components/ic-footer-link/ic-footer-link.js.map +1 -1
  171. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.css +1 -1
  172. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js +4 -3
  173. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js.map +1 -1
  174. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.test.a11y.js +1 -1
  175. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.test.a11y.js.map +1 -1
  176. package/dist/collection/components/ic-hero/ic-hero.css +35 -30
  177. package/dist/collection/components/ic-hero/ic-hero.js +10 -10
  178. package/dist/collection/components/ic-hero/ic-hero.js.map +1 -1
  179. package/dist/collection/components/ic-horizontal-scroll/assets/left-arrow.svg +3 -0
  180. package/dist/collection/components/ic-horizontal-scroll/assets/right-arrow.svg +3 -0
  181. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.css +539 -0
  182. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js +213 -0
  183. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js.map +1 -0
  184. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.test.a11y.js +34 -0
  185. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.test.a11y.js.map +1 -0
  186. package/dist/collection/components/ic-input-component-container/ic-input-component-container.css +16 -17
  187. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js +8 -8
  188. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js.map +1 -1
  189. package/dist/collection/components/ic-input-container/ic-input-container.css +0 -1
  190. package/dist/collection/components/ic-input-container/ic-input-container.js +2 -2
  191. package/dist/collection/components/ic-input-container/ic-input-container.js.map +1 -1
  192. package/dist/collection/components/ic-input-label/ic-input-label.js +8 -8
  193. package/dist/collection/components/ic-input-label/ic-input-label.js.map +1 -1
  194. package/dist/collection/components/ic-input-validation/ic-input-validation.css +4 -5
  195. package/dist/collection/components/ic-input-validation/ic-input-validation.js +5 -5
  196. package/dist/collection/components/ic-input-validation/ic-input-validation.js.map +1 -1
  197. package/dist/collection/components/ic-link/ic-link.css +0 -9
  198. package/dist/collection/components/ic-link/ic-link.js +38 -11
  199. package/dist/collection/components/ic-link/ic-link.js.map +1 -1
  200. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.css +43 -7
  201. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js +48 -9
  202. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js.map +1 -1
  203. package/dist/collection/components/ic-menu/ic-menu.css +20 -15
  204. package/dist/collection/components/ic-menu/ic-menu.js +135 -68
  205. package/dist/collection/components/ic-menu/ic-menu.js.map +1 -1
  206. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js +9 -8
  207. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js.map +1 -1
  208. package/dist/collection/components/ic-navigation-group/ic-navigation-group.css +14 -7
  209. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js +7 -6
  210. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js.map +1 -1
  211. package/dist/collection/components/ic-navigation-item/ic-navigation-item.css +68 -18
  212. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js +113 -16
  213. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js.map +1 -1
  214. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.css +15 -11
  215. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js +8 -8
  216. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js.map +1 -1
  217. package/dist/collection/components/ic-page-header/ic-page-header.css +15 -5
  218. package/dist/collection/components/ic-page-header/ic-page-header.js +10 -10
  219. package/dist/collection/components/ic-page-header/ic-page-header.js.map +1 -1
  220. package/dist/collection/components/ic-radio-group/ic-radio-group.css +32 -0
  221. package/dist/collection/components/ic-radio-group/ic-radio-group.js +44 -13
  222. package/dist/collection/components/ic-radio-group/ic-radio-group.js.map +1 -1
  223. package/dist/collection/components/ic-radio-group/ic-radio-group.test.a11y.js +1 -1
  224. package/dist/collection/components/ic-radio-group/ic-radio-group.test.a11y.js.map +1 -1
  225. package/dist/collection/components/ic-radio-option/ic-radio-option.css +32 -42
  226. package/dist/collection/components/ic-radio-option/ic-radio-option.js +65 -19
  227. package/dist/collection/components/ic-radio-option/ic-radio-option.js.map +1 -1
  228. package/dist/collection/components/ic-search-bar/ic-search-bar.css +24 -18
  229. package/dist/collection/components/ic-search-bar/ic-search-bar.js +87 -82
  230. package/dist/collection/components/ic-search-bar/ic-search-bar.js.map +1 -1
  231. package/dist/collection/components/ic-section-container/ic-section-container.css +1 -0
  232. package/dist/collection/components/ic-section-container/ic-section-container.js +2 -2
  233. package/dist/collection/components/ic-section-container/ic-section-container.js.map +1 -1
  234. package/dist/collection/components/ic-select/assets/Expand.svg +1 -1
  235. package/dist/collection/components/ic-select/ic-select.css +35 -18
  236. package/dist/collection/components/ic-select/ic-select.js +320 -77
  237. package/dist/collection/components/ic-select/ic-select.js.map +1 -1
  238. package/dist/collection/components/ic-side-navigation/ic-side-navigation.css +47 -37
  239. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js +39 -23
  240. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js.map +1 -1
  241. package/dist/collection/components/ic-skeleton/ic-skeleton.css +1 -1
  242. package/dist/collection/components/ic-skeleton/ic-skeleton.js +2 -2
  243. package/dist/collection/components/ic-skeleton/ic-skeleton.js.map +1 -1
  244. package/dist/collection/components/ic-status-tag/ic-status-tag.css +7 -7
  245. package/dist/collection/components/ic-status-tag/ic-status-tag.js +22 -3
  246. package/dist/collection/components/ic-status-tag/ic-status-tag.js.map +1 -1
  247. package/dist/collection/components/ic-status-tag/ic-status-tag.test.a11y.js +1 -1
  248. package/dist/collection/components/ic-status-tag/ic-status-tag.test.a11y.js.map +1 -1
  249. package/dist/collection/components/ic-step/ic-step.css +127 -30
  250. package/dist/collection/components/ic-step/ic-step.js +269 -28
  251. package/dist/collection/components/ic-step/ic-step.js.map +1 -1
  252. package/dist/collection/components/ic-step/ic-step.types.js.map +1 -1
  253. package/dist/collection/components/ic-stepper/ic-stepper-test-examples.js +74 -0
  254. package/dist/collection/components/ic-stepper/ic-stepper-test-examples.js.map +1 -0
  255. package/dist/collection/components/ic-stepper/ic-stepper.css +15 -1
  256. package/dist/collection/components/ic-stepper/ic-stepper.js +210 -40
  257. package/dist/collection/components/ic-stepper/ic-stepper.js.map +1 -1
  258. package/dist/collection/components/ic-stepper/ic-stepper.test.a11y.js +13 -1
  259. package/dist/collection/components/ic-stepper/ic-stepper.test.a11y.js.map +1 -1
  260. package/dist/collection/components/ic-switch/ic-switch.css +20 -20
  261. package/dist/collection/components/ic-switch/ic-switch.js +36 -7
  262. package/dist/collection/components/ic-switch/ic-switch.js.map +1 -1
  263. package/dist/collection/components/ic-tab/ic-tab.css +1 -1
  264. package/dist/collection/components/ic-tab/ic-tab.js +37 -6
  265. package/dist/collection/components/ic-tab/ic-tab.js.map +1 -1
  266. package/dist/collection/components/ic-tab-context/ic-tab-context.js +31 -4
  267. package/dist/collection/components/ic-tab-context/ic-tab-context.js.map +1 -1
  268. package/dist/collection/components/ic-tab-context/ic-tab-context.test.a11y.js +1 -1
  269. package/dist/collection/components/ic-tab-context/ic-tab-context.test.a11y.js.map +1 -1
  270. package/dist/collection/components/ic-tab-group/ic-tab-group.css +6 -120
  271. package/dist/collection/components/ic-tab-group/ic-tab-group.js +12 -156
  272. package/dist/collection/components/ic-tab-group/ic-tab-group.js.map +1 -1
  273. package/dist/collection/components/ic-tab-panel/ic-tab-panel.css +4 -0
  274. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js +2 -2
  275. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js.map +1 -1
  276. package/dist/collection/components/ic-text-field/ic-text-field.css +7 -7
  277. package/dist/collection/components/ic-text-field/ic-text-field.js +32 -32
  278. package/dist/collection/components/ic-text-field/ic-text-field.js.map +1 -1
  279. package/dist/collection/components/ic-theme/ic-theme.js +9 -6
  280. package/dist/collection/components/ic-theme/ic-theme.js.map +1 -1
  281. package/dist/collection/components/ic-toast/ic-toast.css +597 -0
  282. package/dist/collection/components/ic-toast/ic-toast.js +382 -0
  283. package/dist/collection/components/ic-toast/ic-toast.js.map +1 -0
  284. package/dist/collection/components/ic-toast/ic-toast.test.a11y.js +16 -0
  285. package/dist/collection/components/ic-toast/ic-toast.test.a11y.js.map +1 -0
  286. package/dist/collection/components/ic-toast/ic-toast.types.js +2 -0
  287. package/dist/collection/components/ic-toast/ic-toast.types.js.map +1 -0
  288. package/dist/collection/components/ic-toast-region/ic-toast-region.js +81 -0
  289. package/dist/collection/components/ic-toast-region/ic-toast-region.js.map +1 -0
  290. package/dist/collection/components/ic-tooltip/ic-tooltip.css +9 -11
  291. package/dist/collection/components/ic-tooltip/ic-tooltip.js +22 -1
  292. package/dist/collection/components/ic-tooltip/ic-tooltip.js.map +1 -1
  293. package/dist/collection/components/ic-top-navigation/ic-top-navigation.css +34 -52
  294. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js +21 -15
  295. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js.map +1 -1
  296. package/dist/collection/components/ic-top-navigation/ic-top-navigation.test.a11y.js +1 -1
  297. package/dist/collection/components/ic-top-navigation/ic-top-navigation.test.a11y.js.map +1 -1
  298. package/dist/collection/components/ic-typography/ic-typography.js +1 -1
  299. package/dist/collection/components/ic-typography/ic-typography.js.map +1 -1
  300. package/dist/collection/normalize.css +440 -0
  301. package/dist/collection/testspec.setup.js +8 -0
  302. package/dist/collection/testspec.setup.js.map +1 -1
  303. package/dist/collection/utils/constants.js +28 -0
  304. package/dist/collection/utils/constants.js.map +1 -1
  305. package/dist/collection/utils/helpers.js +12 -3
  306. package/dist/collection/utils/helpers.js.map +1 -1
  307. package/dist/collection/utils/types.js.map +1 -1
  308. package/dist/components/OpenInNew.js +5 -0
  309. package/dist/components/OpenInNew.js.map +1 -0
  310. package/dist/components/check-icon.js +1 -1
  311. package/dist/components/chevron-icon.js +1 -1
  312. package/dist/components/helpers.js +70 -3
  313. package/dist/components/helpers.js.map +1 -1
  314. package/dist/components/ic-alert.js +6 -25
  315. package/dist/components/ic-alert.js.map +1 -1
  316. package/dist/components/ic-back-to-top.js +23 -11
  317. package/dist/components/ic-back-to-top.js.map +1 -1
  318. package/dist/components/ic-breadcrumb-group.js.map +1 -1
  319. package/dist/components/ic-breadcrumb2.js +14 -4
  320. package/dist/components/ic-breadcrumb2.js.map +1 -1
  321. package/dist/components/ic-button2.js +8 -20
  322. package/dist/components/ic-button2.js.map +1 -1
  323. package/dist/components/ic-card.js +52 -6
  324. package/dist/components/ic-card.js.map +1 -1
  325. package/dist/components/ic-checkbox-group.js +3 -3
  326. package/dist/components/ic-checkbox-group.js.map +1 -1
  327. package/dist/components/ic-checkbox.js +17 -4
  328. package/dist/components/ic-checkbox.js.map +1 -1
  329. package/dist/components/ic-chip.d.ts +11 -0
  330. package/dist/components/ic-chip.js +111 -0
  331. package/dist/components/ic-chip.js.map +1 -0
  332. package/dist/components/ic-classification-banner.js +2 -2
  333. package/dist/components/ic-classification-banner.js.map +1 -1
  334. package/dist/components/ic-data-entity.js +1 -1
  335. package/dist/components/ic-data-entity.js.map +1 -1
  336. package/dist/components/ic-data-row.js +12 -10
  337. package/dist/components/ic-data-row.js.map +1 -1
  338. package/dist/components/ic-divider2.js +2 -2
  339. package/dist/components/ic-divider2.js.map +1 -1
  340. package/dist/components/ic-footer-link-group.js +4 -3
  341. package/dist/components/ic-footer-link-group.js.map +1 -1
  342. package/dist/components/ic-footer-link.js +17 -5
  343. package/dist/components/ic-footer-link.js.map +1 -1
  344. package/dist/components/ic-footer.js +4 -4
  345. package/dist/components/ic-footer.js.map +1 -1
  346. package/dist/components/ic-hero.js +2 -2
  347. package/dist/components/ic-hero.js.map +1 -1
  348. package/dist/components/ic-horizontal-scroll.d.ts +11 -0
  349. package/dist/components/ic-horizontal-scroll.js +8 -0
  350. package/dist/components/ic-horizontal-scroll.js.map +1 -0
  351. package/dist/components/ic-horizontal-scroll2.js +199 -0
  352. package/dist/components/ic-horizontal-scroll2.js.map +1 -0
  353. package/dist/components/ic-input-component-container2.js +2 -3
  354. package/dist/components/ic-input-component-container2.js.map +1 -1
  355. package/dist/components/ic-input-container2.js +1 -1
  356. package/dist/components/ic-input-container2.js.map +1 -1
  357. package/dist/components/ic-input-label2.js +1 -1
  358. package/dist/components/ic-input-label2.js.map +1 -1
  359. package/dist/components/ic-input-validation2.js +2 -4
  360. package/dist/components/ic-input-validation2.js.map +1 -1
  361. package/dist/components/ic-link2.js +15 -8
  362. package/dist/components/ic-link2.js.map +1 -1
  363. package/dist/components/ic-loading-indicator2.js +27 -7
  364. package/dist/components/ic-loading-indicator2.js.map +1 -1
  365. package/dist/components/ic-menu2.js +66 -35
  366. package/dist/components/ic-menu2.js.map +1 -1
  367. package/dist/components/ic-navigation-button.js +5 -4
  368. package/dist/components/ic-navigation-button.js.map +1 -1
  369. package/dist/components/ic-navigation-group.js +5 -4
  370. package/dist/components/ic-navigation-group.js.map +1 -1
  371. package/dist/components/ic-navigation-item.js +22 -10
  372. package/dist/components/ic-navigation-item.js.map +1 -1
  373. package/dist/components/ic-navigation-menu2.js +8 -8
  374. package/dist/components/ic-navigation-menu2.js.map +1 -1
  375. package/dist/components/ic-page-header.js +30 -6
  376. package/dist/components/ic-page-header.js.map +1 -1
  377. package/dist/components/ic-radio-group.js +14 -5
  378. package/dist/components/ic-radio-group.js.map +1 -1
  379. package/dist/components/ic-radio-option.js +25 -6
  380. package/dist/components/ic-radio-option.js.map +1 -1
  381. package/dist/components/ic-search-bar.js +56 -43
  382. package/dist/components/ic-search-bar.js.map +1 -1
  383. package/dist/components/ic-section-container2.js +1 -1
  384. package/dist/components/ic-section-container2.js.map +1 -1
  385. package/dist/components/ic-select.js +212 -59
  386. package/dist/components/ic-select.js.map +1 -1
  387. package/dist/components/ic-side-navigation.js +23 -11
  388. package/dist/components/ic-side-navigation.js.map +1 -1
  389. package/dist/components/ic-skeleton.js +1 -1
  390. package/dist/components/ic-skeleton.js.map +1 -1
  391. package/dist/components/ic-status-tag.js +6 -4
  392. package/dist/components/ic-status-tag.js.map +1 -1
  393. package/dist/components/ic-step.js +117 -16
  394. package/dist/components/ic-step.js.map +1 -1
  395. package/dist/components/ic-stepper.js +173 -42
  396. package/dist/components/ic-stepper.js.map +1 -1
  397. package/dist/components/ic-switch.js +13 -3
  398. package/dist/components/ic-switch.js.map +1 -1
  399. package/dist/components/ic-tab-context.js +6 -1
  400. package/dist/components/ic-tab-context.js.map +1 -1
  401. package/dist/components/ic-tab-group.js +30 -125
  402. package/dist/components/ic-tab-group.js.map +1 -1
  403. package/dist/components/ic-tab-panel.js +1 -1
  404. package/dist/components/ic-tab-panel.js.map +1 -1
  405. package/dist/components/ic-tab.js +11 -2
  406. package/dist/components/ic-tab.js.map +1 -1
  407. package/dist/components/ic-text-field2.js +6 -6
  408. package/dist/components/ic-text-field2.js.map +1 -1
  409. package/dist/components/ic-theme.js +3 -3
  410. package/dist/components/ic-theme.js.map +1 -1
  411. package/dist/components/ic-toast-region.d.ts +11 -0
  412. package/dist/components/ic-toast-region.js +63 -0
  413. package/dist/components/ic-toast-region.js.map +1 -0
  414. package/dist/components/ic-toast.d.ts +11 -0
  415. package/dist/components/ic-toast.js +214 -0
  416. package/dist/components/ic-toast.js.map +1 -0
  417. package/dist/components/ic-tooltip2.js +7 -3
  418. package/dist/components/ic-tooltip2.js.map +1 -1
  419. package/dist/components/ic-top-navigation.js +23 -12
  420. package/dist/components/ic-top-navigation.js.map +1 -1
  421. package/dist/components/ic-typography2.js.map +1 -1
  422. package/dist/components/index.d.ts +5 -1
  423. package/dist/components/index.js +4 -0
  424. package/dist/components/index.js.map +1 -1
  425. package/dist/components/types.js.map +1 -1
  426. package/dist/core/core.css +2 -2
  427. package/dist/core/core.esm.js +1 -1
  428. package/dist/core/core.esm.js.map +1 -1
  429. package/dist/core/normalize.css +440 -0
  430. package/dist/core/p-1724000c.js +2 -0
  431. package/dist/core/p-1724000c.js.map +1 -0
  432. package/dist/core/p-18ae4b6d.entry.js +2 -0
  433. package/dist/core/p-18ae4b6d.entry.js.map +1 -0
  434. package/dist/core/p-18bf3cb0.entry.js +2 -0
  435. package/dist/core/p-18bf3cb0.entry.js.map +1 -0
  436. package/dist/core/p-24240e11.js +2 -0
  437. package/dist/core/p-284970bc.entry.js +2 -0
  438. package/dist/core/p-284970bc.entry.js.map +1 -0
  439. package/dist/core/p-31a595c1.entry.js +2 -0
  440. package/dist/core/p-31a595c1.entry.js.map +1 -0
  441. package/dist/core/{p-07cd789d.entry.js → p-35a03442.entry.js} +2 -2
  442. package/dist/core/p-35a03442.entry.js.map +1 -0
  443. package/dist/core/p-360adc51.entry.js +2 -0
  444. package/dist/core/p-360adc51.entry.js.map +1 -0
  445. package/dist/core/p-3dda76db.entry.js +2 -0
  446. package/dist/core/p-3dda76db.entry.js.map +1 -0
  447. package/dist/core/p-41e239cb.entry.js +2 -0
  448. package/dist/core/p-41e239cb.entry.js.map +1 -0
  449. package/dist/core/p-44c9612c.entry.js +2 -0
  450. package/dist/core/p-44c9612c.entry.js.map +1 -0
  451. package/dist/core/p-4a73728b.entry.js +2 -0
  452. package/dist/core/p-4a73728b.entry.js.map +1 -0
  453. package/dist/core/p-521be4e2.entry.js +2 -0
  454. package/dist/core/p-521be4e2.entry.js.map +1 -0
  455. package/dist/core/{p-f9370be6.js → p-5450cebf.js} +3 -3
  456. package/dist/core/p-5450cebf.js.map +1 -0
  457. package/dist/core/p-5b083ce5.entry.js +2 -0
  458. package/dist/core/p-5b083ce5.entry.js.map +1 -0
  459. package/dist/core/p-62b3516e.entry.js +2 -0
  460. package/dist/core/p-62b3516e.entry.js.map +1 -0
  461. package/dist/core/{p-10da19d2.entry.js → p-691ea0f2.entry.js} +2 -2
  462. package/dist/core/p-691ea0f2.entry.js.map +1 -0
  463. package/dist/core/p-6a397882.entry.js +2 -0
  464. package/dist/core/p-6a397882.entry.js.map +1 -0
  465. package/dist/core/p-6f57b13c.js.map +1 -1
  466. package/dist/core/p-7818d958.entry.js +2 -0
  467. package/dist/core/p-7818d958.entry.js.map +1 -0
  468. package/dist/core/p-7a0bf893.entry.js +2 -0
  469. package/dist/core/p-7a0bf893.entry.js.map +1 -0
  470. package/dist/core/p-7a9bc7f2.entry.js +2 -0
  471. package/dist/core/p-7a9bc7f2.entry.js.map +1 -0
  472. package/dist/core/{p-e93e9aa3.entry.js → p-7fd50355.entry.js} +2 -2
  473. package/dist/core/p-7fd50355.entry.js.map +1 -0
  474. package/dist/core/p-897e967a.entry.js +2 -0
  475. package/dist/core/p-897e967a.entry.js.map +1 -0
  476. package/dist/core/p-8c7f4343.js +2 -0
  477. package/dist/core/p-8d4f7027.js +2 -0
  478. package/dist/core/p-8f1176c6.entry.js +2 -0
  479. package/dist/core/p-8f1176c6.entry.js.map +1 -0
  480. package/dist/core/{p-0118400b.entry.js → p-8ffa00c9.entry.js} +2 -2
  481. package/dist/core/p-8ffa00c9.entry.js.map +1 -0
  482. package/dist/core/p-91a8db51.entry.js +2 -0
  483. package/dist/core/p-91a8db51.entry.js.map +1 -0
  484. package/dist/core/p-a09d853e.entry.js +2 -0
  485. package/dist/core/p-a09d853e.entry.js.map +1 -0
  486. package/dist/core/p-a10da430.entry.js +2 -0
  487. package/dist/core/p-a10da430.entry.js.map +1 -0
  488. package/dist/core/p-a667e329.entry.js +2 -0
  489. package/dist/core/p-a667e329.entry.js.map +1 -0
  490. package/dist/core/{p-6be5e06b.entry.js → p-ad2477d8.entry.js} +2 -2
  491. package/dist/core/p-ad2477d8.entry.js.map +1 -0
  492. package/dist/core/p-b35ae170.entry.js +2 -0
  493. package/dist/core/p-b35ae170.entry.js.map +1 -0
  494. package/dist/core/p-b40bd77c.entry.js +2 -0
  495. package/dist/core/p-b40bd77c.entry.js.map +1 -0
  496. package/dist/core/p-b4234318.entry.js +2 -0
  497. package/dist/core/p-b4234318.entry.js.map +1 -0
  498. package/dist/core/{p-c4d3c18c.entry.js → p-ba8d6c23.entry.js} +2 -2
  499. package/dist/core/p-ba8d6c23.entry.js.map +1 -0
  500. package/dist/core/p-bd819f68.entry.js +2 -0
  501. package/dist/core/p-bd819f68.entry.js.map +1 -0
  502. package/dist/core/p-c4a7c734.entry.js +2 -0
  503. package/dist/core/p-c4a7c734.entry.js.map +1 -0
  504. package/dist/core/p-c72e4b75.entry.js +2 -0
  505. package/dist/core/p-c72e4b75.entry.js.map +1 -0
  506. package/dist/core/p-c7b86643.entry.js +2 -0
  507. package/dist/core/p-c7b86643.entry.js.map +1 -0
  508. package/dist/core/p-c7c5d2c5.entry.js +2 -0
  509. package/dist/core/p-c7c5d2c5.entry.js.map +1 -0
  510. package/dist/core/p-c8f07be6.entry.js +2 -0
  511. package/dist/core/p-c8f07be6.entry.js.map +1 -0
  512. package/dist/core/{p-6d0eaaeb.entry.js → p-c9068822.entry.js} +2 -2
  513. package/dist/core/{p-6d0eaaeb.entry.js.map → p-c9068822.entry.js.map} +1 -1
  514. package/dist/core/p-cccbf2bf.entry.js +2 -0
  515. package/dist/core/p-cccbf2bf.entry.js.map +1 -0
  516. package/dist/core/{p-02799e26.entry.js → p-d2508752.entry.js} +2 -2
  517. package/dist/core/{p-02799e26.entry.js.map → p-d2508752.entry.js.map} +1 -1
  518. package/dist/core/p-d37b9695.entry.js +2 -0
  519. package/dist/core/p-d37b9695.entry.js.map +1 -0
  520. package/dist/core/p-d86b0d0e.entry.js +2 -0
  521. package/dist/core/p-d86b0d0e.entry.js.map +1 -0
  522. package/dist/core/p-dea3d5f0.entry.js +2 -0
  523. package/dist/core/p-dea3d5f0.entry.js.map +1 -0
  524. package/dist/core/p-e0d88c31.entry.js +2 -0
  525. package/dist/core/p-e0d88c31.entry.js.map +1 -0
  526. package/dist/core/p-e9202767.entry.js +2 -0
  527. package/dist/core/p-e9202767.entry.js.map +1 -0
  528. package/dist/core/p-eba373bf.entry.js +2 -0
  529. package/dist/core/p-eba373bf.entry.js.map +1 -0
  530. package/dist/core/{p-cadb531f.entry.js → p-ed6cf9b9.entry.js} +2 -2
  531. package/dist/core/p-ed6cf9b9.entry.js.map +1 -0
  532. package/dist/esm/OpenInNew-67a881e0.js +5 -0
  533. package/dist/esm/OpenInNew-67a881e0.js.map +1 -0
  534. package/dist/esm/{check-icon-53f1d9e5.js → check-icon-abb210ec.js} +2 -2
  535. package/dist/esm/check-icon-abb210ec.js.map +1 -0
  536. package/dist/esm/chevron-icon-98c98242.js +8 -0
  537. package/dist/esm/chevron-icon-98c98242.js.map +1 -0
  538. package/dist/esm/core.js +2 -2
  539. package/dist/esm/{helpers-3d41833c.js → helpers-c332acf8.js} +71 -4
  540. package/dist/esm/helpers-c332acf8.js.map +1 -0
  541. package/dist/esm/ic-alert.entry.js +6 -25
  542. package/dist/esm/ic-alert.entry.js.map +1 -1
  543. package/dist/esm/ic-back-to-top.entry.js +24 -12
  544. package/dist/esm/ic-back-to-top.entry.js.map +1 -1
  545. package/dist/esm/ic-breadcrumb-group.entry.js +2 -2
  546. package/dist/esm/ic-breadcrumb-group.entry.js.map +1 -1
  547. package/dist/esm/ic-breadcrumb.entry.js +14 -5
  548. package/dist/esm/ic-breadcrumb.entry.js.map +1 -1
  549. package/dist/esm/ic-button_3.entry.js +39 -29
  550. package/dist/esm/ic-button_3.entry.js.map +1 -1
  551. package/dist/esm/ic-card.entry.js +29 -5
  552. package/dist/esm/ic-card.entry.js.map +1 -1
  553. package/dist/esm/ic-checkbox-group.entry.js +4 -4
  554. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  555. package/dist/esm/ic-checkbox.entry.js +16 -4
  556. package/dist/esm/ic-checkbox.entry.js.map +1 -1
  557. package/dist/esm/ic-chip.entry.js +73 -0
  558. package/dist/esm/ic-chip.entry.js.map +1 -0
  559. package/dist/esm/ic-classification-banner.entry.js +3 -3
  560. package/dist/esm/ic-classification-banner.entry.js.map +1 -1
  561. package/dist/esm/ic-data-entity.entry.js +2 -2
  562. package/dist/esm/ic-data-entity.entry.js.map +1 -1
  563. package/dist/esm/ic-data-row.entry.js +14 -12
  564. package/dist/esm/ic-data-row.entry.js.map +1 -1
  565. package/dist/esm/ic-divider.entry.js +3 -3
  566. package/dist/esm/ic-divider.entry.js.map +1 -1
  567. package/dist/esm/ic-footer-link-group.entry.js +4 -3
  568. package/dist/esm/ic-footer-link-group.entry.js.map +1 -1
  569. package/dist/esm/ic-footer-link.entry.js +12 -5
  570. package/dist/esm/ic-footer-link.entry.js.map +1 -1
  571. package/dist/esm/ic-footer.entry.js +5 -5
  572. package/dist/esm/ic-footer.entry.js.map +1 -1
  573. package/dist/esm/ic-hero.entry.js +3 -3
  574. package/dist/esm/ic-hero.entry.js.map +1 -1
  575. package/dist/esm/ic-horizontal-scroll.entry.js +154 -0
  576. package/dist/esm/ic-horizontal-scroll.entry.js.map +1 -0
  577. package/dist/esm/ic-input-component-container_3.entry.js +70 -40
  578. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -1
  579. package/dist/esm/ic-input-label_2.entry.js +3 -5
  580. package/dist/esm/ic-input-label_2.entry.js.map +1 -1
  581. package/dist/esm/ic-link.entry.js +13 -7
  582. package/dist/esm/ic-link.entry.js.map +1 -1
  583. package/dist/esm/ic-navigation-button.entry.js +5 -4
  584. package/dist/esm/ic-navigation-button.entry.js.map +1 -1
  585. package/dist/esm/ic-navigation-group.entry.js +6 -5
  586. package/dist/esm/ic-navigation-group.entry.js.map +1 -1
  587. package/dist/esm/ic-navigation-item.entry.js +18 -11
  588. package/dist/esm/ic-navigation-item.entry.js.map +1 -1
  589. package/dist/esm/ic-navigation-menu.entry.js +8 -8
  590. package/dist/esm/ic-navigation-menu.entry.js.map +1 -1
  591. package/dist/esm/ic-page-header.entry.js +5 -5
  592. package/dist/esm/ic-page-header.entry.js.map +1 -1
  593. package/dist/esm/ic-radio-group.entry.js +13 -5
  594. package/dist/esm/ic-radio-group.entry.js.map +1 -1
  595. package/dist/esm/ic-radio-option.entry.js +24 -6
  596. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  597. package/dist/esm/ic-search-bar.entry.js +53 -41
  598. package/dist/esm/ic-search-bar.entry.js.map +1 -1
  599. package/dist/esm/ic-section-container.entry.js +2 -2
  600. package/dist/esm/ic-section-container.entry.js.map +1 -1
  601. package/dist/esm/ic-select.entry.js +206 -59
  602. package/dist/esm/ic-select.entry.js.map +1 -1
  603. package/dist/esm/ic-side-navigation.entry.js +24 -12
  604. package/dist/esm/ic-side-navigation.entry.js.map +1 -1
  605. package/dist/esm/ic-skeleton.entry.js +2 -2
  606. package/dist/esm/ic-skeleton.entry.js.map +1 -1
  607. package/dist/esm/ic-status-tag.entry.js +6 -5
  608. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  609. package/dist/esm/ic-step.entry.js +103 -15
  610. package/dist/esm/ic-step.entry.js.map +1 -1
  611. package/dist/esm/ic-stepper.entry.js +166 -42
  612. package/dist/esm/ic-stepper.entry.js.map +1 -1
  613. package/dist/esm/ic-switch.entry.js +12 -3
  614. package/dist/esm/ic-switch.entry.js.map +1 -1
  615. package/dist/esm/ic-tab-context.entry.js +7 -2
  616. package/dist/esm/ic-tab-context.entry.js.map +1 -1
  617. package/dist/esm/ic-tab-group.entry.js +9 -118
  618. package/dist/esm/ic-tab-group.entry.js.map +1 -1
  619. package/dist/esm/ic-tab-panel.entry.js +2 -2
  620. package/dist/esm/ic-tab-panel.entry.js.map +1 -1
  621. package/dist/esm/ic-tab.entry.js +10 -2
  622. package/dist/esm/ic-tab.entry.js.map +1 -1
  623. package/dist/esm/ic-text-field.entry.js +5 -5
  624. package/dist/esm/ic-text-field.entry.js.map +1 -1
  625. package/dist/esm/ic-theme.entry.js +4 -4
  626. package/dist/esm/ic-theme.entry.js.map +1 -1
  627. package/dist/esm/ic-toast-region.entry.js +44 -0
  628. package/dist/esm/ic-toast-region.entry.js.map +1 -0
  629. package/dist/esm/ic-toast.entry.js +161 -0
  630. package/dist/esm/ic-toast.entry.js.map +1 -0
  631. package/dist/esm/ic-top-navigation.entry.js +15 -10
  632. package/dist/esm/ic-top-navigation.entry.js.map +1 -1
  633. package/dist/esm/ic-typography.entry.js +1 -1
  634. package/dist/esm/ic-typography.entry.js.map +1 -1
  635. package/dist/esm/{index-1500de1f.js → index-90721b3c.js} +21 -2
  636. package/dist/esm/index-90721b3c.js.map +1 -0
  637. package/dist/esm/loader.js +2 -2
  638. package/dist/esm/types-dd515332.js.map +1 -1
  639. package/dist/types/components/ic-alert/ic-alert.d.ts +14 -10
  640. package/dist/types/components/ic-back-to-top/ic-back-to-top.d.ts +1 -0
  641. package/dist/types/components/ic-breadcrumb/ic-breadcrumb.d.ts +9 -5
  642. package/dist/types/components/ic-breadcrumb-group/ic-breadcrumb-group.d.ts +2 -2
  643. package/dist/types/components/ic-button/ic-button.d.ts +11 -14
  644. package/dist/types/components/ic-card/ic-card.d.ts +31 -10
  645. package/dist/types/components/ic-checkbox/ic-checkbox.d.ts +18 -10
  646. package/dist/types/components/ic-checkbox-group/ic-checkbox-group.d.ts +9 -9
  647. package/dist/types/components/ic-chip/ic-chip.d.ts +48 -0
  648. package/dist/types/components/ic-chip/ic-chip.test.a11y.d.ts +1 -0
  649. package/dist/types/components/ic-chip/ic-chip.types.d.ts +2 -0
  650. package/dist/types/components/ic-classification-banner/ic-classification-banner.d.ts +5 -5
  651. package/dist/types/components/ic-data-entity/ic-data-entity.d.ts +2 -2
  652. package/dist/types/components/ic-data-row/ic-data-row.d.ts +3 -3
  653. package/dist/types/components/ic-footer/ic-footer.d.ts +12 -12
  654. package/dist/types/components/ic-footer-link/ic-footer-link.d.ts +20 -0
  655. package/dist/types/components/ic-footer-link-group/ic-footer-link-group.d.ts +1 -1
  656. package/dist/types/components/ic-hero/ic-hero.d.ts +9 -9
  657. package/dist/types/components/ic-horizontal-scroll/ic-horizontal-scroll.d.ts +39 -0
  658. package/dist/types/components/ic-horizontal-scroll/ic-horizontal-scroll.test.a11y.d.ts +1 -0
  659. package/dist/types/components/ic-input-component-container/ic-input-component-container.d.ts +8 -8
  660. package/dist/types/components/ic-input-container/ic-input-container.d.ts +2 -2
  661. package/dist/types/components/ic-input-label/ic-input-label.d.ts +8 -8
  662. package/dist/types/components/ic-input-validation/ic-input-validation.d.ts +5 -5
  663. package/dist/types/components/ic-link/ic-link.d.ts +10 -7
  664. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.d.ts +7 -3
  665. package/dist/types/components/ic-menu/ic-menu.d.ts +36 -18
  666. package/dist/types/components/ic-navigation-button/ic-navigation-button.d.ts +6 -6
  667. package/dist/types/components/ic-navigation-group/ic-navigation-group.d.ts +3 -3
  668. package/dist/types/components/ic-navigation-item/ic-navigation-item.d.ts +28 -8
  669. package/dist/types/components/ic-navigation-menu/ic-navigation-menu.d.ts +2 -2
  670. package/dist/types/components/ic-page-header/ic-page-header.d.ts +10 -8
  671. package/dist/types/components/ic-radio-group/ic-radio-group.d.ts +15 -11
  672. package/dist/types/components/ic-radio-option/ic-radio-option.d.ts +17 -11
  673. package/dist/types/components/ic-search-bar/ic-search-bar.d.ts +31 -30
  674. package/dist/types/components/ic-section-container/ic-section-container.d.ts +2 -2
  675. package/dist/types/components/ic-select/ic-select.d.ts +68 -23
  676. package/dist/types/components/ic-side-navigation/ic-side-navigation.d.ts +13 -12
  677. package/dist/types/components/ic-skeleton/ic-skeleton.d.ts +2 -2
  678. package/dist/types/components/ic-status-tag/ic-status-tag.d.ts +5 -1
  679. package/dist/types/components/ic-step/ic-step.d.ts +37 -8
  680. package/dist/types/components/ic-step/ic-step.types.d.ts +2 -0
  681. package/dist/types/components/ic-stepper/ic-stepper-test-examples.d.ts +4 -0
  682. package/dist/types/components/ic-stepper/ic-stepper.d.ts +23 -6
  683. package/dist/types/components/ic-switch/ic-switch.d.ts +11 -7
  684. package/dist/types/components/ic-tab/ic-tab.d.ts +9 -5
  685. package/dist/types/components/ic-tab-context/ic-tab-context.d.ts +8 -4
  686. package/dist/types/components/ic-tab-group/ic-tab-group.d.ts +5 -33
  687. package/dist/types/components/ic-tab-panel/ic-tab-panel.d.ts +2 -2
  688. package/dist/types/components/ic-text-field/ic-text-field.d.ts +31 -31
  689. package/dist/types/components/ic-theme/ic-theme.d.ts +3 -3
  690. package/dist/types/components/ic-toast/ic-toast.d.ts +66 -0
  691. package/dist/types/components/ic-toast/ic-toast.test.a11y.d.ts +1 -0
  692. package/dist/types/components/ic-toast/ic-toast.types.d.ts +1 -0
  693. package/dist/types/components/ic-toast-region/ic-toast-region.d.ts +12 -0
  694. package/dist/types/components/ic-tooltip/ic-tooltip.d.ts +4 -0
  695. package/dist/types/components/ic-top-navigation/ic-top-navigation.d.ts +7 -6
  696. package/dist/types/components/ic-typography/ic-typography.d.ts +1 -1
  697. package/dist/types/components.d.ts +935 -560
  698. package/dist/types/interface.d.ts +0 -1
  699. package/dist/types/testspec.setup.d.ts +1 -0
  700. package/dist/types/utils/constants.d.ts +22 -0
  701. package/dist/types/utils/helpers.d.ts +2 -0
  702. package/dist/types/utils/types.d.ts +3 -0
  703. package/hydrate/index.js +1592 -585
  704. package/package.json +5 -5
  705. package/dist/cjs/check-icon-999d9877.js.map +0 -1
  706. package/dist/cjs/chevron-icon-d175fe66.js.map +0 -1
  707. package/dist/cjs/error-icon-99504103.js +0 -18
  708. package/dist/cjs/error-icon-99504103.js.map +0 -1
  709. package/dist/cjs/helpers-8bc3b6d2.js.map +0 -1
  710. package/dist/cjs/index-3ef30d9d.js.map +0 -1
  711. package/dist/cjs/success-icon-887b2097.js +0 -11
  712. package/dist/cjs/success-icon-887b2097.js.map +0 -1
  713. package/dist/collection/components/ic-alert/ic-alert.types.js +0 -2
  714. package/dist/collection/components/ic-alert/ic-alert.types.js.map +0 -1
  715. package/dist/collection/components/ic-tab-group/assets/left-arrow.svg +0 -3
  716. package/dist/collection/components/ic-tab-group/assets/right-arrow.svg +0 -3
  717. package/dist/components/error-icon.js +0 -15
  718. package/dist/components/error-icon.js.map +0 -1
  719. package/dist/components/success-icon.js +0 -9
  720. package/dist/components/success-icon.js.map +0 -1
  721. package/dist/core/p-0118400b.entry.js.map +0 -1
  722. package/dist/core/p-07cd789d.entry.js.map +0 -1
  723. package/dist/core/p-0b125f26.entry.js +0 -2
  724. package/dist/core/p-0b125f26.entry.js.map +0 -1
  725. package/dist/core/p-10da19d2.entry.js.map +0 -1
  726. package/dist/core/p-1337db5e.entry.js +0 -2
  727. package/dist/core/p-1337db5e.entry.js.map +0 -1
  728. package/dist/core/p-1721bcf3.entry.js +0 -2
  729. package/dist/core/p-1721bcf3.entry.js.map +0 -1
  730. package/dist/core/p-1e7b4310.js +0 -2
  731. package/dist/core/p-23831891.js +0 -2
  732. package/dist/core/p-23831891.js.map +0 -1
  733. package/dist/core/p-272c7abd.entry.js +0 -2
  734. package/dist/core/p-272c7abd.entry.js.map +0 -1
  735. package/dist/core/p-2f114521.entry.js +0 -2
  736. package/dist/core/p-2f114521.entry.js.map +0 -1
  737. package/dist/core/p-31a8595f.entry.js +0 -2
  738. package/dist/core/p-31a8595f.entry.js.map +0 -1
  739. package/dist/core/p-33a45ace.entry.js +0 -2
  740. package/dist/core/p-33a45ace.entry.js.map +0 -1
  741. package/dist/core/p-347ec49e.entry.js +0 -2
  742. package/dist/core/p-347ec49e.entry.js.map +0 -1
  743. package/dist/core/p-39ae284e.entry.js +0 -2
  744. package/dist/core/p-39ae284e.entry.js.map +0 -1
  745. package/dist/core/p-558552f8.entry.js +0 -2
  746. package/dist/core/p-558552f8.entry.js.map +0 -1
  747. package/dist/core/p-5e261268.entry.js +0 -2
  748. package/dist/core/p-5e261268.entry.js.map +0 -1
  749. package/dist/core/p-60ffb73e.entry.js +0 -2
  750. package/dist/core/p-60ffb73e.entry.js.map +0 -1
  751. package/dist/core/p-69650186.entry.js +0 -2
  752. package/dist/core/p-69650186.entry.js.map +0 -1
  753. package/dist/core/p-6b34d98f.entry.js +0 -2
  754. package/dist/core/p-6b34d98f.entry.js.map +0 -1
  755. package/dist/core/p-6be5e06b.entry.js.map +0 -1
  756. package/dist/core/p-6f6bd657.entry.js +0 -2
  757. package/dist/core/p-6f6bd657.entry.js.map +0 -1
  758. package/dist/core/p-7093d214.entry.js +0 -2
  759. package/dist/core/p-7093d214.entry.js.map +0 -1
  760. package/dist/core/p-7577c6a3.entry.js +0 -2
  761. package/dist/core/p-7577c6a3.entry.js.map +0 -1
  762. package/dist/core/p-7b11e1dc.entry.js +0 -2
  763. package/dist/core/p-7b11e1dc.entry.js.map +0 -1
  764. package/dist/core/p-7b39977f.entry.js +0 -2
  765. package/dist/core/p-7b39977f.entry.js.map +0 -1
  766. package/dist/core/p-7f632414.entry.js +0 -2
  767. package/dist/core/p-7f632414.entry.js.map +0 -1
  768. package/dist/core/p-898607d0.entry.js +0 -2
  769. package/dist/core/p-898607d0.entry.js.map +0 -1
  770. package/dist/core/p-8ddeb574.entry.js +0 -2
  771. package/dist/core/p-8ddeb574.entry.js.map +0 -1
  772. package/dist/core/p-9cd04875.entry.js +0 -2
  773. package/dist/core/p-9cd04875.entry.js.map +0 -1
  774. package/dist/core/p-ac43322e.entry.js +0 -2
  775. package/dist/core/p-ac43322e.entry.js.map +0 -1
  776. package/dist/core/p-ae6aa67f.js +0 -2
  777. package/dist/core/p-ae81dffa.entry.js +0 -2
  778. package/dist/core/p-ae81dffa.entry.js.map +0 -1
  779. package/dist/core/p-b3dec76d.entry.js +0 -2
  780. package/dist/core/p-b3dec76d.entry.js.map +0 -1
  781. package/dist/core/p-b5a988c0.entry.js +0 -2
  782. package/dist/core/p-b5a988c0.entry.js.map +0 -1
  783. package/dist/core/p-bf5717ca.js +0 -2
  784. package/dist/core/p-c4d3c18c.entry.js.map +0 -1
  785. package/dist/core/p-c6dd4f47.entry.js +0 -2
  786. package/dist/core/p-c6dd4f47.entry.js.map +0 -1
  787. package/dist/core/p-cadb531f.entry.js.map +0 -1
  788. package/dist/core/p-cc83692e.entry.js +0 -2
  789. package/dist/core/p-cc83692e.entry.js.map +0 -1
  790. package/dist/core/p-dd3c3e3c.entry.js +0 -2
  791. package/dist/core/p-dd3c3e3c.entry.js.map +0 -1
  792. package/dist/core/p-df5caf13.entry.js +0 -2
  793. package/dist/core/p-df5caf13.entry.js.map +0 -1
  794. package/dist/core/p-e106305b.entry.js +0 -2
  795. package/dist/core/p-e106305b.entry.js.map +0 -1
  796. package/dist/core/p-e28af65b.js +0 -2
  797. package/dist/core/p-e28af65b.js.map +0 -1
  798. package/dist/core/p-e590f1d2.entry.js +0 -2
  799. package/dist/core/p-e590f1d2.entry.js.map +0 -1
  800. package/dist/core/p-e93e9aa3.entry.js.map +0 -1
  801. package/dist/core/p-ecfb2e6b.entry.js +0 -2
  802. package/dist/core/p-ecfb2e6b.entry.js.map +0 -1
  803. package/dist/core/p-f9370be6.js.map +0 -1
  804. package/dist/esm/check-icon-53f1d9e5.js.map +0 -1
  805. package/dist/esm/chevron-icon-5b38c60a.js +0 -8
  806. package/dist/esm/chevron-icon-5b38c60a.js.map +0 -1
  807. package/dist/esm/error-icon-6046a380.js +0 -15
  808. package/dist/esm/error-icon-6046a380.js.map +0 -1
  809. package/dist/esm/helpers-3d41833c.js.map +0 -1
  810. package/dist/esm/index-1500de1f.js.map +0 -1
  811. package/dist/esm/success-icon-2f71b115.js +0 -9
  812. package/dist/esm/success-icon-2f71b115.js.map +0 -1
  813. package/dist/types/components/ic-alert/ic-alert.types.d.ts +0 -1
  814. /package/dist/collection/{components/ic-link/assets → assets}/OpenInNew.svg +0 -0
  815. /package/dist/core/{p-1e7b4310.js.map → p-24240e11.js.map} +0 -0
  816. /package/dist/core/{p-ae6aa67f.js.map → p-8c7f4343.js.map} +0 -0
  817. /package/dist/core/{p-bf5717ca.js.map → p-8d4f7027.js.map} +0 -0
@@ -1,6 +1,6 @@
1
1
  import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
2
2
 
3
- const icInputContainerCss = "ic-input-container .component-container{display:flex;flex-direction:column;position:relative}";
3
+ const icInputContainerCss = "ic-input-container .component-container{display:flex;flex-direction:column}";
4
4
 
5
5
  const InputContainer = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
6
6
  constructor() {
@@ -1 +1 @@
1
- {"file":"ic-input-container2.js","mappings":";;AAAA,MAAM,mBAAmB,GAAG,+FAA+F;;MCM9G,cAAc;;;;oBAII,KAAK;oBAKL,KAAK;;EAElC,MAAM;IACJ,QACE,EAAC,IAAI,QACH,WACE,KAAK,EAAE;QACL,CAAC,qBAAqB,GAAG,IAAI;QAC7B,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ;QAC3B,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ;OAC5B,IAED,eAAa,CACT,CACD,EACP;GACH;;;;;;;;;;;;;;;;;;;;;;","names":[],"sources":["./src/components/ic-input-container/ic-input-container.css?tag=ic-input-container","./src/components/ic-input-container/ic-input-container.tsx"],"sourcesContent":["ic-input-container .component-container {\n display: flex;\n flex-direction: column;\n position: relative;\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 * disabled\n */\n @Prop() disabled?: boolean = false;\n\n /**\n * readonly\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"],"version":3}
1
+ {"file":"ic-input-container2.js","mappings":";;AAAA,MAAM,mBAAmB,GAAG,6EAA6E;;MCM5F,cAAc;;;;oBAII,KAAK;oBAKL,KAAK;;EAElC,MAAM;IACJ,QACE,EAAC,IAAI,QACH,WACE,KAAK,EAAE;QACL,CAAC,qBAAqB,GAAG,IAAI;QAC7B,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ;QAC3B,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ;OAC5B,IAED,eAAa,CACT,CACD,EACP;GACH;;;;;;;;;;;;;;;;;;;;;;","names":[],"sources":["./src/components/ic-input-container/ic-input-container.css?tag=ic-input-container","./src/components/ic-input-container/ic-input-container.tsx"],"sourcesContent":["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"],"version":3}
@@ -1,5 +1,5 @@
1
1
  import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
2
- import { a as onComponentRequiredPropUndefined, H as getInputHelperTextID } from './helpers.js';
2
+ import { a as onComponentRequiredPropUndefined, K as getInputHelperTextID } from './helpers.js';
3
3
  import { d as defineCustomElement$1 } from './ic-typography2.js';
4
4
 
5
5
  const icInputLabelCss = "ic-input-label{margin-bottom:var(--ic-space-xs)}ic-input-label.with-helper{margin-bottom:var(--ic-space-xxxs)}ic-input-label.disabled{color:var(--ic-color-tertiary-text)}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)}";
@@ -1 +1 @@
1
- {"file":"ic-input-label2.js","mappings":";;;;AAAA,MAAM,eAAe,GAAG,wmBAAwmB;;MCWnnB,UAAU;;;;;oBAQO,KAAK;sBAIJ,EAAE;;oBAQH,KAAK;oBAIL,KAAK;iBAIP,KAAK;gBAIN,KAAK;;EAE9B,gBAAgB;IACd,gCAAgC,CAC9B,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,EACzC,aAAa,CACd,CAAC;GACH;EAED,MAAM;IACJ,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,GACpE,IAAI,CAAC;IACP,MAAM,SAAS,GAAG,QAAQ,GAAG,KAAK,GAAG,IAAI,GAAG,KAAK,CAAC;IAClD,MAAM,YAAY,GAAG,QAAQ,IAC3B,GAAG,SAAS,EAAE,KAEd,aAAO,OAAO,EAAE,IAAI,CAAC,GAAG,IAAG,SAAS,CAAS,CAC9C,CAAC;IAEF,MAAM,EAAE,GAAG,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAE1C,QACE,EAAC,IAAI,IACH,KAAK,EAAE;QACL,CAAC,UAAU,GAAG,QAAQ;QACtB,CAAC,UAAU,GAAG,QAAQ;QACtB,CAAC,aAAa,GAAG,UAAU,KAAK,EAAE;OACnC,IAED,qBACE,OAAO,EAAC,OAAO,EACf,KAAK,EAAE;QACL,CAAC,gBAAgB,GAAG,QAAQ;QAC5B,CAAC,aAAa,GAAG,KAAK,IAAI,EAAE,QAAQ,IAAI,QAAQ,CAAC;QACjD,CAAC,MAAM,GAAG,IAAI;OACf,IAEA,YAAY,CACC,EAEf,UAAU,KAAK,EAAE,KAChB,qBACE,OAAO,EAAC,SAAS,EACjB,KAAK,EAAE;QACL,CAAC,YAAY,GAAG,IAAI;QACpB,CAAC,mBAAmB,GAAG,CAAC,QAAQ,IAAI,CAAC,QAAQ;QAC7C,CAAC,qBAAqB,GAAG,QAAQ;OAClC,IAED,YAAM,EAAE,EAAE,EAAE,IAAG,UAAU,CAAQ,CACnB,CACjB,CACI,EACP;GACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":[],"sources":["./src/components/ic-input-label/ic-input-label.css?tag=ic-input-label","./src/components/ic-input-label/ic-input-label.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.disabled {\n color: var(--ic-color-tertiary-text);\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 * for\n */\n @Prop() for: string;\n /**\n * required\n */\n @Prop() required: boolean = false;\n /**\n * helperText\n */\n @Prop() helperText: string = \"\";\n /**\n * label\n */\n @Prop() label!: string;\n /**\n * disabled\n */\n @Prop() disabled: boolean = false;\n /**\n * readonly\n */\n @Prop() readonly: boolean = false;\n /**\n * error\n */\n @Prop() error?: boolean = false;\n /**\n * dark\n */\n @Prop() dark?: 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"],"version":3}
1
+ {"file":"ic-input-label2.js","mappings":";;;;AAAA,MAAM,eAAe,GAAG,wmBAAwmB;;MCWnnB,UAAU;;;;;oBAQO,KAAK;sBAIJ,EAAE;;oBAQH,KAAK;oBAIL,KAAK;iBAIP,KAAK;gBAIN,KAAK;;EAE9B,gBAAgB;IACd,gCAAgC,CAC9B,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,EACzC,aAAa,CACd,CAAC;GACH;EAED,MAAM;IACJ,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,GACpE,IAAI,CAAC;IACP,MAAM,SAAS,GAAG,QAAQ,GAAG,KAAK,GAAG,IAAI,GAAG,KAAK,CAAC;IAClD,MAAM,YAAY,GAAG,QAAQ,IAC3B,GAAG,SAAS,EAAE,KAEd,aAAO,OAAO,EAAE,IAAI,CAAC,GAAG,IAAG,SAAS,CAAS,CAC9C,CAAC;IAEF,MAAM,EAAE,GAAG,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAE1C,QACE,EAAC,IAAI,IACH,KAAK,EAAE;QACL,CAAC,UAAU,GAAG,QAAQ;QACtB,CAAC,UAAU,GAAG,QAAQ;QACtB,CAAC,aAAa,GAAG,UAAU,KAAK,EAAE;OACnC,IAED,qBACE,OAAO,EAAC,OAAO,EACf,KAAK,EAAE;QACL,CAAC,gBAAgB,GAAG,QAAQ;QAC5B,CAAC,aAAa,GAAG,KAAK,IAAI,EAAE,QAAQ,IAAI,QAAQ,CAAC;QACjD,CAAC,MAAM,GAAG,IAAI;OACf,IAEA,YAAY,CACC,EAEf,UAAU,KAAK,EAAE,KAChB,qBACE,OAAO,EAAC,SAAS,EACjB,KAAK,EAAE;QACL,CAAC,YAAY,GAAG,IAAI;QACpB,CAAC,mBAAmB,GAAG,CAAC,QAAQ,IAAI,CAAC,QAAQ;QAC7C,CAAC,qBAAqB,GAAG,QAAQ;OAClC,IAED,YAAM,EAAE,EAAE,EAAE,IAAG,UAAU,CAAQ,CACnB,CACjB,CACI,EACP;GACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":[],"sources":["./src/components/ic-input-label/ic-input-label.css?tag=ic-input-label","./src/components/ic-input-label/ic-input-label.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.disabled {\n color: var(--ic-color-tertiary-text);\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 * The ID of the form element the label is bound to.\n */\n @Prop() for: string;\n /**\n * If `true`, the input label will require a value.\n */\n @Prop() required: boolean = false;\n /**\n * The helper text that will be displayed.\n */\n @Prop() helperText: string = \"\";\n /**\n * The text content of the label.\n */\n @Prop() label!: string;\n /**\n * If `true`, the disabled state will be set.\n */\n @Prop() disabled: boolean = false;\n /**\n * If `true`, the readonly state will be set.\n */\n @Prop() readonly: boolean = false;\n /**\n * If `true`, the input label will display with error styling.\n */\n @Prop() error?: boolean = false;\n /**\n * If `true`, the dark variant of the input label will be displayed.\n */\n @Prop() dark?: 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"],"version":3}
@@ -1,11 +1,9 @@
1
1
  import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
2
2
  import { a as IcInformationStatus } from './types.js';
3
- import { w as warningIcon, e as errorIcon } from './error-icon.js';
4
- import { s as successIcon } from './success-icon.js';
5
- import { a as onComponentRequiredPropUndefined, J as getInputValidationTextID } from './helpers.js';
3
+ import { a as onComponentRequiredPropUndefined, L as getInputValidationTextID, M as warningIcon, N as errorIcon, J as successIcon } from './helpers.js';
6
4
  import { d as defineCustomElement$1 } from './ic-typography2.js';
7
5
 
8
- const icInputValidationCss = "ic-input-validation{min-height:28px;width:var(--input-width, 320px);margin-top:var(--ic-space-xxxs);display:flex}ic-input-validation.fullwidth{width:100%}ic-input-validation.error{color:var(--ic-status-error)}ic-input-validation.success{color:var(--ic-status-success)}ic-input-validation span.status-icon{padding-right:var(--ic-space-xxs)}ic-input-validation span.status-icon>svg{height:20px;width:20px}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-mid)}ic-input-validation .statustext{flex-grow:1}";
6
+ const icInputValidationCss = "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.error{color:var(--ic-status-error)}ic-input-validation.success{color:var(--ic-status-success)}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-mid)}ic-input-validation .statustext{flex-grow:1}";
9
7
 
10
8
  const icon = {
11
9
  [IcInformationStatus.Warning]: warningIcon,
@@ -1 +1 @@
1
- {"file":"ic-input-validation2.js","mappings":";;;;;;;AAAA,MAAM,oBAAoB,GAAG,ypBAAypB;;ACgBtrB,MAAM,IAAI,GAAG;EACX,CAAC,mBAAmB,CAAC,OAAO,GAAG,WAAW;EAC1C,CAAC,mBAAmB,CAAC,KAAK,GAAG,SAAS;EACtC,CAAC,mBAAmB,CAAC,OAAO,GAAG,WAAW;CAC3C,CAAC;MASW,eAAe;;;;;;kBAcmB,EAAE;qBAIlB,KAAK;wBAIa,QAAQ;;EAEvD,gBAAgB;IACd,gCAAgC,CAC9B,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC,EAC7C,kBAAkB,CACnB,CAAC;GACH;EAED,MAAM;IACJ,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,KAAK,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;IAChE,MAAM,EAAE,GAAG,wBAAwB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC9C,QACE,EAAC,IAAI,IACH,KAAK,EAAE;QACL,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,KAAK,EAAE;QACjC,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS;OAC9B,IAEA,WAAW,KAAK,EAAE,KACjB,YACE,KAAK,EAAE;QACL,CAAC,aAAa,GAAG,IAAI;QACrB,CAAC,QAAQ,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI;OAC9B,EACD,SAAS,EAAE,WAAW,GACtB,CACH,EAED,qBAAe,OAAO,EAAC,SAAS,EAAC,KAAK,EAAC,YAAY,IACjD,yBAAiB,IAAI,CAAC,YAAY,EAAE,EAAE,EAAE,EAAE,IACvC,IAAI,CAAC,OAAO,CACR,CACO,EAEhB,YAAM,IAAI,EAAC,8BAA8B,GAAQ,CAC5C,EACP;GACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":[],"sources":["./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-validation {\n min-height: 28px;\n width: var(--input-width, 320px);\n margin-top: var(--ic-space-xxxs);\n display: flex;\n}\n\nic-input-validation.fullwidth {\n width: 100%;\n}\n\nic-input-validation.error {\n color: var(--ic-status-error);\n}\n\nic-input-validation.success {\n color: var(--ic-status-success);\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: 20px;\n width: 20px;\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-mid);\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 validation message to display\n */\n @Prop() message!: string;\n /**\n * The id of the input field the message relates to\n */\n @Prop() for: string;\n /**\n * The status\n */\n @Prop() status: IcInformationStatusOrEmpty = \"\";\n /**\n * If true then fill width of container\n */\n @Prop() fullWidth: boolean = false;\n /**\n * aria live mode to apply to message\n */\n @Prop() ariaLiveMode: IcAriaLiveModeVariants = \"polite\";\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"],"version":3}
1
+ {"file":"ic-input-validation2.js","mappings":";;;;;AAAA,MAAM,oBAAoB,GAAG,6oBAA6oB;;ACgB1qB,MAAM,IAAI,GAAG;EACX,CAAC,mBAAmB,CAAC,OAAO,GAAG,WAAW;EAC1C,CAAC,mBAAmB,CAAC,KAAK,GAAG,SAAS;EACtC,CAAC,mBAAmB,CAAC,OAAO,GAAG,WAAW;CAC3C,CAAC;MASW,eAAe;;;;;;kBAcmB,EAAE;qBAIlB,KAAK;wBAIa,QAAQ;;EAEvD,gBAAgB;IACd,gCAAgC,CAC9B,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC,EAC7C,kBAAkB,CACnB,CAAC;GACH;EAED,MAAM;IACJ,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,KAAK,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;IAChE,MAAM,EAAE,GAAG,wBAAwB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC9C,QACE,EAAC,IAAI,IACH,KAAK,EAAE;QACL,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,KAAK,EAAE;QACjC,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS;OAC9B,IAEA,WAAW,KAAK,EAAE,KACjB,YACE,KAAK,EAAE;QACL,CAAC,aAAa,GAAG,IAAI;QACrB,CAAC,QAAQ,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI;OAC9B,EACD,SAAS,EAAE,WAAW,GACtB,CACH,EAED,qBAAe,OAAO,EAAC,SAAS,EAAC,KAAK,EAAC,YAAY,IACjD,yBAAiB,IAAI,CAAC,YAAY,EAAE,EAAE,EAAE,EAAE,IACvC,IAAI,CAAC,OAAO,CACR,CACO,EAEhB,YAAM,IAAI,EAAC,8BAA8B,GAAQ,CAC5C,EACP;GACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":[],"sources":["./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-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.error {\n color: var(--ic-status-error);\n}\n\nic-input-validation.success {\n color: var(--ic-status-success);\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-mid);\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 validation message to display.\n */\n @Prop() message!: string;\n /**\n * The ID of the form element the validation is bound to.\n */\n @Prop() for: string;\n /**\n * The status of the validation - e.g. 'error' | 'warning' | 'success'.\n */\n @Prop() status: IcInformationStatusOrEmpty = \"\";\n /**\n * If `true`, the input validation will fill the width of the container.\n */\n @Prop() fullWidth: boolean = false;\n /**\n * The ARIA live mode to apply to the message.\n */\n @Prop() ariaLiveMode: IcAriaLiveModeVariants = \"polite\";\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"],"version":3}
@@ -1,10 +1,9 @@
1
1
  import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
2
+ import { O as OpenInNew } from './OpenInNew.js';
2
3
  import { b as getThemeFromContext, m as inheritAttributes, n as IC_INHERITED_ARIA } from './helpers.js';
3
4
  import { I as IcThemeForegroundEnum } from './types.js';
4
5
 
5
- const OpenInNew = `<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px"><path d="M0 0h24v24H0z" fill="none"/><path d="M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z"/></svg>`;
6
-
7
- const icLinkCss = "/*! 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(.link) .ic-link,:host(.link) ::slotted(a){color:var(--ic-hyperlink);text-decoration:underline;font-weight:var(--ic-font-weight-bold);transition:var(--ic-easing-transition-fast)}:host(.link.dark) .ic-link.dark,:host(.link.dark) ::slotted(a){color:var(--ic-color-primary-text)}:host(.link.light) .ic-link.light,:host(.link.light) ::slotted(a){color:var(--ic-color-white-text)}:host(.link) .ic-link:visited,:host(.link) ::slotted(a:visited){color:var(--ic-hyperlink-visited)}:host(.link) .ic-link:hover,:host(.link) .ic-link:focus,:host(.link) ::slotted(a:hover),:host(.link) ::slotted(a:focus){text-decoration-line:underline;text-decoration-thickness:25%;text-underline-offset:25%}:host(.link) .ic-link:hover,:host(.link) ::slotted(a:hover){outline:none}:host(.link) .ic-link:focus,:host(.link) ::slotted(a:focus){outline:var(--ic-hc-focus-outline)}:host(.link) .ic-link:active,:host(.link) .ic-link:focus:active,:host(.link) .ic-link:visited:active,:host(.link) ::slotted(a:active),:host(.link) ::slotted(a:focus:active),:host(.link) ::slotted(a:visited:active){text-decoration:none}.ic-link-open-in-new-icon{vertical-align:middle;margin-left:var(--ic-space-xxs)}.ic-link>.ic-link-open-in-new-icon{fill:var(--ic-hyperlink)}.ic-link.dark>.ic-link-open-in-new-icon{fill:var(--ic-color-primary-text)}.ic-link.light>.ic-link-open-in-new-icon{fill:var(--ic-color-white-text)}.ic-link-open-in-new-icon>svg{width:var(--ic-space-md);height:var(--ic-space-md);fill:currentcolor}.ic-link:visited>.ic-link-open-in-new-icon{fill:var(--ic-hyperlink-visited)}.ic-link.light:visited>.ic-link-open-in-new-icon{fill:var(--ic-hyperlink-contrast-visited)}:host(.breadcrumb-link) .ic-link{display:var(--breadcrumb-link-display);align-items:var(--breadcrumb-link-align-items);gap:var(--breadcrumb-link-gap)}:host(.breadcrumb-link) .ic-link ::slotted(.back-icon){height:var(--ic-space-lg);width:var(--ic-space-lg)}:host(.breadcrumb-link.current-page) a,:host(.breadcrumb-link.current-page) ::slotted(a){font-weight:normal;color:inherit;text-decoration:none;display:flex;align-items:center}:host(.breadcrumb-link.current-page) .ic-link,:host(.breadcrumb-link.current-page) ::slotted(a:focus){outline:var(--ic-hc-focus-outline);text-decoration:none}:host(.breadcrumb-link.current-page) .ic-link:visited{color:var(--ic-color-primary-text)}";
6
+ const icLinkCss = "/*! 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(.link) .ic-link,:host(.link) ::slotted(a){color:var(--ic-hyperlink);text-decoration:underline;font-weight:var(--ic-font-weight-bold);transition:var(--ic-easing-transition-fast)}:host(.link.dark) .ic-link.dark,:host(.link.dark) ::slotted(a){color:var(--ic-color-primary-text)}:host(.link.light) .ic-link.light,:host(.link.light) ::slotted(a){color:var(--ic-color-white-text)}:host(.link) .ic-link:visited,:host(.link) ::slotted(a:visited){color:var(--ic-hyperlink-visited)}:host(.link) .ic-link:hover,:host(.link) .ic-link:focus,:host(.link) ::slotted(a:hover),:host(.link) ::slotted(a:focus){text-decoration-line:underline;text-decoration-thickness:25%;text-underline-offset:25%;outline:none}:host(.link) .ic-link:active,:host(.link) .ic-link:focus:active,:host(.link) .ic-link:visited:active,:host(.link) ::slotted(a:active),:host(.link) ::slotted(a:focus:active),:host(.link) ::slotted(a:visited:active){text-decoration:none}.ic-link-open-in-new-icon{vertical-align:middle;margin-left:var(--ic-space-xxs)}.ic-link>.ic-link-open-in-new-icon{fill:var(--ic-hyperlink)}.ic-link.dark>.ic-link-open-in-new-icon{fill:var(--ic-color-primary-text)}.ic-link.light>.ic-link-open-in-new-icon{fill:var(--ic-color-white-text)}.ic-link-open-in-new-icon>svg{width:var(--ic-space-md);height:var(--ic-space-md);fill:currentcolor}.ic-link:visited>.ic-link-open-in-new-icon{fill:var(--ic-hyperlink-visited)}.ic-link.light:visited>.ic-link-open-in-new-icon{fill:var(--ic-hyperlink-contrast-visited)}:host(.breadcrumb-link) .ic-link{display:var(--breadcrumb-link-display);align-items:var(--breadcrumb-link-align-items);gap:var(--breadcrumb-link-gap)}:host(.breadcrumb-link) .ic-link ::slotted(.back-icon){height:var(--ic-space-lg);width:var(--ic-space-lg)}:host(.breadcrumb-link.current-page) a,:host(.breadcrumb-link.current-page) ::slotted(a){font-weight:normal;color:inherit;text-decoration:none;display:flex;align-items:center}:host(.breadcrumb-link.current-page) .ic-link,:host(.breadcrumb-link.current-page) ::slotted(a:focus){outline:var(--ic-hc-focus-outline);text-decoration:none}:host(.breadcrumb-link.current-page) .ic-link:visited{color:var(--ic-color-primary-text)}";
8
7
 
9
8
  const Link = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
10
9
  constructor() {
@@ -36,13 +35,19 @@ const Link = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
36
35
  break;
37
36
  }
38
37
  }
38
+ /**
39
+ * Sets focus on the link.
40
+ */
41
+ async setFocus() {
42
+ if (this.el.shadowRoot.querySelector("a")) {
43
+ this.el.shadowRoot.querySelector("a").focus();
44
+ }
45
+ }
39
46
  componentWillLoad() {
40
47
  this.inheritedAttributes = inheritAttributes(this.el, [
41
48
  ...IC_INHERITED_ARIA,
42
49
  "aria-expanded",
43
50
  ]);
44
- }
45
- componentDidLoad() {
46
51
  this.updateTheme();
47
52
  }
48
53
  hasRouterSlot() {
@@ -59,9 +64,10 @@ const Link = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
59
64
  [`${appearance}`]: href !== null,
60
65
  }, download: download !== false ? download : null, href: href, hrefLang: hreflang, referrerPolicy: referrerpolicy, rel: rel, target: target, tabindex: href !== null ? "0" : "-1" }, this.inheritedAttributes), h("slot", null), showIcon && (h("span", { class: "ic-link-open-in-new-icon", innerHTML: OpenInNew }))))));
61
66
  }
67
+ static get delegatesFocus() { return true; }
62
68
  get el() { return this; }
63
69
  static get style() { return icLinkCss; }
64
- }, [1, "ic-link", {
70
+ }, [17, "ic-link", {
65
71
  "download": [8],
66
72
  "href": [1],
67
73
  "hreflang": [1],
@@ -69,8 +75,9 @@ const Link = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
69
75
  "rel": [1],
70
76
  "target": [1],
71
77
  "showIcon": [4, "show-icon"],
72
- "appearance": [1025]
73
- }, [[4, "icThemeChange", "themeChangeHandler"]]]);
78
+ "appearance": [1025],
79
+ "setFocus": [64]
80
+ }, [[4, "themeChange", "themeChangeHandler"]]]);
74
81
  function defineCustomElement() {
75
82
  if (typeof customElements === "undefined") {
76
83
  return;
@@ -1 +1 @@
1
- {"file":"ic-link2.js","mappings":";;;;;;AAAA,MAAM,SAAS,GAAG,gpJAAgpJ;;MCoBrpJ,IAAI;;;;;IACP,wBAAmB,GAA6B,EAAE,CAAC;oBAQrB,KAAK;gBAKnB,IAAI;;;;;;sBA8B8B,SAAS;;EAGnE,kBAAkB,CAAC,EAAe;IAChC,MAAM,KAAK,GAAY,EAAE,CAAC,MAAM,CAAC;IACjC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;GAC9B;EAEO,WAAW,CAAC,WAA8B,IAAI;IACpD,MAAM,KAAK,GAAG,mBAAmB,CAAC,IAAI,CAAC,EAAE,EAAE,QAAQ,IAAI,IAAI,CAAC,CAAC;IAE7D,QAAQ,KAAK;MACX,KAAK,qBAAqB,CAAC,KAAK;QAC9B,IAAI,CAAC,UAAU,GAAG,qBAAqB,CAAC,KAAK,CAAC;QAC9C,MAAM;MACR,KAAK,qBAAqB,CAAC,IAAI;QAC7B,IAAI,CAAC,UAAU,GAAG,qBAAqB,CAAC,IAAI,CAAC;QAC7C,MAAM;KACT;GACF;EAED,iBAAiB;IACf,IAAI,CAAC,mBAAmB,GAAG,iBAAiB,CAAC,IAAI,CAAC,EAAE,EAAE;MACpD,GAAG,iBAAiB;MACpB,eAAe;KAChB,CAAC,CAAC;GACJ;EAED,gBAAgB;IACd,IAAI,CAAC,WAAW,EAAE,CAAC;GACpB;EAEO,aAAa;IACnB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC;IAChE,IAAI,IAAI,CAAC,UAAU,EAAE;MACnB,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC;KACzD;IACD,OAAO,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;GAC1B;EAED,MAAM;IACJ,MAAM,EACJ,QAAQ,EACR,IAAI,EACJ,QAAQ,EACR,cAAc,EACd,GAAG,EACH,MAAM,EACN,QAAQ,EACR,UAAU,GACX,GAAG,IAAI,CAAC;IAET,QACE,EAAC,IAAI,IAAC,KAAK,EAAE,EAAE,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC,GAAG,UAAU,EAAE,GAAG,IAAI,EAAE,IACrD,IAAI,CAAC,aAAa,EAAE,IACnB,YAAM,IAAI,EAAC,aAAa,GAAQ,KAEhC,uBACE,KAAK,EAAE;QACL,CAAC,SAAS,GAAG,IAAI,KAAK,IAAI;QAC1B,CAAC,GAAG,UAAU,EAAE,GAAG,IAAI,KAAK,IAAI;OACjC,EACD,QAAQ,EAAE,QAAQ,KAAK,KAAK,GAAG,QAAQ,GAAG,IAAI,EAC9C,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,QAAQ,EAClB,cAAc,EAAE,cAAc,EAC9B,GAAG,EAAE,GAAG,EACR,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,IAAI,KAAK,IAAI,GAAG,GAAG,GAAG,IAAI,IAChC,IAAI,CAAC,mBAAmB,GAE5B,eAAQ,EACP,QAAQ,KACP,YAAM,KAAK,EAAC,0BAA0B,EAAC,SAAS,EAAE,SAAS,GAAI,CAChE,CACC,CACL,CACI,EACP;GACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":[],"sources":["./src/components/ic-link/ic-link.css?tag=ic-link&encapsulation=shadow","./src/components/ic-link/ic-link.tsx"],"sourcesContent":["@import \"../../global/normalise.css\";\n\n:host(.link) .ic-link,\n:host(.link) ::slotted(a) {\n color: var(--ic-hyperlink);\n text-decoration: underline;\n font-weight: var(--ic-font-weight-bold);\n transition: var(--ic-easing-transition-fast);\n}\n\n:host(.link.dark) .ic-link.dark,\n:host(.link.dark) ::slotted(a) {\n color: var(--ic-color-primary-text);\n}\n\n:host(.link.light) .ic-link.light,\n:host(.link.light) ::slotted(a) {\n color: var(--ic-color-white-text);\n}\n\n:host(.link) .ic-link:visited,\n:host(.link) ::slotted(a:visited) {\n color: var(--ic-hyperlink-visited);\n}\n\n:host(.link) .ic-link:hover,\n:host(.link) .ic-link:focus,\n:host(.link) ::slotted(a:hover),\n:host(.link) ::slotted(a:focus) {\n text-decoration-line: underline;\n text-decoration-thickness: 25%;\n text-underline-offset: 25%;\n}\n\n:host(.link) .ic-link:hover,\n:host(.link) ::slotted(a:hover) {\n outline: none;\n}\n\n:host(.link) .ic-link:focus,\n:host(.link) ::slotted(a:focus) {\n outline: var(--ic-hc-focus-outline);\n}\n\n:host(.link) .ic-link:active,\n:host(.link) .ic-link:focus:active,\n:host(.link) .ic-link:visited:active,\n:host(.link) ::slotted(a:active),\n:host(.link) ::slotted(a:focus:active),\n:host(.link) ::slotted(a:visited:active) {\n text-decoration: none;\n}\n\n.ic-link-open-in-new-icon {\n vertical-align: middle;\n margin-left: var(--ic-space-xxs);\n}\n\n.ic-link > .ic-link-open-in-new-icon {\n fill: var(--ic-hyperlink);\n}\n\n.ic-link.dark > .ic-link-open-in-new-icon {\n fill: var(--ic-color-primary-text);\n}\n\n.ic-link.light > .ic-link-open-in-new-icon {\n fill: var(--ic-color-white-text);\n}\n\n.ic-link-open-in-new-icon > svg {\n width: var(--ic-space-md);\n height: var(--ic-space-md);\n fill: currentcolor;\n}\n\n.ic-link:visited > .ic-link-open-in-new-icon {\n fill: var(--ic-hyperlink-visited);\n}\n\n.ic-link.light:visited > .ic-link-open-in-new-icon {\n fill: var(--ic-hyperlink-contrast-visited);\n}\n\n:host(.breadcrumb-link) .ic-link {\n display: var(--breadcrumb-link-display);\n align-items: var(--breadcrumb-link-align-items);\n gap: var(--breadcrumb-link-gap);\n}\n\n:host(.breadcrumb-link) .ic-link ::slotted(.back-icon) {\n height: var(--ic-space-lg);\n width: var(--ic-space-lg);\n}\n\n:host(.breadcrumb-link.current-page) a,\n:host(.breadcrumb-link.current-page) ::slotted(a) {\n font-weight: normal;\n color: inherit;\n text-decoration: none;\n display: flex;\n align-items: center;\n}\n\n:host(.breadcrumb-link.current-page) .ic-link,\n:host(.breadcrumb-link.current-page) ::slotted(a:focus) {\n outline: var(--ic-hc-focus-outline);\n text-decoration: none;\n}\n\n:host(.breadcrumb-link.current-page) .ic-link:visited {\n color: var(--ic-color-primary-text);\n}\n","import { Component, Element, Prop, h, Host, Listen } from \"@stencil/core\";\n\nimport OpenInNew from \"./assets/OpenInNew.svg\";\nimport { getThemeFromContext, inheritAttributes } from \"../../utils/helpers\";\nimport { IC_INHERITED_ARIA } from \"../../utils/constants\";\nimport {\n IcTheme,\n IcThemeForeground,\n IcThemeForegroundEnum,\n} from \"../../utils/types\";\n\n/**\n * @slot router-item - Handle routing by nesting your routes in this slot\n */\n\n@Component({\n tag: \"ic-link\",\n styleUrl: \"ic-link.css\",\n shadow: true,\n})\nexport class Link {\n private inheritedAttributes: { [k: string]: unknown } = {};\n private routerSlot: HTMLElement;\n\n @Element() el: HTMLIcLinkElement;\n\n /**\n * Prompts the user to 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.\n */\n @Prop() href?: string = null;\n\n /**\n * Hints at the human language of the linked URL.\n */\n @Prop() hreflang?: 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 * Where 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 * Determines whether the 'open in new tab/window' icon is to be displayed.\n */\n @Prop() showIcon?: boolean;\n\n /**\n * Determines the whether the appearance is dark, light, or the default.\n */\n @Prop({ mutable: true }) appearance?: IcThemeForeground = \"default\";\n\n @Listen(\"icThemeChange\", { target: \"document\" })\n themeChangeHandler(ev: CustomEvent): void {\n const theme: IcTheme = ev.detail;\n this.updateTheme(theme.mode);\n }\n\n private updateTheme(newTheme: IcThemeForeground = null): void {\n const theme = getThemeFromContext(this.el, newTheme || null);\n\n switch (theme) {\n case IcThemeForegroundEnum.Light:\n this.appearance = IcThemeForegroundEnum.Light;\n break;\n case IcThemeForegroundEnum.Dark:\n this.appearance = IcThemeForegroundEnum.Dark;\n break;\n }\n }\n\n componentWillLoad(): void {\n this.inheritedAttributes = inheritAttributes(this.el, [\n ...IC_INHERITED_ARIA,\n \"aria-expanded\",\n ]);\n }\n\n componentDidLoad(): void {\n this.updateTheme();\n }\n\n private hasRouterSlot(): boolean {\n this.routerSlot = this.el.querySelector('[slot=\"router-item\"]');\n if (this.routerSlot) {\n this.routerSlot.ariaLabel = this.routerSlot.textContent;\n }\n return !!this.routerSlot;\n }\n\n render() {\n const {\n download,\n href,\n hreflang,\n referrerpolicy,\n rel,\n target,\n showIcon,\n appearance,\n } = this;\n\n return (\n <Host class={{ [\"link\"]: true, [`${appearance}`]: true }}>\n {this.hasRouterSlot() ? (\n <slot name=\"router-item\"></slot>\n ) : (\n <a\n class={{\n [\"ic-link\"]: href !== null,\n [`${appearance}`]: href !== null,\n }}\n download={download !== false ? download : null}\n href={href}\n hrefLang={hreflang}\n referrerPolicy={referrerpolicy}\n rel={rel}\n target={target}\n tabindex={href !== null ? \"0\" : \"-1\"}\n {...this.inheritedAttributes}\n >\n <slot />\n {showIcon && (\n <span class=\"ic-link-open-in-new-icon\" innerHTML={OpenInNew} />\n )}\n </a>\n )}\n </Host>\n );\n }\n}\n"],"version":3}
1
+ {"file":"ic-link2.js","mappings":";;;;;AAAA,MAAM,SAAS,GAAG,q/IAAq/I;;MC8B1/I,IAAI;;;;;IACP,wBAAmB,GAA6B,EAAE,CAAC;oBAQrB,KAAK;gBAKnB,IAAI;;;;;;sBA8B8B,SAAS;;EAGnE,kBAAkB,CAAC,EAAe;IAChC,MAAM,KAAK,GAAY,EAAE,CAAC,MAAM,CAAC;IACjC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;GAC9B;EAEO,WAAW,CAAC,WAA8B,IAAI;IACpD,MAAM,KAAK,GAAG,mBAAmB,CAAC,IAAI,CAAC,EAAE,EAAE,QAAQ,IAAI,IAAI,CAAC,CAAC;IAE7D,QAAQ,KAAK;MACX,KAAK,qBAAqB,CAAC,KAAK;QAC9B,IAAI,CAAC,UAAU,GAAG,qBAAqB,CAAC,KAAK,CAAC;QAC9C,MAAM;MACR,KAAK,qBAAqB,CAAC,IAAI;QAC7B,IAAI,CAAC,UAAU,GAAG,qBAAqB,CAAC,IAAI,CAAC;QAC7C,MAAM;KACT;GACF;;;;EAMD,MAAM,QAAQ;IACZ,IAAI,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE;MACzC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC;KAC/C;GACF;EAED,iBAAiB;IACf,IAAI,CAAC,mBAAmB,GAAG,iBAAiB,CAAC,IAAI,CAAC,EAAE,EAAE;MACpD,GAAG,iBAAiB;MACpB,eAAe;KAChB,CAAC,CAAC;IAEH,IAAI,CAAC,WAAW,EAAE,CAAC;GACpB;EAEO,aAAa;IACnB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC;IAChE,IAAI,IAAI,CAAC,UAAU,EAAE;MACnB,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC;KACzD;IACD,OAAO,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;GAC1B;EAED,MAAM;IACJ,MAAM,EACJ,QAAQ,EACR,IAAI,EACJ,QAAQ,EACR,cAAc,EACd,GAAG,EACH,MAAM,EACN,QAAQ,EACR,UAAU,GACX,GAAG,IAAI,CAAC;IAET,QACE,EAAC,IAAI,IAAC,KAAK,EAAE,EAAE,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC,GAAG,UAAU,EAAE,GAAG,IAAI,EAAE,IACrD,IAAI,CAAC,aAAa,EAAE,IACnB,YAAM,IAAI,EAAC,aAAa,GAAQ,KAEhC,uBACE,KAAK,EAAE;QACL,CAAC,SAAS,GAAG,IAAI,KAAK,IAAI;QAC1B,CAAC,GAAG,UAAU,EAAE,GAAG,IAAI,KAAK,IAAI;OACjC,EACD,QAAQ,EAAE,QAAQ,KAAK,KAAK,GAAG,QAAQ,GAAG,IAAI,EAC9C,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,QAAQ,EAClB,cAAc,EAAE,cAAc,EAC9B,GAAG,EAAE,GAAG,EACR,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,IAAI,KAAK,IAAI,GAAG,GAAG,GAAG,IAAI,IAChC,IAAI,CAAC,mBAAmB,GAE5B,eAAQ,EACP,QAAQ,KACP,YAAM,KAAK,EAAC,0BAA0B,EAAC,SAAS,EAAE,SAAS,GAAI,CAChE,CACC,CACL,CACI,EACP;GACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":[],"sources":["./src/components/ic-link/ic-link.css?tag=ic-link&encapsulation=shadow","./src/components/ic-link/ic-link.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n:host(.link) .ic-link,\n:host(.link) ::slotted(a) {\n color: var(--ic-hyperlink);\n text-decoration: underline;\n font-weight: var(--ic-font-weight-bold);\n transition: var(--ic-easing-transition-fast);\n}\n\n:host(.link.dark) .ic-link.dark,\n:host(.link.dark) ::slotted(a) {\n color: var(--ic-color-primary-text);\n}\n\n:host(.link.light) .ic-link.light,\n:host(.link.light) ::slotted(a) {\n color: var(--ic-color-white-text);\n}\n\n:host(.link) .ic-link:visited,\n:host(.link) ::slotted(a:visited) {\n color: var(--ic-hyperlink-visited);\n}\n\n:host(.link) .ic-link:hover,\n:host(.link) .ic-link:focus,\n:host(.link) ::slotted(a:hover),\n:host(.link) ::slotted(a:focus) {\n text-decoration-line: underline;\n text-decoration-thickness: 25%;\n text-underline-offset: 25%;\n outline: none;\n}\n\n:host(.link) .ic-link:active,\n:host(.link) .ic-link:focus:active,\n:host(.link) .ic-link:visited:active,\n:host(.link) ::slotted(a:active),\n:host(.link) ::slotted(a:focus:active),\n:host(.link) ::slotted(a:visited:active) {\n text-decoration: none;\n}\n\n.ic-link-open-in-new-icon {\n vertical-align: middle;\n margin-left: var(--ic-space-xxs);\n}\n\n.ic-link > .ic-link-open-in-new-icon {\n fill: var(--ic-hyperlink);\n}\n\n.ic-link.dark > .ic-link-open-in-new-icon {\n fill: var(--ic-color-primary-text);\n}\n\n.ic-link.light > .ic-link-open-in-new-icon {\n fill: var(--ic-color-white-text);\n}\n\n.ic-link-open-in-new-icon > svg {\n width: var(--ic-space-md);\n height: var(--ic-space-md);\n fill: currentcolor;\n}\n\n.ic-link:visited > .ic-link-open-in-new-icon {\n fill: var(--ic-hyperlink-visited);\n}\n\n.ic-link.light:visited > .ic-link-open-in-new-icon {\n fill: var(--ic-hyperlink-contrast-visited);\n}\n\n:host(.breadcrumb-link) .ic-link {\n display: var(--breadcrumb-link-display);\n align-items: var(--breadcrumb-link-align-items);\n gap: var(--breadcrumb-link-gap);\n}\n\n:host(.breadcrumb-link) .ic-link ::slotted(.back-icon) {\n height: var(--ic-space-lg);\n width: var(--ic-space-lg);\n}\n\n:host(.breadcrumb-link.current-page) a,\n:host(.breadcrumb-link.current-page) ::slotted(a) {\n font-weight: normal;\n color: inherit;\n text-decoration: none;\n display: flex;\n align-items: center;\n}\n\n:host(.breadcrumb-link.current-page) .ic-link,\n:host(.breadcrumb-link.current-page) ::slotted(a:focus) {\n outline: var(--ic-hc-focus-outline);\n text-decoration: none;\n}\n\n:host(.breadcrumb-link.current-page) .ic-link:visited {\n color: var(--ic-color-primary-text);\n}\n","import {\n Component,\n Element,\n Prop,\n h,\n Host,\n Listen,\n Method,\n} from \"@stencil/core\";\n\nimport OpenInNew from \"../../assets/OpenInNew.svg\";\nimport { getThemeFromContext, inheritAttributes } from \"../../utils/helpers\";\nimport { IC_INHERITED_ARIA } from \"../../utils/constants\";\nimport {\n IcTheme,\n IcThemeForeground,\n IcThemeForegroundEnum,\n} from \"../../utils/types\";\n\n/**\n * @slot router-item - Handle routing by nesting your routes in this slot.\n */\n\n@Component({\n tag: \"ic-link\",\n styleUrl: \"ic-link.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class Link {\n private inheritedAttributes: { [k: string]: unknown } = {};\n private routerSlot: HTMLElement;\n\n @Element() el: HTMLIcLinkElement;\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.\n */\n @Prop() href?: string = null;\n\n /**\n * The human language of the linked URL.\n */\n @Prop() hreflang?: string;\n\n /**\n * How much of the referrer to send when following the link.\n */\n @Prop() referrerpolicy?: ReferrerPolicy;\n\n /**\n * The relationship of the linked URL as space-separated link types.\n */\n @Prop() rel?: string;\n\n /**\n * The place to display the linked URL, as the name for a browsing context (a tab, window, or iframe).\n */\n @Prop() target?: string;\n\n /**\n * If `true`, the 'open in new tab/window' icon will be displayed.\n */\n @Prop() showIcon?: boolean;\n\n /**\n * The appearance of the link, e.g. dark, light, or default.\n */\n @Prop({ mutable: true }) appearance?: IcThemeForeground = \"default\";\n\n @Listen(\"themeChange\", { target: \"document\" })\n themeChangeHandler(ev: CustomEvent): void {\n const theme: IcTheme = ev.detail;\n this.updateTheme(theme.mode);\n }\n\n private updateTheme(newTheme: IcThemeForeground = null): void {\n const theme = getThemeFromContext(this.el, newTheme || null);\n\n switch (theme) {\n case IcThemeForegroundEnum.Light:\n this.appearance = IcThemeForegroundEnum.Light;\n break;\n case IcThemeForegroundEnum.Dark:\n this.appearance = IcThemeForegroundEnum.Dark;\n break;\n }\n }\n\n /**\n * Sets focus on the link.\n */\n @Method()\n async setFocus(): Promise<void> {\n if (this.el.shadowRoot.querySelector(\"a\")) {\n this.el.shadowRoot.querySelector(\"a\").focus();\n }\n }\n\n componentWillLoad(): void {\n this.inheritedAttributes = inheritAttributes(this.el, [\n ...IC_INHERITED_ARIA,\n \"aria-expanded\",\n ]);\n\n this.updateTheme();\n }\n\n private hasRouterSlot(): boolean {\n this.routerSlot = this.el.querySelector('[slot=\"router-item\"]');\n if (this.routerSlot) {\n this.routerSlot.ariaLabel = this.routerSlot.textContent;\n }\n return !!this.routerSlot;\n }\n\n render() {\n const {\n download,\n href,\n hreflang,\n referrerpolicy,\n rel,\n target,\n showIcon,\n appearance,\n } = this;\n\n return (\n <Host class={{ [\"link\"]: true, [`${appearance}`]: true }}>\n {this.hasRouterSlot() ? (\n <slot name=\"router-item\"></slot>\n ) : (\n <a\n class={{\n [\"ic-link\"]: href !== null,\n [`${appearance}`]: href !== null,\n }}\n download={download !== false ? download : null}\n href={href}\n hrefLang={hreflang}\n referrerPolicy={referrerpolicy}\n rel={rel}\n target={target}\n tabindex={href !== null ? \"0\" : \"-1\"}\n {...this.inheritedAttributes}\n >\n <slot />\n {showIcon && (\n <span class=\"ic-link-open-in-new-icon\" innerHTML={OpenInNew} />\n )}\n </a>\n )}\n </Host>\n );\n }\n}\n"],"version":3}
@@ -2,7 +2,7 @@ import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal
2
2
  import { I as IcThemeForegroundEnum } from './types.js';
3
3
  import { d as defineCustomElement$1 } from './ic-typography2.js';
4
4
 
5
- const icLoadingIndicatorCss = "/*! 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;--linear-border-radius:4px;--inner-color:var(--ic-action-default);--outer-color:var(--ic-architectural-100);--label-color:var(--ic-color-primary-text);--margin:none;--linear-line-height:var(--ic-space-xs)}:host(.light){--inner-color:var(--ic-architectural-white);--outer-color:var(--ic-architectural-800);--label-color:var(--ic-architectural-white)}.ic-loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center}:host([size=\"small\"]){--circular-diameter:40px;--linear-line-height:var(--ic-space-xxs)}:host([size=\"default\"]){--circular-diameter:80px}:host([size=\"large\"]){--circular-diameter:120px}:host([size=\"icon\"]){display:inline-block;--margin:var(--ic-space-xxxs);--circular-diameter:20px}:host([label]){--margin:0 0 var(--ic-space-xs) 0}.ic-loading-label{white-space:nowrap;color:var(--label-color);margin-left:var(--label-margin-left)}.ic-loading-circular-outer{height:var(--circular-diameter);width:var(--circular-diameter)}.ic-loading-circular-outer.indeterminate{animation:circular-animation 1s linear;animation-iteration-count:infinite}@keyframes circular-animation{100%{transform:rotate(360deg)}}.ic-loading-circular-outer,.ic-loading-linear-outer{margin:var(--margin)}.ic-loading-linear-outer{background-color:var(--outer-color);height:var(--linear-line-height);width:100%;border-radius:var(--linear-border-radius);overflow:hidden}.ic-loading-linear-inner{position:relative;height:100%;background-color:var(--inner-color);border-radius:var(--linear-border-radius)}.indeterminate>.ic-loading-linear-inner{animation:linear-animation 2s infinite}.determinate>.ic-loading-linear-inner{transition:width 0.5s;width:var(--linear-width)}:host([full-width]){--linear-border-radius:none}@keyframes linear-animation{0%{width:0%;left:-1%}25%{width:0%;left:-1%}50%{width:101%;left:-1%}75%{width:0%;left:101%}100%{width:0%;left:101%}}.ic-loading-circular-svg{position:relative;width:100%;height:100%;transform:rotate(-90deg)}.ic-loading-circular-svg circle{width:100%;height:100%;fill:none;stroke:var(--outer-color);stroke-width:var(--circular-line-width);stroke-linecap:round}.ic-loading-circular-svg circle:nth-child(2){--circular-indeterminate:calc(\n (0.25 * var(--stroke-dasharray)) - var(--stroke-dasharray)\n );stroke-dasharray:var(--stroke-dasharray), var(--stroke-dasharray);stroke-dashoffset:var(--stroke-dashoffset, var(--circular-indeterminate));stroke:var(--inner-color)}@media (forced-colors: active){.indeterminate>.ic-loading-circular-inner{forced-color-adjust:none}.ic-loading-linear-outer{border:var(--ic-hc-border)}.ic-loading-linear-inner{background-color:canvastext}.ic-loading-circular-svg circle{stroke:Background}.ic-loading-circular-svg circle:nth-child(2){stroke:canvastext}}";
5
+ const icLoadingIndicatorCss = "/*! 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;--linear-border-radius:0.25rem;--inner-color:var(--ic-action-default);--outer-color:var(--ic-architectural-100);--label-color:var(--ic-color-primary-text);--margin:none;--linear-line-height:var(--ic-space-xs)}:host(.light){--inner-color:var(--ic-architectural-white);--outer-color:var(--ic-architectural-800);--label-color:var(--ic-architectural-white)}.ic-loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center}:host([size=\"small\"]){--circular-diameter:2.5rem;--linear-line-height:var(--ic-space-xxs)}:host([size=\"default\"]){--circular-diameter:5rem}:host([size=\"large\"]){--circular-diameter:7.5rem}:host([size=\"icon\"]){display:inline-block;--margin:var(--ic-space-xxxs);--circular-diameter:1.25rem}:host([label]){--margin:0 0 var(--ic-space-xs) 0}.ic-loading-label{white-space:nowrap;color:var(--label-color);margin-left:var(--label-margin-left)}.ic-loading-circular-outer{height:var(--circular-diameter);width:var(--circular-diameter)}.ic-loading-circular-outer.indeterminate{animation:circular-animation 1s linear;animation-iteration-count:infinite}@keyframes circular-animation{100%{transform:rotate(360deg)}}.ic-loading-circular-outer,.ic-loading-linear-outer{margin:var(--margin)}.ic-loading-linear-outer{background-color:var(--outer-color);height:var(--linear-line-height);width:100%;border-radius:var(--linear-border-radius);overflow:hidden}.ic-loading-linear-inner{position:relative;height:100%;background-color:var(--inner-color);border-radius:var(--linear-border-radius)}.indeterminate>.ic-loading-linear-inner{animation:linear-animation 2s infinite}.determinate>.ic-loading-linear-inner{transition:width 0.5s;width:var(--linear-width)}:host([full-width]){--linear-border-radius:none}@keyframes linear-animation{0%{width:0%;left:-1%}25%{width:0%;left:-1%}50%{width:101%;left:-1%}75%{width:0%;left:101%}100%{width:0%;left:101%}}.ic-loading-circular-svg{position:relative;width:100%;height:100%;transform:rotate(-90deg)}.ic-loading-circular-svg circle{width:100%;height:100%;fill:none;stroke:var(--outer-color);stroke-width:var(--circular-line-width);stroke-linecap:round}.ic-loading-circular-svg circle:nth-child(2){--circular-indeterminate:calc(\n (0.25 * var(--stroke-dasharray)) - var(--stroke-dasharray)\n );stroke-dasharray:var(--stroke-dasharray), var(--stroke-dasharray);stroke-dashoffset:var(--stroke-dashoffset, var(--circular-indeterminate));stroke:var(--compact-step-inner-color, var(--inner-color))}:host([inner-label]) .ic-loading-circular-inner{display:grid}:host([inner-label]) .ic-loading-circular-svg,.inner-text{grid-column:1;grid-row:1}:host(.not-required.compact-step-progress-indicator) .ic-loading-circular-svg circle:nth-child(2){stroke:var(--ic-architectural-300)}.inner-text{display:flex;align-items:center;justify-content:center;width:var(--ic-space-lg);height:inherit;overflow:hidden;margin:auto;color:var(--ic-theme-primary)}:host(.not-required.compact-step-progress-indicator) .inner-text{color:var(--ic-color-tertiary-text)}@media (forced-colors: active){.indeterminate>.ic-loading-circular-inner{forced-color-adjust:none}.ic-loading-linear-outer{border:var(--ic-hc-border)}.ic-loading-linear-inner{background-color:canvastext}.ic-loading-circular-svg circle{stroke:Background}.ic-loading-circular-svg circle:nth-child(2){stroke:canvastext}:host(.not-required.compact-step-progress-indicator) .ic-loading-circular-svg circle:nth-child(2){stroke:GrayText}}";
6
6
 
7
7
  const LoadingIndicator = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
8
8
  constructor() {
@@ -43,9 +43,23 @@ const LoadingIndicator = /*@__PURE__*/ proxyCustomElement(class extends HTMLElem
43
43
  // Sets the circular indicator line width - accounting for the circle size being altered using the CSS custom property
44
44
  this.setCircleLineWidth = () => {
45
45
  const { offsetWidth: width } = this.outerElement;
46
- if (width) {
47
- this.circularLineWidth = width * 0.1;
48
- this.circularDiameter = width;
46
+ const compactStepCircularLineWidth = this.host.classList.contains("compact-step-progress-indicator")
47
+ ? 40
48
+ : 0;
49
+ const toastDismissTimerCircularLineWidth = this.host.classList.contains("toast-dismiss-timer")
50
+ ? 20
51
+ : 0;
52
+ if (width ||
53
+ compactStepCircularLineWidth ||
54
+ toastDismissTimerCircularLineWidth) {
55
+ this.circularLineWidth =
56
+ (compactStepCircularLineWidth ||
57
+ toastDismissTimerCircularLineWidth ||
58
+ width) * 0.1;
59
+ this.circularDiameter =
60
+ compactStepCircularLineWidth ||
61
+ toastDismissTimerCircularLineWidth ||
62
+ width;
49
63
  this.outerElement.style.setProperty("--circular-line-width", `${this.circularLineWidth}px`);
50
64
  }
51
65
  };
@@ -82,7 +96,7 @@ const LoadingIndicator = /*@__PURE__*/ proxyCustomElement(class extends HTMLElem
82
96
  }
83
97
  };
84
98
  this.setCircleXY = () => {
85
- if (this.circularDiameter) {
99
+ if (this.circularDiameter > 0) {
86
100
  const r = this.circularDiameter / 2;
87
101
  const x = r;
88
102
  const y = r;
@@ -107,6 +121,7 @@ const LoadingIndicator = /*@__PURE__*/ proxyCustomElement(class extends HTMLElem
107
121
  this.max = 100;
108
122
  this.label = undefined;
109
123
  this.description = "Loading";
124
+ this.innerLabel = undefined;
110
125
  this.labelDuration = 8000;
111
126
  this.size = "default";
112
127
  this.type = "circular";
@@ -122,7 +137,9 @@ const LoadingIndicator = /*@__PURE__*/ proxyCustomElement(class extends HTMLElem
122
137
  this.updateLabel();
123
138
  }
124
139
  watchProgressHandler() {
125
- this.updateCircularProgressMeter();
140
+ if (this.type === "circular") {
141
+ this.updateCircularProgressMeter();
142
+ }
126
143
  }
127
144
  componentWillLoad() {
128
145
  this.indeterminate = this.progress === undefined;
@@ -149,7 +166,9 @@ const LoadingIndicator = /*@__PURE__*/ proxyCustomElement(class extends HTMLElem
149
166
  render() {
150
167
  const { appearance, label, description, size } = this;
151
168
  const { x, y, r } = this.setCircleXY();
152
- return (h(Host, { class: { ["light"]: appearance === IcThemeForegroundEnum.Light } }, h("div", { class: "ic-loading-container" }, h("div", { ref: (el) => (this.outerElement = el), class: this.calcOuterClass(), role: "progressbar", "aria-labelledby": this.label && this.size !== "icon" && "ic-loading-label", "aria-label": description, "aria-valuenow": this.progress, "aria-valuemin": this.min, "aria-valuemax": this.max }, h("div", { ref: (el) => (this.innerElement = el), class: `ic-loading-${this.type}-inner` }, this.type === "circular" && (h("svg", { class: "ic-loading-circular-svg", viewBox: `0 0 ${this.circularDiameter || 0} ${this.circularDiameter || 0}` }, h("circle", { cx: `${x}`, cy: `${y}`, r: `${r}` }), h("circle", { cx: `${x}`, cy: `${y}`, r: `${r}` }))))), label && size !== "icon" && (h("ic-typography", { id: "ic-loading-label", class: "ic-loading-label", role: "status", variant: this.getLabelVariant() }, h("p", null, this.indicatorLabel))))));
169
+ return (h(Host, { class: { ["light"]: appearance === IcThemeForegroundEnum.Light } }, h("div", { class: "ic-loading-container" }, h("div", { ref: (el) => (this.outerElement = el), class: this.calcOuterClass(), role: "progressbar", "aria-labelledby": this.label && this.size !== "icon" && "ic-loading-label", "aria-label": description, "aria-valuenow": this.progress, "aria-valuemin": this.min, "aria-valuemax": this.max }, h("div", { ref: (el) => (this.innerElement = el), class: `ic-loading-${this.type}-inner` }, this.innerLabel &&
170
+ this.innerLabel !== undefined &&
171
+ this.size === "small" && (h("ic-typography", { variant: "subtitle-small", class: "inner-text" }, this.innerLabel)), this.type === "circular" && (h("svg", { class: "ic-loading-circular-svg", viewBox: `0 0 ${this.circularDiameter || 0} ${this.circularDiameter || 0}` }, h("circle", { cx: `${x}`, cy: `${y}`, r: `${r}` }), h("circle", { cx: `${x}`, cy: `${y}`, r: `${r}` }))))), label && size !== "icon" && (h("ic-typography", { id: "ic-loading-label", class: "ic-loading-label", role: "status", variant: this.getLabelVariant() }, h("p", null, this.indicatorLabel))))));
153
172
  }
154
173
  get host() { return this; }
155
174
  static get watchers() { return {
@@ -163,6 +182,7 @@ const LoadingIndicator = /*@__PURE__*/ proxyCustomElement(class extends HTMLElem
163
182
  "max": [2],
164
183
  "label": [1],
165
184
  "description": [1],
185
+ "innerLabel": [2, "inner-label"],
166
186
  "labelDuration": [2, "label-duration"],
167
187
  "size": [513],
168
188
  "type": [513],
@@ -1 +1 @@
1
- {"file":"ic-loading-indicator2.js","mappings":"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","names":[],"sources":["./src/components/ic-loading-indicator/ic-loading-indicator.css?tag=ic-loading-indicator&encapsulation=shadow","./src/components/ic-loading-indicator/ic-loading-indicator.tsx"],"sourcesContent":["@import \"../../global/normalise.css\";\n\n:host {\n /**\n * @prop --circular-diameter: Diameter of the circular-indicator\n */\n\n display: block;\n\n --linear-border-radius: 4px;\n --inner-color: var(--ic-action-default);\n --outer-color: var(--ic-architectural-100);\n --label-color: var(--ic-color-primary-text);\n --margin: none;\n --linear-line-height: var(--ic-space-xs);\n}\n\n:host(.light) {\n --inner-color: var(--ic-architectural-white);\n --outer-color: var(--ic-architectural-800);\n --label-color: var(--ic-architectural-white);\n}\n\n.ic-loading-container {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n}\n\n:host([size=\"small\"]) {\n --circular-diameter: 40px;\n --linear-line-height: var(--ic-space-xxs);\n}\n\n:host([size=\"default\"]) {\n --circular-diameter: 80px;\n}\n\n:host([size=\"large\"]) {\n --circular-diameter: 120px;\n}\n\n:host([size=\"icon\"]) {\n display: inline-block;\n\n --margin: var(--ic-space-xxxs);\n --circular-diameter: 20px;\n}\n\n:host([label]) {\n --margin: 0 0 var(--ic-space-xs) 0;\n}\n\n.ic-loading-label {\n white-space: nowrap;\n color: var(--label-color);\n margin-left: var(--label-margin-left);\n}\n\n.ic-loading-circular-outer {\n height: var(--circular-diameter);\n width: var(--circular-diameter);\n\n}\n\n.ic-loading-circular-outer.indeterminate {\n animation: circular-animation 1s linear;\n animation-iteration-count: infinite;\n}\n\n@keyframes circular-animation {\n 100% {\n transform: rotate(360deg);\n }\n}\n\n.ic-loading-circular-outer,\n.ic-loading-linear-outer {\n margin: var(--margin);\n}\n\n.ic-loading-linear-outer {\n background-color: var(--outer-color);\n height: var(--linear-line-height);\n width: 100%;\n border-radius: var(--linear-border-radius);\n overflow: hidden;\n}\n\n.ic-loading-linear-inner {\n position: relative;\n height: 100%;\n background-color: var(--inner-color);\n border-radius: var(--linear-border-radius);\n}\n\n.indeterminate > .ic-loading-linear-inner {\n animation: linear-animation 2s infinite;\n}\n\n.determinate > .ic-loading-linear-inner {\n transition: width 0.5s;\n width: var(--linear-width);\n}\n\n:host([full-width]) {\n --linear-border-radius: none;\n}\n\n@keyframes linear-animation {\n 0% {\n width: 0%;\n left: -1%;\n }\n\n 25% {\n width: 0%;\n left: -1%;\n }\n\n 50% {\n width: 101%;\n left: -1%;\n }\n\n 75% {\n width: 0%;\n left: 101%;\n }\n\n 100% {\n width: 0%;\n left: 101%;\n }\n}\n\n.ic-loading-circular-svg {\n position: relative;\n width: 100%;\n height: 100%;\n transform: rotate(-90deg);\n}\n\n.ic-loading-circular-svg circle {\n width: 100%;\n height: 100%;\n fill: none;\n stroke: var(--outer-color);\n stroke-width: var(--circular-line-width);\n stroke-linecap: round;\n}\n\n/* --stroke-dash-array calculated via dashArray method */\n.ic-loading-circular-svg circle:nth-child(2) {\n --circular-indeterminate: calc(\n (0.25 * var(--stroke-dasharray)) - var(--stroke-dasharray)\n );\n\n stroke-dasharray: var(--stroke-dasharray), var(--stroke-dasharray);\n stroke-dashoffset: var(--stroke-dashoffset, var(--circular-indeterminate));\n stroke: var(--inner-color);\n}\n\n/** High Contrast **/\n@media (forced-colors: active) {\n .indeterminate > .ic-loading-circular-inner {\n forced-color-adjust: none;\n }\n\n .ic-loading-linear-outer {\n border: var(--ic-hc-border);\n }\n\n .ic-loading-linear-inner {\n background-color: canvastext;\n }\n\n .ic-loading-circular-svg circle {\n stroke: Background;\n }\n\n .ic-loading-circular-svg circle:nth-child(2) {\n stroke: canvastext;\n }\n}\n","import { Component, Element, h, Host, Prop, State, Watch } from \"@stencil/core\";\nimport {\n IcLoadingCircleXYR,\n IcLoadingSizes,\n IcLoadingTypes,\n} from \"./ic-loading-indicator.types\";\nimport {\n IcThemeForegroundEnum,\n IcThemeForegroundNoDefault,\n} from \"../../utils/types\";\n\n@Component({\n tag: \"ic-loading-indicator\",\n styleUrl: \"ic-loading-indicator.css\",\n shadow: true,\n})\nexport class LoadingIndicator {\n @Element() host: HTMLIcLoadingIndicatorElement;\n\n /**\n * The current amount of progress made.\n * If not provided, component acts as an indeterminate loading indicator.\n */\n @Prop() progress?: number;\n\n /**\n * The minimum value that the progress value can take.\n * Used to calculate the proportional width of the progress bar.\n */\n @Prop() min?: number = 0;\n\n /**\n * The maximum value that the progress value can take.\n * Used to calculate the proportional width of the progress bar.\n */\n @Prop() max?: number = 100;\n\n /**\n * The label to be displayed beneath the loading indicator.\n * Display a changing label by separating multiple messages with forward slashes.\n */\n @Prop() label?: string;\n\n /**\n * Provide a description to be set as the aria-label of the loading indicator when not using a visible label.\n */\n @Prop() description?: string = \"Loading\";\n\n /**\n * The time in milliseconds before the label changes.\n */\n @Prop() labelDuration?: number = 8000;\n\n /**\n * The size of the loading indicator.\n */\n @Prop({ reflect: true }) size?: IcLoadingSizes = \"default\";\n\n /**\n * The type of indicator, either linear or circular.\n */\n @Prop({ reflect: true }) type?: IcLoadingTypes = \"circular\";\n\n /**\n * When linear, determines whether the full-width version (i.e. without a border radius) should be displayed.\n */\n @Prop({ reflect: true }) fullWidth?: boolean = false;\n\n /**\n * Determines whether the dark or light loading indicator should be displayed.\n */\n @Prop() appearance?: IcThemeForegroundNoDefault = \"dark\";\n\n @State() indicatorLabel: string;\n @State() indeterminate: boolean;\n @State() showSecond: boolean = false;\n @State() circularLineWidth: number;\n @State() circularDiameter: number;\n\n @Watch(\"label\")\n watchPropHandler(): void {\n this.updateLabel();\n }\n\n @Watch(\"progress\")\n watchProgressHandler(): void {\n this.updateCircularProgressMeter();\n }\n\n private outerElement?: HTMLDivElement;\n private innerElement?: HTMLDivElement;\n private labelList: string[];\n private circularMeter: SVGCircleElement;\n\n private updateCircularProgressMeter = () => {\n if (!this.indeterminate) {\n this.circularMeter.style.setProperty(\n \"--progress-value\",\n String(this.progress)\n );\n }\n };\n\n private getLabel = (\n labelIndex: number,\n setLabel: (label: string) => void\n ) => {\n return new Promise(() => {\n setInterval(() => {\n if (labelIndex < this.labelList.length - 1) {\n labelIndex++;\n } else {\n labelIndex = 0;\n }\n setLabel(this.labelList[labelIndex]);\n }, this.labelDuration);\n });\n };\n\n private getLabelVariant = () => {\n let variant: \"label\" | \"h4\" | \"h2\" = \"h4\";\n const width = this.outerElement?.offsetWidth;\n if (this.size === \"small\" || (this.type === \"circular\" && width < 60)) {\n variant = \"label\";\n } else if (\n this.size === \"large\" ||\n (this.type === \"circular\" && width >= 120)\n ) {\n variant = \"h2\";\n }\n return variant;\n };\n\n // Sets the circular indicator line width - accounting for the circle size being altered using the CSS custom property\n private setCircleLineWidth = () => {\n const { offsetWidth: width } = this.outerElement;\n if (width) {\n this.circularLineWidth = width * 0.1;\n this.circularDiameter = width;\n this.outerElement.style.setProperty(\n \"--circular-line-width\",\n `${this.circularLineWidth}px`\n );\n }\n };\n\n private setLinearDeterminateWidth = () => {\n if (!this.innerElement) return;\n // Ensure progress cannot be out of bounds\n\n const progress = Math.min(this.max, Math.max(this.min, this.progress));\n const proportion = (progress - this.min) / (this.max - this.min);\n this.showSecond = proportion > 0.5;\n if (this.showSecond) {\n this.innerElement.classList.remove(\"clip\");\n } else {\n this.innerElement.classList.add(\"clip\");\n }\n this.innerElement.style.setProperty(\n \"--linear-width\",\n `${proportion * 100}%`\n );\n };\n\n private calcOuterClass = (): string => {\n let cls = `ic-loading-${this.type}-outer`;\n cls += this.indeterminate ? \" indeterminate\" : \" determinate\";\n return cls;\n };\n\n private updateLabel = (): void => {\n if (this.label !== undefined) {\n this.labelList = this.label.split(\"/\");\n const labelIndex = 0;\n this.indicatorLabel = this.labelList[labelIndex];\n if (this.labelList.length > 1) {\n this.getLabel(labelIndex, (label) => {\n this.indicatorLabel = label;\n });\n }\n }\n };\n\n private setCircleXY = (): IcLoadingCircleXYR => {\n if (this.circularDiameter) {\n const r = this.circularDiameter / 2;\n const x = r;\n const y = r;\n const nextRadius = r - this.circularLineWidth / 2;\n this.setDashSteps(nextRadius);\n\n return { x, y, r: nextRadius };\n }\n return { x: 0, y: 0, r: 0 };\n };\n\n private setDashSteps = (radius: number) => {\n const dashArray = 2 * Math.PI * radius;\n const progress = Math.min(Math.max(this.progress, this.min), this.max);\n const proportion = -1 - (progress - this.min) / (this.max - this.min);\n\n this.circularMeter.style.setProperty(\n \"--stroke-dasharray\",\n `${dashArray}px`\n );\n\n if (!this.indeterminate) {\n this.circularMeter.style.setProperty(\n \"--circular-steps-max\",\n String(this.max)\n );\n this.circularMeter.style.setProperty(\n \"--stroke-dashoffset\",\n `${proportion * dashArray}px`\n );\n }\n };\n\n componentWillLoad(): void {\n this.indeterminate = this.progress === undefined;\n this.updateLabel();\n }\n\n componentDidLoad(): void {\n if (this.type === \"circular\") {\n this.setCircleLineWidth();\n this.circularMeter = this.host.shadowRoot.querySelector(\n \".ic-loading-circular-svg circle:nth-child(2)\"\n );\n this.updateCircularProgressMeter();\n }\n\n if (Number(this.progress) >= 0 && this.type === \"linear\") {\n this.setLinearDeterminateWidth();\n }\n }\n\n componentWillUpdate(): void {\n this.indeterminate = this.progress === undefined;\n }\n\n componentDidUpdate(): void {\n if (Number(this.progress) >= 0 && this.type === \"linear\") {\n this.setLinearDeterminateWidth();\n }\n }\n\n render() {\n const { appearance, label, description, size } = this;\n const { x, y, r } = this.setCircleXY();\n\n return (\n <Host class={{ [\"light\"]: appearance === IcThemeForegroundEnum.Light }}>\n <div class=\"ic-loading-container\">\n <div\n ref={(el) => (this.outerElement = el as HTMLDivElement)}\n class={this.calcOuterClass()}\n role=\"progressbar\"\n aria-labelledby={\n this.label && this.size !== \"icon\" && \"ic-loading-label\"\n }\n aria-label={description}\n aria-valuenow={this.progress}\n aria-valuemin={this.min}\n aria-valuemax={this.max}\n >\n <div\n ref={(el) => (this.innerElement = el as HTMLDivElement)}\n class={`ic-loading-${this.type}-inner`}\n >\n {this.type === \"circular\" && (\n <svg\n class=\"ic-loading-circular-svg\"\n viewBox={`0 0 ${this.circularDiameter || 0} ${\n this.circularDiameter || 0\n }`}\n >\n <circle cx={`${x}`} cy={`${y}`} r={`${r}`}></circle>\n <circle cx={`${x}`} cy={`${y}`} r={`${r}`}></circle>\n </svg>\n )}\n </div>\n </div>\n {label && size !== \"icon\" && (\n <ic-typography\n id=\"ic-loading-label\"\n class=\"ic-loading-label\"\n role=\"status\"\n variant={this.getLabelVariant()}\n >\n <p>{this.indicatorLabel}</p>\n </ic-typography>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
1
+ {"file":"ic-loading-indicator2.js","mappings":"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","names":[],"sources":["./src/components/ic-loading-indicator/ic-loading-indicator.css?tag=ic-loading-indicator&encapsulation=shadow","./src/components/ic-loading-indicator/ic-loading-indicator.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n:host {\n /**\n * @prop --circular-diameter: Diameter of the circular-indicator\n */\n\n display: block;\n\n --linear-border-radius: 0.25rem;\n --inner-color: var(--ic-action-default);\n --outer-color: var(--ic-architectural-100);\n --label-color: var(--ic-color-primary-text);\n --margin: none;\n --linear-line-height: var(--ic-space-xs);\n}\n\n:host(.light) {\n --inner-color: var(--ic-architectural-white);\n --outer-color: var(--ic-architectural-800);\n --label-color: var(--ic-architectural-white);\n}\n\n.ic-loading-container {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n}\n\n:host([size=\"small\"]) {\n --circular-diameter: 2.5rem;\n --linear-line-height: var(--ic-space-xxs);\n}\n\n:host([size=\"default\"]) {\n --circular-diameter: 5rem;\n}\n\n:host([size=\"large\"]) {\n --circular-diameter: 7.5rem;\n}\n\n:host([size=\"icon\"]) {\n display: inline-block;\n\n --margin: var(--ic-space-xxxs);\n --circular-diameter: 1.25rem;\n}\n\n:host([label]) {\n --margin: 0 0 var(--ic-space-xs) 0;\n}\n\n.ic-loading-label {\n white-space: nowrap;\n color: var(--label-color);\n margin-left: var(--label-margin-left);\n}\n\n.ic-loading-circular-outer {\n height: var(--circular-diameter);\n width: var(--circular-diameter);\n}\n\n.ic-loading-circular-outer.indeterminate {\n animation: circular-animation 1s linear;\n animation-iteration-count: infinite;\n}\n\n@keyframes circular-animation {\n 100% {\n transform: rotate(360deg);\n }\n}\n\n.ic-loading-circular-outer,\n.ic-loading-linear-outer {\n margin: var(--margin);\n}\n\n.ic-loading-linear-outer {\n background-color: var(--outer-color);\n height: var(--linear-line-height);\n width: 100%;\n border-radius: var(--linear-border-radius);\n overflow: hidden;\n}\n\n.ic-loading-linear-inner {\n position: relative;\n height: 100%;\n background-color: var(--inner-color);\n border-radius: var(--linear-border-radius);\n}\n\n.indeterminate > .ic-loading-linear-inner {\n animation: linear-animation 2s infinite;\n}\n\n.determinate > .ic-loading-linear-inner {\n transition: width 0.5s;\n width: var(--linear-width);\n}\n\n:host([full-width]) {\n --linear-border-radius: none;\n}\n\n@keyframes linear-animation {\n 0% {\n width: 0%;\n left: -1%;\n }\n\n 25% {\n width: 0%;\n left: -1%;\n }\n\n 50% {\n width: 101%;\n left: -1%;\n }\n\n 75% {\n width: 0%;\n left: 101%;\n }\n\n 100% {\n width: 0%;\n left: 101%;\n }\n}\n\n.ic-loading-circular-svg {\n position: relative;\n width: 100%;\n height: 100%;\n transform: rotate(-90deg);\n}\n\n.ic-loading-circular-svg circle {\n width: 100%;\n height: 100%;\n fill: none;\n stroke: var(--outer-color);\n stroke-width: var(--circular-line-width);\n stroke-linecap: round;\n}\n\n/* --stroke-dash-array calculated via dashArray method */\n.ic-loading-circular-svg circle:nth-child(2) {\n --circular-indeterminate: calc(\n (0.25 * var(--stroke-dasharray)) - var(--stroke-dasharray)\n );\n\n stroke-dasharray: var(--stroke-dasharray), var(--stroke-dasharray);\n stroke-dashoffset: var(--stroke-dashoffset, var(--circular-indeterminate));\n stroke: var(--compact-step-inner-color, var(--inner-color));\n}\n\n:host([inner-label]) .ic-loading-circular-inner {\n display: grid;\n}\n\n:host([inner-label]) .ic-loading-circular-svg,\n.inner-text {\n grid-column: 1;\n grid-row: 1;\n}\n\n:host(.not-required.compact-step-progress-indicator)\n .ic-loading-circular-svg\n circle:nth-child(2) {\n stroke: var(--ic-architectural-300);\n}\n\n.inner-text {\n display: flex;\n align-items: center;\n justify-content: center;\n width: var(--ic-space-lg);\n height: inherit;\n overflow: hidden;\n margin: auto;\n color: var(--ic-theme-primary);\n}\n\n:host(.not-required.compact-step-progress-indicator) .inner-text {\n color: var(--ic-color-tertiary-text);\n}\n\n/** High Contrast **/\n@media (forced-colors: active) {\n .indeterminate > .ic-loading-circular-inner {\n forced-color-adjust: none;\n }\n\n .ic-loading-linear-outer {\n border: var(--ic-hc-border);\n }\n\n .ic-loading-linear-inner {\n background-color: canvastext;\n }\n\n .ic-loading-circular-svg circle {\n stroke: Background;\n }\n\n .ic-loading-circular-svg circle:nth-child(2) {\n stroke: canvastext;\n }\n\n :host(.not-required.compact-step-progress-indicator)\n .ic-loading-circular-svg\n circle:nth-child(2) {\n stroke: GrayText;\n }\n}\n","import { Component, Element, h, Host, Prop, State, Watch } from \"@stencil/core\";\nimport {\n IcLoadingCircleXYR,\n IcLoadingSizes,\n IcLoadingTypes,\n} from \"./ic-loading-indicator.types\";\nimport {\n IcThemeForegroundEnum,\n IcThemeForegroundNoDefault,\n} from \"../../utils/types\";\n\n@Component({\n tag: \"ic-loading-indicator\",\n styleUrl: \"ic-loading-indicator.css\",\n shadow: true,\n})\nexport class LoadingIndicator {\n @Element() host: HTMLIcLoadingIndicatorElement;\n\n /**\n * The current amount of progress made.\n * If not provided, component acts as an indeterminate loading indicator.\n */\n @Prop() progress?: number;\n\n /**\n * The minimum value that the progress value can take.\n * Used to calculate the proportional width of the progress bar.\n */\n @Prop() min?: number = 0;\n\n /**\n * The maximum value that the progress value can take.\n * Used to calculate the proportional width of the progress bar.\n */\n @Prop() max?: number = 100;\n\n /**\n * The label to be displayed beneath the loading indicator.\n * Display a changing label by separating multiple messages with forward slashes.\n */\n @Prop() label?: string;\n\n /**\n * The description that will be set as the aria-label of the loading indicator when not using a visible label.\n */\n @Prop() description?: string = \"Loading\";\n\n /**\n * @internal The step number of a compact step, managed by ic-step.\n */\n @Prop() innerLabel?: number;\n\n /**\n * The time in milliseconds before the label changes.\n */\n @Prop() labelDuration?: number = 8000;\n\n /**\n * The size of the loading indicator.\n */\n @Prop({ reflect: true }) size?: IcLoadingSizes = \"default\";\n\n /**\n * The type of indicator, either linear or circular.\n */\n @Prop({ reflect: true }) type?: IcLoadingTypes = \"circular\";\n\n /**\n * If `true`, when linear, the full-width variant (i.e. without a border radius) will be displayed.\n */\n @Prop({ reflect: true }) fullWidth?: boolean = false;\n\n /**\n * The appearance of the loading indicator, e.g. dark or light.\n */\n @Prop() appearance?: IcThemeForegroundNoDefault = \"dark\";\n\n @State() indicatorLabel: string;\n @State() indeterminate: boolean;\n @State() showSecond: boolean = false;\n @State() circularLineWidth: number;\n @State() circularDiameter: number;\n\n @Watch(\"label\")\n watchPropHandler(): void {\n this.updateLabel();\n }\n\n @Watch(\"progress\")\n watchProgressHandler(): void {\n if (this.type === \"circular\") {\n this.updateCircularProgressMeter();\n }\n }\n\n private outerElement?: HTMLDivElement;\n private innerElement?: HTMLDivElement;\n private labelList: string[];\n private circularMeter: SVGCircleElement;\n\n private updateCircularProgressMeter = () => {\n if (!this.indeterminate) {\n this.circularMeter.style.setProperty(\n \"--progress-value\",\n String(this.progress)\n );\n }\n };\n\n private getLabel = (\n labelIndex: number,\n setLabel: (label: string) => void\n ) => {\n return new Promise(() => {\n setInterval(() => {\n if (labelIndex < this.labelList.length - 1) {\n labelIndex++;\n } else {\n labelIndex = 0;\n }\n setLabel(this.labelList[labelIndex]);\n }, this.labelDuration);\n });\n };\n\n private getLabelVariant = () => {\n let variant: \"label\" | \"h4\" | \"h2\" = \"h4\";\n const width = this.outerElement?.offsetWidth;\n if (this.size === \"small\" || (this.type === \"circular\" && width < 60)) {\n variant = \"label\";\n } else if (\n this.size === \"large\" ||\n (this.type === \"circular\" && width >= 120)\n ) {\n variant = \"h2\";\n }\n return variant;\n };\n\n // Sets the circular indicator line width - accounting for the circle size being altered using the CSS custom property\n private setCircleLineWidth = () => {\n const { offsetWidth: width } = this.outerElement;\n\n const compactStepCircularLineWidth = this.host.classList.contains(\n \"compact-step-progress-indicator\"\n )\n ? 40\n : 0;\n const toastDismissTimerCircularLineWidth = this.host.classList.contains(\n \"toast-dismiss-timer\"\n )\n ? 20\n : 0;\n\n if (\n width ||\n compactStepCircularLineWidth ||\n toastDismissTimerCircularLineWidth\n ) {\n this.circularLineWidth =\n (compactStepCircularLineWidth ||\n toastDismissTimerCircularLineWidth ||\n width) * 0.1;\n this.circularDiameter =\n compactStepCircularLineWidth ||\n toastDismissTimerCircularLineWidth ||\n width;\n this.outerElement.style.setProperty(\n \"--circular-line-width\",\n `${this.circularLineWidth}px`\n );\n }\n };\n\n private setLinearDeterminateWidth = () => {\n if (!this.innerElement) return;\n // Ensure progress cannot be out of bounds\n\n const progress = Math.min(this.max, Math.max(this.min, this.progress));\n const proportion = (progress - this.min) / (this.max - this.min);\n this.showSecond = proportion > 0.5;\n if (this.showSecond) {\n this.innerElement.classList.remove(\"clip\");\n } else {\n this.innerElement.classList.add(\"clip\");\n }\n this.innerElement.style.setProperty(\n \"--linear-width\",\n `${proportion * 100}%`\n );\n };\n\n private calcOuterClass = (): string => {\n let cls = `ic-loading-${this.type}-outer`;\n cls += this.indeterminate ? \" indeterminate\" : \" determinate\";\n return cls;\n };\n\n private updateLabel = (): void => {\n if (this.label !== undefined) {\n this.labelList = this.label.split(\"/\");\n const labelIndex = 0;\n this.indicatorLabel = this.labelList[labelIndex];\n if (this.labelList.length > 1) {\n this.getLabel(labelIndex, (label) => {\n this.indicatorLabel = label;\n });\n }\n }\n };\n\n private setCircleXY = (): IcLoadingCircleXYR => {\n if (this.circularDiameter > 0) {\n const r = this.circularDiameter / 2;\n const x = r;\n const y = r;\n const nextRadius = r - this.circularLineWidth / 2;\n this.setDashSteps(nextRadius);\n\n return { x, y, r: nextRadius };\n }\n return { x: 0, y: 0, r: 0 };\n };\n\n private setDashSteps = (radius: number) => {\n const dashArray = 2 * Math.PI * radius;\n const progress = Math.min(Math.max(this.progress, this.min), this.max);\n const proportion = -1 - (progress - this.min) / (this.max - this.min);\n\n this.circularMeter.style.setProperty(\n \"--stroke-dasharray\",\n `${dashArray}px`\n );\n\n if (!this.indeterminate) {\n this.circularMeter.style.setProperty(\n \"--circular-steps-max\",\n String(this.max)\n );\n this.circularMeter.style.setProperty(\n \"--stroke-dashoffset\",\n `${proportion * dashArray}px`\n );\n }\n };\n\n componentWillLoad(): void {\n this.indeterminate = this.progress === undefined;\n this.updateLabel();\n }\n\n componentDidLoad(): void {\n if (this.type === \"circular\") {\n this.setCircleLineWidth();\n this.circularMeter = this.host.shadowRoot.querySelector(\n \".ic-loading-circular-svg circle:nth-child(2)\"\n );\n this.updateCircularProgressMeter();\n }\n\n if (Number(this.progress) >= 0 && this.type === \"linear\") {\n this.setLinearDeterminateWidth();\n }\n }\n\n componentWillUpdate(): void {\n this.indeterminate = this.progress === undefined;\n }\n\n componentDidUpdate(): void {\n if (Number(this.progress) >= 0 && this.type === \"linear\") {\n this.setLinearDeterminateWidth();\n }\n }\n\n render() {\n const { appearance, label, description, size } = this;\n const { x, y, r } = this.setCircleXY();\n\n return (\n <Host class={{ [\"light\"]: appearance === IcThemeForegroundEnum.Light }}>\n <div class=\"ic-loading-container\">\n <div\n ref={(el) => (this.outerElement = el as HTMLDivElement)}\n class={this.calcOuterClass()}\n role=\"progressbar\"\n aria-labelledby={\n this.label && this.size !== \"icon\" && \"ic-loading-label\"\n }\n aria-label={description}\n aria-valuenow={this.progress}\n aria-valuemin={this.min}\n aria-valuemax={this.max}\n >\n <div\n ref={(el) => (this.innerElement = el as HTMLDivElement)}\n class={`ic-loading-${this.type}-inner`}\n >\n {this.innerLabel &&\n this.innerLabel !== undefined &&\n this.size === \"small\" && (\n <ic-typography variant=\"subtitle-small\" class=\"inner-text\">\n {this.innerLabel}\n </ic-typography>\n )}\n {this.type === \"circular\" && (\n <svg\n class=\"ic-loading-circular-svg\"\n viewBox={`0 0 ${this.circularDiameter || 0} ${\n this.circularDiameter || 0\n }`}\n >\n <circle cx={`${x}`} cy={`${y}`} r={`${r}`}></circle>\n <circle cx={`${x}`} cy={`${y}`} r={`${r}`}></circle>\n </svg>\n )}\n </div>\n </div>\n {label && size !== \"icon\" && (\n <ic-typography\n id=\"ic-loading-label\"\n class=\"ic-loading-label\"\n role=\"status\"\n variant={this.getLabelVariant()}\n >\n <p>{this.indicatorLabel}</p>\n </ic-typography>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"version":3}