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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (401) hide show
  1. package/dist/cjs/core.cjs.js +2 -2
  2. package/dist/cjs/core.cjs.js.map +1 -1
  3. package/dist/cjs/{helpers-d0eeccf0.js → helpers-8bc3b6d2.js} +83 -38
  4. package/dist/cjs/helpers-8bc3b6d2.js.map +1 -0
  5. package/dist/cjs/ic-alert.cjs.entry.js +2 -2
  6. package/dist/cjs/ic-alert.cjs.entry.js.map +1 -1
  7. package/dist/cjs/ic-back-to-top.cjs.entry.js +2 -2
  8. package/dist/cjs/ic-back-to-top.cjs.entry.js.map +1 -1
  9. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +1 -1
  10. package/dist/cjs/ic-breadcrumb.cjs.entry.js +2 -2
  11. package/dist/cjs/ic-breadcrumb.cjs.entry.js.map +1 -1
  12. package/dist/cjs/ic-button_3.cjs.entry.js +56 -17
  13. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  14. package/dist/cjs/ic-card.cjs.entry.js +16 -3
  15. package/dist/cjs/ic-card.cjs.entry.js.map +1 -1
  16. package/dist/cjs/ic-checkbox-group.cjs.entry.js +1 -1
  17. package/dist/cjs/ic-checkbox.cjs.entry.js +5 -4
  18. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ic-classification-banner.cjs.entry.js +1 -1
  20. package/dist/cjs/ic-classification-banner.cjs.entry.js.map +1 -1
  21. package/dist/cjs/ic-data-entity.cjs.entry.js +1 -1
  22. package/dist/cjs/ic-data-entity.cjs.entry.js.map +1 -1
  23. package/dist/cjs/ic-data-row.cjs.entry.js +2 -2
  24. package/dist/cjs/ic-data-row.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ic-divider.cjs.entry.js +1 -1
  26. package/dist/cjs/ic-footer-link-group.cjs.entry.js +1 -1
  27. package/dist/cjs/ic-footer-link.cjs.entry.js +2 -2
  28. package/dist/cjs/ic-footer-link.cjs.entry.js.map +1 -1
  29. package/dist/cjs/ic-footer.cjs.entry.js +2 -2
  30. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -1
  31. package/dist/cjs/ic-hero.cjs.entry.js +1 -1
  32. package/dist/cjs/ic-input-component-container_3.cjs.entry.js +3 -3
  33. package/dist/cjs/ic-input-component-container_3.cjs.entry.js.map +1 -1
  34. package/dist/cjs/ic-input-label_2.cjs.entry.js +1 -1
  35. package/dist/cjs/ic-link.cjs.entry.js +1 -1
  36. package/dist/cjs/ic-navigation-button.cjs.entry.js +1 -1
  37. package/dist/cjs/ic-navigation-group.cjs.entry.js +1 -1
  38. package/dist/cjs/ic-navigation-item.cjs.entry.js +1 -1
  39. package/dist/cjs/ic-navigation-menu.cjs.entry.js +1 -1
  40. package/dist/cjs/ic-page-header.cjs.entry.js +1 -1
  41. package/dist/cjs/ic-radio-group.cjs.entry.js +1 -1
  42. package/dist/cjs/ic-radio-option.cjs.entry.js +2 -2
  43. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  44. package/dist/cjs/ic-search-bar.cjs.entry.js +1 -1
  45. package/dist/cjs/ic-select.cjs.entry.js +1 -1
  46. package/dist/cjs/ic-side-navigation.cjs.entry.js +2 -2
  47. package/dist/cjs/ic-side-navigation.cjs.entry.js.map +1 -1
  48. package/dist/cjs/ic-skeleton.cjs.entry.js +1 -1
  49. package/dist/cjs/ic-skeleton.cjs.entry.js.map +1 -1
  50. package/dist/cjs/ic-status-tag.cjs.entry.js +2 -2
  51. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -1
  52. package/dist/cjs/ic-step.cjs.entry.js +1 -9
  53. package/dist/cjs/ic-step.cjs.entry.js.map +1 -1
  54. package/dist/cjs/ic-stepper.cjs.entry.js +1 -1
  55. package/dist/cjs/ic-switch.cjs.entry.js +2 -2
  56. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  57. package/dist/cjs/ic-tab-group.cjs.entry.js +1 -1
  58. package/dist/cjs/ic-tab-panel.cjs.entry.js +0 -4
  59. package/dist/cjs/ic-tab-panel.cjs.entry.js.map +1 -1
  60. package/dist/cjs/ic-tab.cjs.entry.js +1 -5
  61. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -1
  62. package/dist/cjs/ic-text-field.cjs.entry.js +2 -2
  63. package/dist/cjs/ic-text-field.cjs.entry.js.map +1 -1
  64. package/dist/cjs/ic-theme.cjs.entry.js +19 -11
  65. package/dist/cjs/ic-theme.cjs.entry.js.map +1 -1
  66. package/dist/cjs/ic-top-navigation.cjs.entry.js +2 -2
  67. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -1
  68. package/dist/cjs/index-3ef30d9d.js.map +1 -1
  69. package/dist/cjs/loader.cjs.js +2 -2
  70. package/dist/cjs/loader.cjs.js.map +1 -1
  71. package/dist/cjs/types-3eb02246.js.map +1 -1
  72. package/dist/collection/collection-manifest.json +2 -2
  73. package/dist/collection/components/ic-alert/ic-alert.css +10 -4
  74. package/dist/collection/components/ic-back-to-top/ic-back-to-top.css +6 -0
  75. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.css +6 -0
  76. package/dist/collection/components/ic-button/ic-button.css +11 -0
  77. package/dist/collection/components/ic-card/ic-card.css +5 -0
  78. package/dist/collection/components/ic-card/ic-card.js +23 -2
  79. package/dist/collection/components/ic-card/ic-card.js.map +1 -1
  80. package/dist/collection/components/ic-checkbox/ic-checkbox.css +38 -1
  81. package/dist/collection/components/ic-checkbox/ic-checkbox.js +4 -3
  82. package/dist/collection/components/ic-checkbox/ic-checkbox.js.map +1 -1
  83. package/dist/collection/components/ic-classification-banner/ic-classification-banner.css +6 -0
  84. package/dist/collection/components/ic-data-entity/ic-data-entity.css +6 -0
  85. package/dist/collection/components/ic-data-row/ic-data-row.css +7 -1
  86. package/dist/collection/components/ic-footer/ic-footer.css +6 -0
  87. package/dist/collection/components/ic-footer-link/ic-footer-link.css +7 -0
  88. package/dist/collection/components/ic-input-component-container/ic-input-component-container.css +18 -4
  89. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.css +56 -101
  90. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js +53 -12
  91. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js.map +1 -1
  92. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.types.js.map +1 -1
  93. package/dist/collection/components/ic-menu/ic-menu.css +8 -1
  94. package/dist/collection/components/ic-radio-option/ic-radio-option.css +29 -10
  95. package/dist/collection/components/ic-side-navigation/ic-side-navigation.css +11 -0
  96. package/dist/collection/components/ic-skeleton/ic-skeleton.css +8 -0
  97. package/dist/collection/components/ic-status-tag/ic-status-tag.css +8 -0
  98. package/dist/collection/components/ic-step/ic-step.css +36 -1
  99. package/dist/collection/components/ic-step/ic-step.js +4 -11
  100. package/dist/collection/components/ic-step/ic-step.js.map +1 -1
  101. package/dist/collection/components/ic-switch/ic-switch.css +30 -0
  102. package/dist/collection/components/ic-tab/ic-tab.css +11 -1
  103. package/dist/collection/components/ic-tab/ic-tab.js +2 -6
  104. package/dist/collection/components/ic-tab/ic-tab.js.map +1 -1
  105. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js +2 -6
  106. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js.map +1 -1
  107. package/dist/collection/components/ic-text-field/ic-text-field.css +11 -0
  108. package/dist/collection/components/ic-theme/ic-theme.js +21 -11
  109. package/dist/collection/components/ic-theme/ic-theme.js.map +1 -1
  110. package/dist/collection/components/ic-tooltip/ic-tooltip.css +6 -0
  111. package/dist/collection/components/ic-tooltip/ic-tooltip.js +3 -1
  112. package/dist/collection/components/ic-tooltip/ic-tooltip.js.map +1 -1
  113. package/dist/collection/components/ic-top-navigation/ic-top-navigation.css +91 -78
  114. package/dist/collection/utils/constants.js +9 -0
  115. package/dist/collection/utils/constants.js.map +1 -1
  116. package/dist/collection/utils/helpers.js +68 -35
  117. package/dist/collection/utils/helpers.js.map +1 -1
  118. package/dist/collection/utils/types.js.map +1 -1
  119. package/dist/components/helpers.js +78 -36
  120. package/dist/components/helpers.js.map +1 -1
  121. package/dist/components/ic-alert.js +1 -1
  122. package/dist/components/ic-alert.js.map +1 -1
  123. package/dist/components/ic-back-to-top.js +1 -1
  124. package/dist/components/ic-back-to-top.js.map +1 -1
  125. package/dist/components/ic-breadcrumb2.js +1 -1
  126. package/dist/components/ic-breadcrumb2.js.map +1 -1
  127. package/dist/components/ic-button2.js +2 -2
  128. package/dist/components/ic-button2.js.map +1 -1
  129. package/dist/components/ic-card.js +19 -4
  130. package/dist/components/ic-card.js.map +1 -1
  131. package/dist/components/ic-checkbox-group.js +1 -1
  132. package/dist/components/ic-checkbox.js +5 -4
  133. package/dist/components/ic-checkbox.js.map +1 -1
  134. package/dist/components/ic-classification-banner.js +1 -1
  135. package/dist/components/ic-classification-banner.js.map +1 -1
  136. package/dist/components/ic-data-entity.js +1 -1
  137. package/dist/components/ic-data-entity.js.map +1 -1
  138. package/dist/components/ic-data-row.js +1 -1
  139. package/dist/components/ic-data-row.js.map +1 -1
  140. package/dist/components/ic-divider2.js +1 -1
  141. package/dist/components/ic-footer-link-group.js +1 -1
  142. package/dist/components/ic-footer-link.js +2 -2
  143. package/dist/components/ic-footer-link.js.map +1 -1
  144. package/dist/components/ic-footer.js +2 -2
  145. package/dist/components/ic-footer.js.map +1 -1
  146. package/dist/components/ic-hero.js +1 -1
  147. package/dist/components/ic-input-component-container2.js +1 -1
  148. package/dist/components/ic-input-component-container2.js.map +1 -1
  149. package/dist/components/ic-input-label2.js +1 -1
  150. package/dist/components/ic-input-validation2.js +1 -1
  151. package/dist/components/ic-link2.js +1 -1
  152. package/dist/components/ic-loading-indicator2.js +53 -14
  153. package/dist/components/ic-loading-indicator2.js.map +1 -1
  154. package/dist/components/ic-menu2.js +1 -1
  155. package/dist/components/ic-menu2.js.map +1 -1
  156. package/dist/components/ic-navigation-button.js +1 -1
  157. package/dist/components/ic-navigation-group.js +1 -1
  158. package/dist/components/ic-navigation-item.js +1 -1
  159. package/dist/components/ic-navigation-menu2.js +1 -1
  160. package/dist/components/ic-radio-group.js +1 -1
  161. package/dist/components/ic-radio-option.js +2 -2
  162. package/dist/components/ic-radio-option.js.map +1 -1
  163. package/dist/components/ic-search-bar.js +1 -1
  164. package/dist/components/ic-select.js +1 -1
  165. package/dist/components/ic-side-navigation.js +2 -2
  166. package/dist/components/ic-side-navigation.js.map +1 -1
  167. package/dist/components/ic-skeleton.js +1 -1
  168. package/dist/components/ic-skeleton.js.map +1 -1
  169. package/dist/components/ic-status-tag.js +1 -1
  170. package/dist/components/ic-status-tag.js.map +1 -1
  171. package/dist/components/ic-step.js +1 -8
  172. package/dist/components/ic-step.js.map +1 -1
  173. package/dist/components/ic-switch.js +2 -2
  174. package/dist/components/ic-switch.js.map +1 -1
  175. package/dist/components/ic-tab-group.js +1 -1
  176. package/dist/components/ic-tab-panel.js +0 -4
  177. package/dist/components/ic-tab-panel.js.map +1 -1
  178. package/dist/components/ic-tab.js +1 -5
  179. package/dist/components/ic-tab.js.map +1 -1
  180. package/dist/components/ic-text-field2.js +2 -2
  181. package/dist/components/ic-text-field2.js.map +1 -1
  182. package/dist/components/ic-theme.js +19 -11
  183. package/dist/components/ic-theme.js.map +1 -1
  184. package/dist/components/ic-tooltip2.js +4 -2
  185. package/dist/components/ic-tooltip2.js.map +1 -1
  186. package/dist/components/ic-top-navigation.js +2 -2
  187. package/dist/components/ic-top-navigation.js.map +1 -1
  188. package/dist/components/types.js.map +1 -1
  189. package/dist/core/core.css +11 -11
  190. package/dist/core/core.esm.js +1 -1
  191. package/dist/core/core.esm.js.map +1 -1
  192. package/dist/core/{p-9c1f2861.entry.js → p-0118400b.entry.js} +2 -2
  193. package/dist/core/p-0118400b.entry.js.map +1 -0
  194. package/dist/core/{p-0992a2ee.entry.js → p-02799e26.entry.js} +2 -2
  195. package/dist/core/p-02799e26.entry.js.map +1 -0
  196. package/dist/core/{p-972f4e69.entry.js → p-07cd789d.entry.js} +2 -2
  197. package/dist/core/{p-972f4e69.entry.js.map → p-07cd789d.entry.js.map} +1 -1
  198. package/dist/core/{p-48029498.entry.js → p-0b125f26.entry.js} +2 -2
  199. package/dist/core/{p-48029498.entry.js.map → p-0b125f26.entry.js.map} +0 -0
  200. package/dist/core/{p-3c6defd7.entry.js → p-10da19d2.entry.js} +2 -2
  201. package/dist/core/{p-3c6defd7.entry.js.map → p-10da19d2.entry.js.map} +0 -0
  202. package/dist/core/{p-6009c5bc.entry.js → p-1337db5e.entry.js} +2 -2
  203. package/dist/core/p-1337db5e.entry.js.map +1 -0
  204. package/dist/core/p-1721bcf3.entry.js +2 -0
  205. package/dist/core/p-1721bcf3.entry.js.map +1 -0
  206. package/dist/core/p-23831891.js +2 -0
  207. package/dist/core/p-23831891.js.map +1 -0
  208. package/dist/core/p-272c7abd.entry.js +2 -0
  209. package/dist/core/p-272c7abd.entry.js.map +1 -0
  210. package/dist/core/{p-ee3a9fd0.entry.js → p-2f114521.entry.js} +2 -2
  211. package/dist/core/{p-ee3a9fd0.entry.js.map → p-2f114521.entry.js.map} +0 -0
  212. package/dist/core/{p-54b77947.entry.js → p-31a8595f.entry.js} +2 -2
  213. package/dist/core/{p-54b77947.entry.js.map → p-31a8595f.entry.js.map} +0 -0
  214. package/dist/core/p-33a45ace.entry.js +2 -0
  215. package/dist/core/{p-c96adfd7.entry.js.map → p-33a45ace.entry.js.map} +1 -1
  216. package/dist/core/{p-a9237c61.entry.js → p-347ec49e.entry.js} +2 -2
  217. package/dist/core/{p-a9237c61.entry.js.map → p-347ec49e.entry.js.map} +0 -0
  218. package/dist/core/p-39ae284e.entry.js +2 -0
  219. package/dist/core/p-39ae284e.entry.js.map +1 -0
  220. package/dist/core/{p-bf4ddf33.entry.js → p-558552f8.entry.js} +2 -2
  221. package/dist/core/p-558552f8.entry.js.map +1 -0
  222. package/dist/core/{p-af6a41bd.entry.js → p-5e261268.entry.js} +2 -2
  223. package/dist/core/{p-af6a41bd.entry.js.map → p-5e261268.entry.js.map} +0 -0
  224. package/dist/core/p-60ffb73e.entry.js +2 -0
  225. package/dist/core/p-60ffb73e.entry.js.map +1 -0
  226. package/dist/core/p-69650186.entry.js +2 -0
  227. package/dist/core/p-69650186.entry.js.map +1 -0
  228. package/dist/core/{p-12e113bf.entry.js → p-6b34d98f.entry.js} +2 -2
  229. package/dist/core/{p-12e113bf.entry.js.map → p-6b34d98f.entry.js.map} +0 -0
  230. package/dist/core/p-6f57b13c.js.map +1 -1
  231. package/dist/core/{p-a183353c.entry.js → p-6f6bd657.entry.js} +2 -2
  232. package/dist/core/{p-a183353c.entry.js.map → p-6f6bd657.entry.js.map} +0 -0
  233. package/dist/core/p-7093d214.entry.js +2 -0
  234. package/dist/core/p-7093d214.entry.js.map +1 -0
  235. package/dist/core/p-7b11e1dc.entry.js +2 -0
  236. package/dist/core/{p-db6566c0.entry.js.map → p-7b11e1dc.entry.js.map} +1 -1
  237. package/dist/core/p-7b39977f.entry.js +2 -0
  238. package/dist/core/p-7b39977f.entry.js.map +1 -0
  239. package/dist/core/p-7f632414.entry.js +2 -0
  240. package/dist/core/p-7f632414.entry.js.map +1 -0
  241. package/dist/core/{p-59041cfc.entry.js → p-898607d0.entry.js} +2 -2
  242. package/dist/core/{p-59041cfc.entry.js.map → p-898607d0.entry.js.map} +0 -0
  243. package/dist/core/{p-c023c49c.entry.js → p-8ddeb574.entry.js} +2 -2
  244. package/dist/core/p-8ddeb574.entry.js.map +1 -0
  245. package/dist/core/{p-037273aa.entry.js → p-9cd04875.entry.js} +2 -2
  246. package/dist/core/{p-037273aa.entry.js.map → p-9cd04875.entry.js.map} +0 -0
  247. package/dist/core/{p-17d0d631.entry.js → p-ac43322e.entry.js} +2 -2
  248. package/dist/core/p-ac43322e.entry.js.map +1 -0
  249. package/dist/core/{p-2177dae2.entry.js → p-ae81dffa.entry.js} +2 -2
  250. package/dist/core/{p-2177dae2.entry.js.map → p-ae81dffa.entry.js.map} +1 -1
  251. package/dist/core/{p-1b619302.entry.js → p-b3dec76d.entry.js} +2 -2
  252. package/dist/core/{p-1b619302.entry.js.map → p-b3dec76d.entry.js.map} +0 -0
  253. package/dist/core/p-b5a988c0.entry.js +2 -0
  254. package/dist/core/p-b5a988c0.entry.js.map +1 -0
  255. package/dist/core/{p-0d63bfe4.entry.js → p-c4d3c18c.entry.js} +2 -2
  256. package/dist/core/{p-0d63bfe4.entry.js.map → p-c4d3c18c.entry.js.map} +0 -0
  257. package/dist/core/{p-9a3d6bca.entry.js → p-c6dd4f47.entry.js} +2 -2
  258. package/dist/core/p-c6dd4f47.entry.js.map +1 -0
  259. package/dist/core/p-cadb531f.entry.js +2 -0
  260. package/dist/core/p-cadb531f.entry.js.map +1 -0
  261. package/dist/core/p-cc83692e.entry.js +2 -0
  262. package/dist/core/{p-d38168f0.entry.js.map → p-cc83692e.entry.js.map} +1 -1
  263. package/dist/core/{p-9db8edb7.entry.js → p-dd3c3e3c.entry.js} +2 -2
  264. package/dist/core/{p-9db8edb7.entry.js.map → p-dd3c3e3c.entry.js.map} +0 -0
  265. package/dist/core/p-df5caf13.entry.js +2 -0
  266. package/dist/core/p-df5caf13.entry.js.map +1 -0
  267. package/dist/core/p-e106305b.entry.js +2 -0
  268. package/dist/core/{p-8054c2c0.entry.js.map → p-e106305b.entry.js.map} +1 -1
  269. package/dist/core/p-e590f1d2.entry.js +2 -0
  270. package/dist/core/p-e590f1d2.entry.js.map +1 -0
  271. package/dist/core/{p-eb33ece2.entry.js → p-e93e9aa3.entry.js} +2 -2
  272. package/dist/core/p-e93e9aa3.entry.js.map +1 -0
  273. package/dist/core/{p-378a7270.entry.js → p-ecfb2e6b.entry.js} +2 -2
  274. package/dist/core/{p-378a7270.entry.js.map → p-ecfb2e6b.entry.js.map} +0 -0
  275. package/dist/core/p-f9370be6.js.map +1 -1
  276. package/dist/esm/core.js +2 -2
  277. package/dist/esm/core.js.map +1 -1
  278. package/dist/esm/{helpers-e090fe7e.js → helpers-3d41833c.js} +79 -37
  279. package/dist/esm/helpers-3d41833c.js.map +1 -0
  280. package/dist/esm/ic-alert.entry.js +2 -2
  281. package/dist/esm/ic-alert.entry.js.map +1 -1
  282. package/dist/esm/ic-back-to-top.entry.js +2 -2
  283. package/dist/esm/ic-back-to-top.entry.js.map +1 -1
  284. package/dist/esm/ic-breadcrumb-group.entry.js +1 -1
  285. package/dist/esm/ic-breadcrumb.entry.js +2 -2
  286. package/dist/esm/ic-breadcrumb.entry.js.map +1 -1
  287. package/dist/esm/ic-button_3.entry.js +56 -17
  288. package/dist/esm/ic-button_3.entry.js.map +1 -1
  289. package/dist/esm/ic-card.entry.js +16 -3
  290. package/dist/esm/ic-card.entry.js.map +1 -1
  291. package/dist/esm/ic-checkbox-group.entry.js +1 -1
  292. package/dist/esm/ic-checkbox.entry.js +5 -4
  293. package/dist/esm/ic-checkbox.entry.js.map +1 -1
  294. package/dist/esm/ic-classification-banner.entry.js +1 -1
  295. package/dist/esm/ic-classification-banner.entry.js.map +1 -1
  296. package/dist/esm/ic-data-entity.entry.js +1 -1
  297. package/dist/esm/ic-data-entity.entry.js.map +1 -1
  298. package/dist/esm/ic-data-row.entry.js +2 -2
  299. package/dist/esm/ic-data-row.entry.js.map +1 -1
  300. package/dist/esm/ic-divider.entry.js +1 -1
  301. package/dist/esm/ic-footer-link-group.entry.js +1 -1
  302. package/dist/esm/ic-footer-link.entry.js +2 -2
  303. package/dist/esm/ic-footer-link.entry.js.map +1 -1
  304. package/dist/esm/ic-footer.entry.js +2 -2
  305. package/dist/esm/ic-footer.entry.js.map +1 -1
  306. package/dist/esm/ic-hero.entry.js +1 -1
  307. package/dist/esm/ic-input-component-container_3.entry.js +3 -3
  308. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -1
  309. package/dist/esm/ic-input-label_2.entry.js +1 -1
  310. package/dist/esm/ic-link.entry.js +1 -1
  311. package/dist/esm/ic-navigation-button.entry.js +1 -1
  312. package/dist/esm/ic-navigation-group.entry.js +1 -1
  313. package/dist/esm/ic-navigation-item.entry.js +1 -1
  314. package/dist/esm/ic-navigation-menu.entry.js +1 -1
  315. package/dist/esm/ic-page-header.entry.js +1 -1
  316. package/dist/esm/ic-radio-group.entry.js +1 -1
  317. package/dist/esm/ic-radio-option.entry.js +2 -2
  318. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  319. package/dist/esm/ic-search-bar.entry.js +1 -1
  320. package/dist/esm/ic-select.entry.js +1 -1
  321. package/dist/esm/ic-side-navigation.entry.js +2 -2
  322. package/dist/esm/ic-side-navigation.entry.js.map +1 -1
  323. package/dist/esm/ic-skeleton.entry.js +1 -1
  324. package/dist/esm/ic-skeleton.entry.js.map +1 -1
  325. package/dist/esm/ic-status-tag.entry.js +2 -2
  326. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  327. package/dist/esm/ic-step.entry.js +1 -9
  328. package/dist/esm/ic-step.entry.js.map +1 -1
  329. package/dist/esm/ic-stepper.entry.js +1 -1
  330. package/dist/esm/ic-switch.entry.js +2 -2
  331. package/dist/esm/ic-switch.entry.js.map +1 -1
  332. package/dist/esm/ic-tab-group.entry.js +1 -1
  333. package/dist/esm/ic-tab-panel.entry.js +0 -4
  334. package/dist/esm/ic-tab-panel.entry.js.map +1 -1
  335. package/dist/esm/ic-tab.entry.js +1 -5
  336. package/dist/esm/ic-tab.entry.js.map +1 -1
  337. package/dist/esm/ic-text-field.entry.js +2 -2
  338. package/dist/esm/ic-text-field.entry.js.map +1 -1
  339. package/dist/esm/ic-theme.entry.js +19 -11
  340. package/dist/esm/ic-theme.entry.js.map +1 -1
  341. package/dist/esm/ic-top-navigation.entry.js +2 -2
  342. package/dist/esm/ic-top-navigation.entry.js.map +1 -1
  343. package/dist/esm/index-1500de1f.js.map +1 -1
  344. package/dist/esm/loader.js +2 -2
  345. package/dist/esm/loader.js.map +1 -1
  346. package/dist/esm/types-dd515332.js.map +1 -1
  347. package/dist/types/components/ic-card/ic-card.d.ts +4 -0
  348. package/dist/types/components/ic-checkbox/ic-checkbox.d.ts +1 -1
  349. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.d.ts +8 -1
  350. package/dist/types/components/ic-loading-indicator/ic-loading-indicator.types.d.ts +5 -0
  351. package/dist/types/components/ic-step/ic-step.d.ts +2 -3
  352. package/dist/types/components/ic-tab/ic-tab.d.ts +1 -2
  353. package/dist/types/components/ic-tab-panel/ic-tab-panel.d.ts +1 -2
  354. package/dist/types/components/ic-theme/ic-theme.d.ts +2 -1
  355. package/dist/types/components.d.ts +6 -6
  356. package/dist/types/utils/constants.d.ts +2 -0
  357. package/dist/types/utils/helpers.d.ts +15 -3
  358. package/dist/types/utils/types.d.ts +3 -0
  359. package/hydrate/index.d.ts +1 -1
  360. package/hydrate/index.js +200 -106
  361. package/package.json +8 -5
  362. package/dist/cjs/helpers-d0eeccf0.js.map +0 -1
  363. package/dist/core/p-0992a2ee.entry.js.map +0 -1
  364. package/dist/core/p-155114db.entry.js +0 -2
  365. package/dist/core/p-155114db.entry.js.map +0 -1
  366. package/dist/core/p-17d0d631.entry.js.map +0 -1
  367. package/dist/core/p-40d3fd89.entry.js +0 -2
  368. package/dist/core/p-40d3fd89.entry.js.map +0 -1
  369. package/dist/core/p-50a0f1a0.entry.js +0 -2
  370. package/dist/core/p-50a0f1a0.entry.js.map +0 -1
  371. package/dist/core/p-5977c1e0.entry.js +0 -2
  372. package/dist/core/p-5977c1e0.entry.js.map +0 -1
  373. package/dist/core/p-6009c5bc.entry.js.map +0 -1
  374. package/dist/core/p-8054c2c0.entry.js +0 -2
  375. package/dist/core/p-89d46b9b.entry.js +0 -2
  376. package/dist/core/p-89d46b9b.entry.js.map +0 -1
  377. package/dist/core/p-9a3d6bca.entry.js.map +0 -1
  378. package/dist/core/p-9c1f2861.entry.js.map +0 -1
  379. package/dist/core/p-9e1f450f.entry.js +0 -2
  380. package/dist/core/p-9e1f450f.entry.js.map +0 -1
  381. package/dist/core/p-a6715f61.entry.js +0 -2
  382. package/dist/core/p-a6715f61.entry.js.map +0 -1
  383. package/dist/core/p-aad5da60.entry.js +0 -2
  384. package/dist/core/p-aad5da60.entry.js.map +0 -1
  385. package/dist/core/p-bf4ddf33.entry.js.map +0 -1
  386. package/dist/core/p-bfa9392f.entry.js +0 -2
  387. package/dist/core/p-bfa9392f.entry.js.map +0 -1
  388. package/dist/core/p-c023c49c.entry.js.map +0 -1
  389. package/dist/core/p-c96adfd7.entry.js +0 -2
  390. package/dist/core/p-d38168f0.entry.js +0 -2
  391. package/dist/core/p-d61c2983.entry.js +0 -2
  392. package/dist/core/p-d61c2983.entry.js.map +0 -1
  393. package/dist/core/p-db6566c0.entry.js +0 -2
  394. package/dist/core/p-eb33ece2.entry.js.map +0 -1
  395. package/dist/core/p-ef59f111.entry.js +0 -2
  396. package/dist/core/p-ef59f111.entry.js.map +0 -1
  397. package/dist/core/p-f228c232.js +0 -2
  398. package/dist/core/p-f228c232.js.map +0 -1
  399. package/dist/core/p-fce4b26b.entry.js +0 -2
  400. package/dist/core/p-fce4b26b.entry.js.map +0 -1
  401. package/dist/esm/helpers-e090fe7e.js.map +0 -1
@@ -456,6 +456,12 @@ video {
456
456
  --linear-line-height: var(--ic-space-xs);
457
457
  }
458
458
 
459
+ :host(.light) {
460
+ --inner-color: var(--ic-architectural-white);
461
+ --outer-color: var(--ic-architectural-800);
462
+ --label-color: var(--ic-architectural-white);
463
+ }
464
+
459
465
  .ic-loading-container {
460
466
  display: flex;
461
467
  flex-direction: column;
@@ -473,7 +479,7 @@ video {
473
479
  }
474
480
 
475
481
  :host([size="large"]) {
476
- --circular-diameter: 160px;
482
+ --circular-diameter: 120px;
477
483
  }
478
484
 
479
485
  :host([size="icon"]) {
@@ -494,11 +500,9 @@ video {
494
500
  }
495
501
 
496
502
  .ic-loading-circular-outer {
497
- box-shadow: inset 0 0 0 var(--circular-line-width) var(--outer-color);
498
503
  height: var(--circular-diameter);
499
504
  width: var(--circular-diameter);
500
- border-radius: 50%;
501
- position: relative;
505
+
502
506
  }
503
507
 
504
508
  .ic-loading-circular-outer.indeterminate {
@@ -506,99 +510,6 @@ video {
506
510
  animation-iteration-count: infinite;
507
511
  }
508
512
 
509
- .ic-loading-circular-inner {
510
- height: var(--circular-diameter);
511
- width: var(--circular-diameter);
512
- border-radius: 50%;
513
- position: relative;
514
- }
515
-
516
- .indeterminate > .ic-loading-circular-inner {
517
- box-shadow: inset 0 0 0 var(--circular-line-width) var(--inner-color);
518
- -webkit-clip-path: inset(0 50% 50% 0);
519
- clip-path: inset(0 50% 50% 0);
520
- }
521
-
522
- .determinate > .ic-loading-circular-inner {
523
- position: absolute;
524
- top: 0;
525
- left: 0;
526
- bottom: 0;
527
- right: 0;
528
- }
529
-
530
- .determinate > .ic-loading-circular-inner.clip {
531
- clip: rect(
532
- 0,
533
- var(--circular-diameter),
534
- var(--circular-diameter),
535
- calc(var(--circular-diameter) / 2)
536
- );
537
- }
538
-
539
- .ic-loading-circular-inner .left,
540
- .ic-loading-circular-inner .right {
541
- height: 100%;
542
- width: 100%;
543
- border: var(--circular-line-width) solid var(--inner-color);
544
- border-radius: 50%;
545
- box-sizing: border-box;
546
- clip: rect(
547
- 0,
548
- calc(var(--circular-diameter) / 2),
549
- var(--circular-diameter),
550
- 0
551
- );
552
- position: absolute;
553
- left: 0;
554
- top: 0;
555
- }
556
-
557
- .indeterminate > .ic-loading-circular-inner .left,
558
- .indeterminate > .ic-loading-circular-inner .right {
559
- display: none;
560
- }
561
-
562
- .determinate > .ic-loading-circular-inner .left {
563
- transform: rotate(var(--circular-rotation));
564
- }
565
-
566
- .determinate > .ic-loading-circular-inner .right {
567
- transform: rotate(180deg);
568
- }
569
-
570
- .determinate > .ic-loading-circular-inner.clip .right {
571
- display: none;
572
- }
573
-
574
- .ic-loading-circular-outer::before {
575
- content: "";
576
- height: var(--circular-line-width);
577
- width: var(--circular-line-width);
578
- border-radius: 50%;
579
- background-color: var(--inner-color);
580
- position: absolute;
581
- display: block;
582
- top: calc(50% - var(--circular-line-width) / 2);
583
- }
584
-
585
- .ic-loading-circular-outer::after {
586
- content: "";
587
- height: var(--circular-line-width);
588
- width: var(--circular-line-width);
589
- border-radius: 50%;
590
- background-color: var(--inner-color);
591
- position: absolute;
592
- display: block;
593
- top: 0;
594
- left: calc(50% - var(--circular-line-width) / 2);
595
- }
596
-
597
- .ic-loading-circular-outer.determinate::before,
598
- .ic-loading-circular-outer.determinate::after {
599
- display: none;
600
- }
601
-
602
513
  @keyframes circular-animation {
603
514
  100% {
604
515
  transform: rotate(360deg);
@@ -665,8 +576,52 @@ video {
665
576
  }
666
577
  }
667
578
 
668
- :host(.light) {
669
- --inner-color: var(--ic-architectural-white);
670
- --outer-color: var(--ic-architectural-800);
671
- --label-color: var(--ic-architectural-white);
579
+ .ic-loading-circular-svg {
580
+ position: relative;
581
+ width: 100%;
582
+ height: 100%;
583
+ transform: rotate(-90deg);
584
+ }
585
+
586
+ .ic-loading-circular-svg circle {
587
+ width: 100%;
588
+ height: 100%;
589
+ fill: none;
590
+ stroke: var(--outer-color);
591
+ stroke-width: var(--circular-line-width);
592
+ stroke-linecap: round;
593
+ }
594
+
595
+ /* --stroke-dash-array calculated via dashArray method */
596
+ .ic-loading-circular-svg circle:nth-child(2) {
597
+ --circular-indeterminate: calc(
598
+ (0.25 * var(--stroke-dasharray)) - var(--stroke-dasharray)
599
+ );
600
+
601
+ stroke-dasharray: var(--stroke-dasharray), var(--stroke-dasharray);
602
+ stroke-dashoffset: var(--stroke-dashoffset, var(--circular-indeterminate));
603
+ stroke: var(--inner-color);
604
+ }
605
+
606
+ /** High Contrast **/
607
+ @media (forced-colors: active) {
608
+ .indeterminate > .ic-loading-circular-inner {
609
+ forced-color-adjust: none;
610
+ }
611
+
612
+ .ic-loading-linear-outer {
613
+ border: var(--ic-hc-border);
614
+ }
615
+
616
+ .ic-loading-linear-inner {
617
+ background-color: canvastext;
618
+ }
619
+
620
+ .ic-loading-circular-svg circle {
621
+ stroke: Background;
622
+ }
623
+
624
+ .ic-loading-circular-svg circle:nth-child(2) {
625
+ stroke: canvastext;
626
+ }
672
627
  }
@@ -2,6 +2,11 @@ import { h, Host } from "@stencil/core";
2
2
  import { IcThemeForegroundEnum, } from "../../utils/types";
3
3
  export class LoadingIndicator {
4
4
  constructor() {
5
+ this.updateCircularProgressMeter = () => {
6
+ if (!this.indeterminate) {
7
+ this.circularMeter.style.setProperty("--progress-value", String(this.progress));
8
+ }
9
+ };
5
10
  this.getLabel = (labelIndex, setLabel) => {
6
11
  return new Promise(() => {
7
12
  setInterval(() => {
@@ -30,13 +35,14 @@ export class LoadingIndicator {
30
35
  };
31
36
  // Sets the circular indicator line width - accounting for the circle size being altered using the CSS custom property
32
37
  this.setCircleLineWidth = () => {
33
- var _a;
34
- const width = (_a = this.outerElement) === null || _a === void 0 ? void 0 : _a.offsetWidth;
38
+ const { offsetWidth: width } = this.outerElement;
35
39
  if (width) {
36
- this.outerElement.style.setProperty("--circular-line-width", `${width * 0.1}px`);
40
+ this.circularLineWidth = width * 0.1;
41
+ this.circularDiameter = width;
42
+ this.outerElement.style.setProperty("--circular-line-width", `${this.circularLineWidth}px`);
37
43
  }
38
44
  };
39
- this.setDeterminateWidth = () => {
45
+ this.setLinearDeterminateWidth = () => {
40
46
  if (!this.innerElement)
41
47
  return;
42
48
  // Ensure progress cannot be out of bounds
@@ -49,7 +55,6 @@ export class LoadingIndicator {
49
55
  else {
50
56
  this.innerElement.classList.add("clip");
51
57
  }
52
- this.innerElement.style.setProperty("--circular-rotation", `${proportion * 360}deg`);
53
58
  this.innerElement.style.setProperty("--linear-width", `${proportion * 100}%`);
54
59
  };
55
60
  this.calcOuterClass = () => {
@@ -69,6 +74,27 @@ export class LoadingIndicator {
69
74
  }
70
75
  }
71
76
  };
77
+ this.setCircleXY = () => {
78
+ if (this.circularDiameter) {
79
+ const r = this.circularDiameter / 2;
80
+ const x = r;
81
+ const y = r;
82
+ const nextRadius = r - this.circularLineWidth / 2;
83
+ this.setDashSteps(nextRadius);
84
+ return { x, y, r: nextRadius };
85
+ }
86
+ return { x: 0, y: 0, r: 0 };
87
+ };
88
+ this.setDashSteps = (radius) => {
89
+ const dashArray = 2 * Math.PI * radius;
90
+ const progress = Math.min(Math.max(this.progress, this.min), this.max);
91
+ const proportion = -1 - (progress - this.min) / (this.max - this.min);
92
+ this.circularMeter.style.setProperty("--stroke-dasharray", `${dashArray}px`);
93
+ if (!this.indeterminate) {
94
+ this.circularMeter.style.setProperty("--circular-steps-max", String(this.max));
95
+ this.circularMeter.style.setProperty("--stroke-dashoffset", `${proportion * dashArray}px`);
96
+ }
97
+ };
72
98
  this.progress = undefined;
73
99
  this.min = 0;
74
100
  this.max = 100;
@@ -82,31 +108,41 @@ export class LoadingIndicator {
82
108
  this.indicatorLabel = undefined;
83
109
  this.indeterminate = undefined;
84
110
  this.showSecond = false;
111
+ this.circularLineWidth = undefined;
112
+ this.circularDiameter = undefined;
85
113
  }
86
114
  watchPropHandler() {
87
115
  this.updateLabel();
88
116
  }
117
+ watchProgressHandler() {
118
+ this.updateCircularProgressMeter();
119
+ }
89
120
  componentWillLoad() {
90
121
  this.indeterminate = this.progress === undefined;
91
122
  this.updateLabel();
92
123
  }
93
124
  componentDidLoad() {
94
- this.setCircleLineWidth();
95
- if (Number(this.progress) >= 0) {
96
- this.setDeterminateWidth();
125
+ if (this.type === "circular") {
126
+ this.setCircleLineWidth();
127
+ this.circularMeter = this.host.shadowRoot.querySelector(".ic-loading-circular-svg circle:nth-child(2)");
128
+ this.updateCircularProgressMeter();
129
+ }
130
+ if (Number(this.progress) >= 0 && this.type === "linear") {
131
+ this.setLinearDeterminateWidth();
97
132
  }
98
133
  }
99
134
  componentWillUpdate() {
100
135
  this.indeterminate = this.progress === undefined;
101
136
  }
102
137
  componentDidUpdate() {
103
- if (Number(this.progress) >= 0) {
104
- this.setDeterminateWidth();
138
+ if (Number(this.progress) >= 0 && this.type === "linear") {
139
+ this.setLinearDeterminateWidth();
105
140
  }
106
141
  }
107
142
  render() {
108
143
  const { appearance, label, description, size } = this;
109
- 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.indeterminate || h("div", { class: "left" }), this.indeterminate || h("div", { class: "right" }))), label && size !== "icon" && (h("ic-typography", { id: "ic-loading-label", class: "ic-loading-label", role: "status", variant: this.getLabelVariant() }, h("p", null, this.indicatorLabel))))));
144
+ const { x, y, r } = this.setCircleXY();
145
+ 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))))));
110
146
  }
111
147
  static get is() { return "ic-loading-indicator"; }
112
148
  static get encapsulation() { return "shadow"; }
@@ -321,7 +357,9 @@ export class LoadingIndicator {
321
357
  return {
322
358
  "indicatorLabel": {},
323
359
  "indeterminate": {},
324
- "showSecond": {}
360
+ "showSecond": {},
361
+ "circularLineWidth": {},
362
+ "circularDiameter": {}
325
363
  };
326
364
  }
327
365
  static get elementRef() { return "host"; }
@@ -329,6 +367,9 @@ export class LoadingIndicator {
329
367
  return [{
330
368
  "propName": "label",
331
369
  "methodName": "watchPropHandler"
370
+ }, {
371
+ "propName": "progress",
372
+ "methodName": "watchProgressHandler"
332
373
  }];
333
374
  }
334
375
  }
@@ -1 +1 @@
1
- {"version":3,"file":"ic-loading-indicator.js","sourceRoot":"","sources":["../../../src/components/ic-loading-indicator/ic-loading-indicator.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, h, Host, Prop, State, Watch } from \"@stencil/core\";\nimport { IcLoadingSizes, IcLoadingTypes } from \"./ic-loading-indicator.types\";\nimport {\n IcThemeForegroundNoDefault,\n IcThemeForegroundEnum,\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\n @Watch(\"label\")\n watchPropHandler(): void {\n this.updateLabel();\n }\n\n private outerElement?: HTMLDivElement;\n private innerElement?: HTMLDivElement;\n private labelList: string[];\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 width = this.outerElement?.offsetWidth;\n if (width) {\n this.outerElement.style.setProperty(\n \"--circular-line-width\",\n `${width * 0.1}px`\n );\n }\n };\n\n private setDeterminateWidth = () => {\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 \"--circular-rotation\",\n `${proportion * 360}deg`\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 componentWillLoad(): void {\n this.indeterminate = this.progress === undefined;\n this.updateLabel();\n }\n\n componentDidLoad(): void {\n this.setCircleLineWidth();\n if (Number(this.progress) >= 0) {\n this.setDeterminateWidth();\n }\n }\n\n componentWillUpdate(): void {\n this.indeterminate = this.progress === undefined;\n }\n\n componentDidUpdate(): void {\n if (Number(this.progress) >= 0) {\n this.setDeterminateWidth();\n }\n }\n\n render() {\n const { appearance, label, description, size } = this;\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.indeterminate || <div class=\"left\" />}\n {this.indeterminate || <div class=\"right\" />}\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"]}
1
+ {"version":3,"file":"ic-loading-indicator.js","sourceRoot":"","sources":["../../../src/components/ic-loading-indicator/ic-loading-indicator.tsx"],"names":[],"mappings":"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","sourcesContent":["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"]}
@@ -1 +1 @@
1
- {"version":3,"file":"ic-loading-indicator.types.js","sourceRoot":"","sources":["../../../src/components/ic-loading-indicator/ic-loading-indicator.types.tsx"],"names":[],"mappings":"","sourcesContent":["export type IcLoadingSizes = \"default\" | \"small\" | \"large\" | \"icon\";\n\nexport type IcLoadingTypes = \"circular\" | \"linear\";\n"]}
1
+ {"version":3,"file":"ic-loading-indicator.types.js","sourceRoot":"","sources":["../../../src/components/ic-loading-indicator/ic-loading-indicator.types.tsx"],"names":[],"mappings":"","sourcesContent":["export type IcLoadingSizes = \"default\" | \"small\" | \"large\" | \"icon\";\n\nexport type IcLoadingTypes = \"circular\" | \"linear\";\n\nexport interface IcLoadingCircleXYR {\n x: number;\n y: number;\n r: number;\n}\n"]}
@@ -543,7 +543,7 @@ video {
543
543
  }
544
544
 
545
545
  .focused-option .check-icon * {
546
- fill: white;
546
+ fill: currentColor;
547
547
  }
548
548
 
549
549
  .option-group-title {
@@ -578,3 +578,10 @@ video {
578
578
  :host(.no-results) li:hover {
579
579
  background-color: transparent;
580
580
  }
581
+
582
+ @media (forced-colors: active) {
583
+ .focused-option:focus {
584
+ outline: none;
585
+ border: 2px solid transparent;
586
+ }
587
+ }
@@ -442,7 +442,8 @@ video {
442
442
 
443
443
 
444
444
  :host {
445
- display: block;
445
+ display: flex;
446
+ flex-direction: column;
446
447
  margin-bottom: var(--ic-space-sm);
447
448
  width: -moz-fit-content;
448
449
  width: fit-content;
@@ -467,11 +468,6 @@ video {
467
468
  .container input:focus + span.checkmark,
468
469
  :host(:focus) .container input:checked + span.checkmark {
469
470
  box-shadow: var(--ic-border-focus);
470
- outline: var(--ic-hc-focus-outline);
471
- }
472
-
473
- .container input:focus-visible {
474
- outline: var(--ic-hc-focus-outline);
475
471
  }
476
472
 
477
473
  /* The container */
@@ -480,8 +476,7 @@ video {
480
476
  position: relative;
481
477
  cursor: pointer;
482
478
  align-items: center;
483
- gap: var(--ic-space-xs);
484
- margin-left: 5px;
479
+ margin-left: var(--ic-space-xxs);
485
480
  }
486
481
 
487
482
  .container.disabled,
@@ -517,6 +512,7 @@ video {
517
512
  border: 1px solid #a7acb3;
518
513
  border-radius: 50%;
519
514
  transition: var(--ic-easing-transition-fast);
515
+ margin: 0 1px;
520
516
  }
521
517
 
522
518
  /* Show the indicator (dot/circle) when checked */
@@ -553,8 +549,7 @@ video {
553
549
  /* When the radio button is checked */
554
550
  .container input:checked ~ .checkmark {
555
551
  border: 2px solid var(--ic-action-default);
556
- margin: -1px;
557
- margin-bottom: 1px;
552
+ margin: 0;
558
553
  }
559
554
 
560
555
  /* When the radio button is checked and disabled */
@@ -643,3 +638,27 @@ video {
643
638
  --input-width: 100%;
644
639
  }
645
640
  }
641
+
642
+ @media (forced-colors: active) {
643
+ /* Styles here only apply to Forced Colors Mode */
644
+
645
+ .container input:checked ~ .checkmark,
646
+ .container:active input:checked ~ .checkmark {
647
+ border-color: Highlight;
648
+ }
649
+
650
+ .container input:checked ~ .checkmark::after,
651
+ .container:active input:checked ~ .checkmark::after {
652
+ background-color: Highlight;
653
+ }
654
+
655
+ .container input:disabled ~ .checkmark,
656
+ .container input:checked:disabled ~ .checkmark {
657
+ border-color: GrayText;
658
+ }
659
+
660
+ .container input:disabled ~ .checkmark::after,
661
+ .container:active input:disabled ~ .checkmark::after {
662
+ background-color: GrayText;
663
+ }
664
+ }
@@ -605,3 +605,14 @@
605
605
  box-shadow: none;
606
606
  }
607
607
  }
608
+
609
+ @media (forced-colors: active) {
610
+ .side-navigation,
611
+ .top-bar {
612
+ border-right: var(--ic-hc-border);
613
+ }
614
+
615
+ slot[name="app-icon"]::slotted(svg) {
616
+ fill: currentColor;
617
+ }
618
+ }
@@ -493,3 +493,11 @@ video {
493
493
  background-color: var(--ic-architectural-600);
494
494
  animation: loading-light 1200ms infinite;
495
495
  }
496
+
497
+ @media (forced-colors: active) {
498
+ :host(.skeleton) {
499
+ -ms-high-contrast-adjust: none;
500
+ forced-color-adjust: none;
501
+ background: currentColor;
502
+ }
503
+ }
@@ -497,3 +497,11 @@ video {
497
497
  color: var(--ic-status-error);
498
498
  border: 1px solid var(--ic-status-error);
499
499
  }
500
+
501
+ @media (forced-colors: active) {
502
+ .tag {
503
+ border: var(--ic-hc-border);
504
+ -ms-high-contrast-adjust: none;
505
+ forced-color-adjust: none;
506
+ }
507
+ }
@@ -77,7 +77,7 @@
77
77
  color: var(--ic-architectural-200);
78
78
  }
79
79
 
80
- .disabled .step-icon-inner {
80
+ .disabled .step-icon {
81
81
  border: 1px dashed var(--ic-architectural-200);
82
82
  width: calc(var(--ic-space-xl) - var(--ic-space-xxxs));
83
83
  height: calc(var(--ic-space-xl) - var(--ic-space-xxxs));
@@ -144,3 +144,38 @@
144
144
  .check-icon > svg > path {
145
145
  fill: white;
146
146
  }
147
+
148
+ /** High Contrast **/
149
+ @media (forced-colors: active) {
150
+ .step-connect:not(.disabled .step-connect) {
151
+ border: var(--ic-hc-border);
152
+ }
153
+
154
+ .active .step-icon-inner,
155
+ .completed .step-icon-inner,
156
+ .current .step-icon-inner {
157
+ forced-color-adjust: none;
158
+ box-shadow: inset canvastext 0 0 0 2px;
159
+ background-color: transparent;
160
+ color: canvastext;
161
+ }
162
+
163
+ .current .step-icon {
164
+ padding: 0;
165
+ border: none;
166
+ }
167
+
168
+ .disabled,
169
+ .disabled .step-title-area {
170
+ color: Graytext;
171
+ }
172
+
173
+ .step-connect-inner,
174
+ .completed .step-connect {
175
+ background-color: canvastext;
176
+ }
177
+
178
+ .check-icon > svg > path {
179
+ fill: canvastext;
180
+ }
181
+ }
@@ -1,6 +1,5 @@
1
1
  import { Host, h } from "@stencil/core";
2
2
  import checkIcon from "../../assets/check-icon.svg";
3
- import { onComponentRequiredPropUndefined } from "../../utils/helpers";
4
3
  export class Step {
5
4
  constructor() {
6
5
  this.stepType = "active";
@@ -9,12 +8,6 @@ export class Step {
9
8
  this.stepNum = undefined;
10
9
  this.lastStep = undefined;
11
10
  }
12
- componentDidLoad() {
13
- onComponentRequiredPropUndefined([
14
- { prop: this.stepNum, propName: "step-num" },
15
- { prop: this.lastStep, propName: "last-step" },
16
- ], "Step");
17
- }
18
11
  render() {
19
12
  let icon;
20
13
  if (this.stepType !== "completed") {
@@ -121,8 +114,8 @@ export class Step {
121
114
  "resolved": "number",
122
115
  "references": {}
123
116
  },
124
- "required": true,
125
- "optional": false,
117
+ "required": false,
118
+ "optional": true,
126
119
  "docs": {
127
120
  "tags": [{
128
121
  "name": "internal",
@@ -141,8 +134,8 @@ export class Step {
141
134
  "resolved": "boolean",
142
135
  "references": {}
143
136
  },
144
- "required": true,
145
- "optional": false,
137
+ "required": false,
138
+ "optional": true,
146
139
  "docs": {
147
140
  "tags": [{
148
141
  "name": "internal",
@@ -1 +1 @@
1
- {"version":3,"file":"ic-step.js","sourceRoot":"","sources":["../../../src/components/ic-step/ic-step.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Host, h, Prop, Element } from \"@stencil/core\";\nimport checkIcon from \"../../assets/check-icon.svg\";\nimport { onComponentRequiredPropUndefined } from \"../../utils/helpers\";\nimport { IcStepTypes } from \"./ic-step.types\";\n\n@Component({\n tag: \"ic-step\",\n styleUrl: \"ic-step.css\",\n shadow: true,\n})\nexport class Step {\n @Element() el: HTMLIcStepElement;\n /**\n * State of step\n */\n @Prop() stepType?: IcStepTypes = \"active\";\n\n /**\n * Name of step\n */\n @Prop() stepTitle?: string;\n\n /**\n * Additional information about step\n */\n @Prop() stepSubtitle?: string;\n\n /**\n * @internal The step number, managed by ic-stepper\n */\n @Prop() stepNum!: number;\n\n /**\n * @internal Final step in series flag, managed by ic-stepper\n */\n @Prop() lastStep!: boolean;\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [\n { prop: this.stepNum, propName: \"step-num\" },\n { prop: this.lastStep, propName: \"last-step\" },\n ],\n \"Step\"\n );\n }\n\n render() {\n let icon;\n if (this.stepType !== \"completed\") {\n icon = (\n <ic-typography variant=\"subtitle-small\">\n <span class=\"step-icon-inner\" aria-hidden=\"true\">\n {this.stepNum}\n </span>\n </ic-typography>\n );\n } else {\n icon = (\n <div class=\"step-icon-inner\" aria-hidden=\"true\">\n <span class=\"check-icon\" innerHTML={checkIcon}></span>\n </div>\n );\n }\n\n let ariaLabel = \"\";\n\n if (this.stepType === \"completed\") {\n ariaLabel = \". Completed step\";\n } else if (this.stepType === \"disabled\") {\n ariaLabel = \". Disabled step\";\n }\n\n const partialBar = this.stepType === \"current\" && (\n <div class=\"step-connect-inner\"></div>\n );\n const finalStep = !this.lastStep && (\n <div\n class={{\n [\"step-connect\"]: true,\n [\"aligned-full-width\"]:\n this.el.parentElement.classList.contains(\"aligned-full-width\"),\n }}\n >\n {partialBar}\n </div>\n );\n\n return (\n <Host\n role=\"listitem\"\n aria-label={`Step ${this.stepNum}${ariaLabel}`}\n aria-current={this.stepType == \"current\" ? \"step\" : null}\n class={{\n [\"aligned-full-width\"]:\n this.el.parentElement.classList.contains(\"aligned-full-width\"),\n }}\n >\n <div\n class={{\n [\"step\"]: true,\n [`${this.stepType}`]: true,\n }}\n >\n <div class=\"step-top\">\n <div class=\"step-icon\">{icon}</div>\n {finalStep}\n </div>\n {(this.stepTitle || this.stepSubtitle) && (\n <div class=\"step-title-area\">\n {this.stepTitle && (\n <ic-typography variant=\"subtitle-large\" class=\"step-title\">\n {this.stepTitle}\n </ic-typography>\n )}\n {this.stepSubtitle && (\n <ic-typography variant=\"caption\" class=\"step-subtitle\">\n {this.stepSubtitle}\n </ic-typography>\n )}\n </div>\n )}\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"ic-step.js","sourceRoot":"","sources":["../../../src/components/ic-step/ic-step.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAClE,OAAO,SAAS,MAAM,6BAA6B,CAAC;AAQpD,MAAM,OAAO,IAAI;;oBAKkB,QAAQ;;;;;;EAsBzC,MAAM;IACJ,IAAI,IAAI,CAAC;IACT,IAAI,IAAI,CAAC,QAAQ,KAAK,WAAW,EAAE;MACjC,IAAI,GAAG,CACL,qBAAe,OAAO,EAAC,gBAAgB;QACrC,YAAM,KAAK,EAAC,iBAAiB,iBAAa,MAAM,IAC7C,IAAI,CAAC,OAAO,CACR,CACO,CACjB,CAAC;KACH;SAAM;MACL,IAAI,GAAG,CACL,WAAK,KAAK,EAAC,iBAAiB,iBAAa,MAAM;QAC7C,YAAM,KAAK,EAAC,YAAY,EAAC,SAAS,EAAE,SAAS,GAAS,CAClD,CACP,CAAC;KACH;IAED,IAAI,SAAS,GAAG,EAAE,CAAC;IAEnB,IAAI,IAAI,CAAC,QAAQ,KAAK,WAAW,EAAE;MACjC,SAAS,GAAG,kBAAkB,CAAC;KAChC;SAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,UAAU,EAAE;MACvC,SAAS,GAAG,iBAAiB,CAAC;KAC/B;IAED,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,KAAK,SAAS,IAAI,CAChD,WAAK,KAAK,EAAC,oBAAoB,GAAO,CACvC,CAAC;IACF,MAAM,SAAS,GAAG,CAAC,IAAI,CAAC,QAAQ,IAAI,CAClC,WACE,KAAK,EAAE;QACL,CAAC,cAAc,CAAC,EAAE,IAAI;QACtB,CAAC,oBAAoB,CAAC,EACpB,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,oBAAoB,CAAC;OACjE,IAEA,UAAU,CACP,CACP,CAAC;IAEF,OAAO,CACL,EAAC,IAAI,IACH,IAAI,EAAC,UAAU,gBACH,QAAQ,IAAI,CAAC,OAAO,GAAG,SAAS,EAAE,kBAChC,IAAI,CAAC,QAAQ,IAAI,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,EACxD,KAAK,EAAE;QACL,CAAC,oBAAoB,CAAC,EACpB,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,oBAAoB,CAAC;OACjE;MAED,WACE,KAAK,EAAE;UACL,CAAC,MAAM,CAAC,EAAE,IAAI;UACd,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,EAAE,IAAI;SAC3B;QAED,WAAK,KAAK,EAAC,UAAU;UACnB,WAAK,KAAK,EAAC,WAAW,IAAE,IAAI,CAAO;UAClC,SAAS,CACN;QACL,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,CACxC,WAAK,KAAK,EAAC,iBAAiB;UACzB,IAAI,CAAC,SAAS,IAAI,CACjB,qBAAe,OAAO,EAAC,gBAAgB,EAAC,KAAK,EAAC,YAAY,IACvD,IAAI,CAAC,SAAS,CACD,CACjB;UACA,IAAI,CAAC,YAAY,IAAI,CACpB,qBAAe,OAAO,EAAC,SAAS,EAAC,KAAK,EAAC,eAAe,IACnD,IAAI,CAAC,YAAY,CACJ,CACjB,CACG,CACP,CACG,CACD,CACR,CAAC;EACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Host, h, Prop, Element } from \"@stencil/core\";\nimport checkIcon from \"../../assets/check-icon.svg\";\nimport { IcStepTypes } from \"./ic-step.types\";\n\n@Component({\n tag: \"ic-step\",\n styleUrl: \"ic-step.css\",\n shadow: true,\n})\nexport class Step {\n @Element() el: HTMLIcStepElement;\n /**\n * State of step\n */\n @Prop() stepType?: IcStepTypes = \"active\";\n\n /**\n * Name of step\n */\n @Prop() stepTitle?: string;\n\n /**\n * Additional information about step\n */\n @Prop() stepSubtitle?: string;\n\n /**\n * @internal The step number, managed by ic-stepper\n */\n @Prop() stepNum?: number;\n\n /**\n * @internal Final step in series flag, managed by ic-stepper\n */\n @Prop() lastStep?: boolean;\n\n render() {\n let icon;\n if (this.stepType !== \"completed\") {\n icon = (\n <ic-typography variant=\"subtitle-small\">\n <span class=\"step-icon-inner\" aria-hidden=\"true\">\n {this.stepNum}\n </span>\n </ic-typography>\n );\n } else {\n icon = (\n <div class=\"step-icon-inner\" aria-hidden=\"true\">\n <span class=\"check-icon\" innerHTML={checkIcon}></span>\n </div>\n );\n }\n\n let ariaLabel = \"\";\n\n if (this.stepType === \"completed\") {\n ariaLabel = \". Completed step\";\n } else if (this.stepType === \"disabled\") {\n ariaLabel = \". Disabled step\";\n }\n\n const partialBar = this.stepType === \"current\" && (\n <div class=\"step-connect-inner\"></div>\n );\n const finalStep = !this.lastStep && (\n <div\n class={{\n [\"step-connect\"]: true,\n [\"aligned-full-width\"]:\n this.el.parentElement.classList.contains(\"aligned-full-width\"),\n }}\n >\n {partialBar}\n </div>\n );\n\n return (\n <Host\n role=\"listitem\"\n aria-label={`Step ${this.stepNum}${ariaLabel}`}\n aria-current={this.stepType == \"current\" ? \"step\" : null}\n class={{\n [\"aligned-full-width\"]:\n this.el.parentElement.classList.contains(\"aligned-full-width\"),\n }}\n >\n <div\n class={{\n [\"step\"]: true,\n [`${this.stepType}`]: true,\n }}\n >\n <div class=\"step-top\">\n <div class=\"step-icon\">{icon}</div>\n {finalStep}\n </div>\n {(this.stepTitle || this.stepSubtitle) && (\n <div class=\"step-title-area\">\n {this.stepTitle && (\n <ic-typography variant=\"subtitle-large\" class=\"step-title\">\n {this.stepTitle}\n </ic-typography>\n )}\n {this.stepSubtitle && (\n <ic-typography variant=\"caption\" class=\"step-subtitle\">\n {this.stepSubtitle}\n </ic-typography>\n )}\n </div>\n )}\n </div>\n </Host>\n );\n }\n}\n"]}