@ukic/web-components 2.19.0 → 2.21.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (590) hide show
  1. package/dist/cjs/core.cjs.js +1 -1
  2. package/dist/cjs/{helpers-88e018cf.js → helpers-466a551d.js} +59 -99
  3. package/dist/cjs/helpers-466a551d.js.map +1 -0
  4. package/dist/cjs/ic-accordion-group.cjs.entry.js +3 -1
  5. package/dist/cjs/ic-accordion-group.cjs.entry.js.map +1 -1
  6. package/dist/cjs/ic-accordion.cjs.entry.js +1 -1
  7. package/dist/cjs/ic-alert.cjs.entry.js +1 -1
  8. package/dist/cjs/ic-back-to-top.cjs.entry.js +15 -9
  9. package/dist/cjs/ic-back-to-top.cjs.entry.js.map +1 -1
  10. package/dist/cjs/ic-badge.cjs.entry.js +55 -77
  11. package/dist/cjs/ic-badge.cjs.entry.js.map +1 -1
  12. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +3 -1
  13. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js.map +1 -1
  14. package/dist/cjs/ic-breadcrumb.cjs.entry.js +1 -1
  15. package/dist/cjs/ic-button_3.cjs.entry.js +14 -14
  16. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  17. package/dist/cjs/ic-card.cjs.entry.js +1 -1
  18. package/dist/cjs/ic-card.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ic-checkbox-group.cjs.entry.js +23 -16
  20. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  21. package/dist/cjs/ic-checkbox.cjs.entry.js +33 -31
  22. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -1
  23. package/dist/cjs/ic-chip.cjs.entry.js +21 -31
  24. package/dist/cjs/ic-chip.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ic-data-row.cjs.entry.js +1 -1
  26. package/dist/cjs/ic-dialog.cjs.entry.js +4 -2
  27. package/dist/cjs/ic-dialog.cjs.entry.js.map +1 -1
  28. package/dist/cjs/ic-divider.cjs.entry.js +1 -1
  29. package/dist/cjs/ic-empty-state.cjs.entry.js +1 -1
  30. package/dist/cjs/ic-footer-link-group.cjs.entry.js +2 -2
  31. package/dist/cjs/ic-footer-link-group.cjs.entry.js.map +1 -1
  32. package/dist/cjs/ic-footer-link.cjs.entry.js +1 -1
  33. package/dist/cjs/ic-footer.cjs.entry.js +2 -2
  34. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -1
  35. package/dist/cjs/ic-hero.cjs.entry.js +3 -2
  36. package/dist/cjs/ic-hero.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +2 -3
  38. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js.map +1 -1
  39. package/dist/cjs/ic-input-component-container_3.cjs.entry.js +5 -5
  40. package/dist/cjs/ic-input-component-container_3.cjs.entry.js.map +1 -1
  41. package/dist/cjs/ic-input-label_2.cjs.entry.js +1 -1
  42. package/dist/cjs/ic-link.cjs.entry.js +2 -2
  43. package/dist/cjs/ic-link.cjs.entry.js.map +1 -1
  44. package/dist/cjs/ic-menu-group.cjs.entry.js +1 -1
  45. package/dist/cjs/ic-menu-item.cjs.entry.js +4 -10
  46. package/dist/cjs/ic-menu-item.cjs.entry.js.map +1 -1
  47. package/dist/cjs/ic-navigation-button.cjs.entry.js +1 -1
  48. package/dist/cjs/ic-navigation-group.cjs.entry.js +1 -1
  49. package/dist/cjs/ic-navigation-item.cjs.entry.js +2 -2
  50. package/dist/cjs/ic-navigation-item.cjs.entry.js.map +1 -1
  51. package/dist/cjs/ic-navigation-menu.cjs.entry.js +1 -1
  52. package/dist/cjs/ic-page-header.cjs.entry.js +1 -1
  53. package/dist/cjs/ic-pagination-item.cjs.entry.js +18 -9
  54. package/dist/cjs/ic-pagination-item.cjs.entry.js.map +1 -1
  55. package/dist/cjs/ic-pagination.cjs.entry.js +21 -9
  56. package/dist/cjs/ic-pagination.cjs.entry.js.map +1 -1
  57. package/dist/cjs/ic-popover-menu.cjs.entry.js +13 -18
  58. package/dist/cjs/ic-popover-menu.cjs.entry.js.map +1 -1
  59. package/dist/cjs/ic-radio-group.cjs.entry.js +12 -16
  60. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -1
  61. package/dist/cjs/ic-radio-option.cjs.entry.js +37 -37
  62. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  63. package/dist/cjs/ic-search-bar.cjs.entry.js +1 -1
  64. package/dist/cjs/ic-select.cjs.entry.js +10 -6
  65. package/dist/cjs/ic-select.cjs.entry.js.map +1 -1
  66. package/dist/cjs/ic-side-navigation.cjs.entry.js +1 -1
  67. package/dist/cjs/ic-skeleton.cjs.entry.js +16 -35
  68. package/dist/cjs/ic-skeleton.cjs.entry.js.map +1 -1
  69. package/dist/cjs/ic-status-tag.cjs.entry.js +1 -1
  70. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -1
  71. package/dist/cjs/ic-step.cjs.entry.js +1 -1
  72. package/dist/cjs/ic-stepper.cjs.entry.js +1 -1
  73. package/dist/cjs/ic-switch.cjs.entry.js +2 -2
  74. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  75. package/dist/cjs/ic-tab-group.cjs.entry.js +1 -1
  76. package/dist/cjs/ic-tab-panel.cjs.entry.js +1 -1
  77. package/dist/cjs/ic-tab.cjs.entry.js +2 -2
  78. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -1
  79. package/dist/cjs/ic-text-field.cjs.entry.js +8 -8
  80. package/dist/cjs/ic-text-field.cjs.entry.js.map +1 -1
  81. package/dist/cjs/ic-theme.cjs.entry.js +13 -15
  82. package/dist/cjs/ic-theme.cjs.entry.js.map +1 -1
  83. package/dist/cjs/ic-toast.cjs.entry.js +1 -1
  84. package/dist/cjs/ic-toggle-button.cjs.entry.js +2 -2
  85. package/dist/cjs/ic-toggle-button.cjs.entry.js.map +1 -1
  86. package/dist/cjs/ic-top-navigation.cjs.entry.js +15 -24
  87. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -1
  88. package/dist/cjs/ic-typography.cjs.entry.js +2 -2
  89. package/dist/cjs/ic-typography.cjs.entry.js.map +1 -1
  90. package/dist/cjs/loader.cjs.js +1 -1
  91. package/dist/collection/components/ic-accordion/test/basic/ic-accordion.spec.js +1 -1
  92. package/dist/collection/components/ic-accordion/test/basic/ic-accordion.spec.js.map +1 -1
  93. package/dist/collection/components/ic-accordion-group/ic-accordion-group.js +5 -1
  94. package/dist/collection/components/ic-accordion-group/ic-accordion-group.js.map +1 -1
  95. package/dist/collection/components/ic-accordion-group/test/basic/ic-accordion-group.spec.js +5 -5
  96. package/dist/collection/components/ic-accordion-group/test/basic/ic-accordion-group.spec.js.map +1 -1
  97. package/dist/collection/components/ic-back-to-top/ic-back-to-top.css +7 -4
  98. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js +37 -7
  99. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js.map +1 -1
  100. package/dist/collection/components/ic-back-to-top/ic-back-to-top.types.js +2 -0
  101. package/dist/collection/components/ic-back-to-top/ic-back-to-top.types.js.map +1 -0
  102. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.spec.js +9 -0
  103. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.spec.js.map +1 -1
  104. package/dist/collection/components/ic-badge/ic-badge.js +64 -78
  105. package/dist/collection/components/ic-badge/ic-badge.js.map +1 -1
  106. package/dist/collection/components/ic-breadcrumb/test/basic/ic-breadcrumb.spec.js +4 -4
  107. package/dist/collection/components/ic-breadcrumb/test/basic/ic-breadcrumb.spec.js.map +1 -1
  108. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js +2 -0
  109. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js.map +1 -1
  110. package/dist/collection/components/ic-button/ic-button.css +289 -11
  111. package/dist/collection/components/ic-button/ic-button.js +11 -11
  112. package/dist/collection/components/ic-button/ic-button.js.map +1 -1
  113. package/dist/collection/components/ic-button/ic-button.types.js.map +1 -1
  114. package/dist/collection/components/ic-card/ic-card.css +8 -0
  115. package/dist/collection/components/ic-checkbox/ic-checkbox.css +1 -1
  116. package/dist/collection/components/ic-checkbox/ic-checkbox.js +31 -29
  117. package/dist/collection/components/ic-checkbox/ic-checkbox.js.map +1 -1
  118. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js +27 -15
  119. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js.map +1 -1
  120. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.spec.js +12 -0
  121. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.spec.js.map +1 -1
  122. package/dist/collection/components/ic-chip/ic-chip.css +5 -1
  123. package/dist/collection/components/ic-chip/ic-chip.js +20 -30
  124. package/dist/collection/components/ic-chip/ic-chip.js.map +1 -1
  125. package/dist/collection/components/ic-classification-banner/test/basic/ic-classification-banner.spec.js +5 -5
  126. package/dist/collection/components/ic-classification-banner/test/basic/ic-classification-banner.spec.js.map +1 -1
  127. package/dist/collection/components/ic-dialog/ic-dialog.css +11 -8
  128. package/dist/collection/components/ic-dialog/ic-dialog.js +4 -2
  129. package/dist/collection/components/ic-dialog/ic-dialog.js.map +1 -1
  130. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.spec.js +2 -2
  131. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.spec.js.map +1 -1
  132. package/dist/collection/components/ic-footer/ic-footer.js +1 -1
  133. package/dist/collection/components/ic-footer/ic-footer.js.map +1 -1
  134. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js +1 -1
  135. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js.map +1 -1
  136. package/dist/collection/components/ic-hero/ic-hero.js +4 -3
  137. package/dist/collection/components/ic-hero/ic-hero.js.map +1 -1
  138. package/dist/collection/components/ic-hero/test/basic/ic-hero.spec.js +1 -1
  139. package/dist/collection/components/ic-hero/test/basic/ic-hero.spec.js.map +1 -1
  140. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js +1 -2
  141. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js.map +1 -1
  142. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js +2 -2
  143. package/dist/collection/components/ic-input-component-container/ic-input-component-container.js.map +1 -1
  144. package/dist/collection/components/ic-input-component-container/test/basic/ic-input-component-container.spec.js +9 -9
  145. package/dist/collection/components/ic-input-component-container/test/basic/ic-input-component-container.spec.js.map +1 -1
  146. package/dist/collection/components/ic-input-container/test/basic/ic-input-container.spec.js +3 -3
  147. package/dist/collection/components/ic-input-container/test/basic/ic-input-container.spec.js.map +1 -1
  148. package/dist/collection/components/ic-input-label/test/basic/ic-input-label.spec.js +6 -6
  149. package/dist/collection/components/ic-input-label/test/basic/ic-input-label.spec.js.map +1 -1
  150. package/dist/collection/components/ic-input-validation/test/basic/ic-input-validation.spec.js +5 -5
  151. package/dist/collection/components/ic-input-validation/test/basic/ic-input-validation.spec.js.map +1 -1
  152. package/dist/collection/components/ic-link/ic-link.css +1 -1
  153. package/dist/collection/components/ic-link/test/basic/ic-link.spec.js +1 -1
  154. package/dist/collection/components/ic-link/test/basic/ic-link.spec.js.map +1 -1
  155. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.css +0 -1
  156. package/dist/collection/components/ic-menu/ic-menu.js +3 -3
  157. package/dist/collection/components/ic-menu/ic-menu.js.map +1 -1
  158. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js +41 -41
  159. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js.map +1 -1
  160. package/dist/collection/components/ic-menu-item/ic-menu-item.js +4 -10
  161. package/dist/collection/components/ic-menu-item/ic-menu-item.js.map +1 -1
  162. package/dist/collection/components/ic-navigation-button/test/basic/ic-navigation-button.spec.js +5 -5
  163. package/dist/collection/components/ic-navigation-button/test/basic/ic-navigation-button.spec.js.map +1 -1
  164. package/dist/collection/components/ic-navigation-item/ic-navigation-item.css +6 -0
  165. package/dist/collection/components/ic-navigation-item/test/basic/ic-navigation-item.spec.js +3 -3
  166. package/dist/collection/components/ic-navigation-item/test/basic/ic-navigation-item.spec.js.map +1 -1
  167. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.e2e.js +1 -1
  168. package/dist/collection/components/ic-navigation-menu/test/basic/ic-navigation-menu.e2e.js.map +1 -1
  169. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.spec.js +1 -1
  170. package/dist/collection/components/ic-page-header/test/basic/ic-page-header.spec.js.map +1 -1
  171. package/dist/collection/components/ic-pagination/ic-pagination.js +26 -8
  172. package/dist/collection/components/ic-pagination/ic-pagination.js.map +1 -1
  173. package/dist/collection/components/ic-pagination/ic-pagination.types.js.map +1 -1
  174. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.spec.js +44 -0
  175. package/dist/collection/components/ic-pagination/test/basic/ic-pagination.spec.js.map +1 -1
  176. package/dist/collection/components/ic-pagination-item/ic-pagination-item.css +5 -1
  177. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js +27 -44
  178. package/dist/collection/components/ic-pagination-item/ic-pagination-item.js.map +1 -1
  179. package/dist/collection/components/ic-pagination-item/test/basic/ic-pagination-item.spec.js +76 -0
  180. package/dist/collection/components/ic-pagination-item/test/basic/ic-pagination-item.spec.js.map +1 -0
  181. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js +12 -17
  182. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js.map +1 -1
  183. package/dist/collection/components/ic-radio-group/ic-radio-group.js +11 -15
  184. package/dist/collection/components/ic-radio-group/ic-radio-group.js.map +1 -1
  185. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.e2e.js +17 -17
  186. package/dist/collection/components/ic-radio-group/test/basic/ic-radio-group.e2e.js.map +1 -1
  187. package/dist/collection/components/ic-radio-option/ic-radio-option.js +37 -37
  188. package/dist/collection/components/ic-radio-option/ic-radio-option.js.map +1 -1
  189. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.e2e.js +5 -5
  190. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.e2e.js.map +1 -1
  191. package/dist/collection/components/ic-section-container/test/basic/ic-section-container.spec.js +4 -4
  192. package/dist/collection/components/ic-section-container/test/basic/ic-section-container.spec.js.map +1 -1
  193. package/dist/collection/components/ic-select/ic-select.js +9 -5
  194. package/dist/collection/components/ic-select/ic-select.js.map +1 -1
  195. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.spec.js +11 -11
  196. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.spec.js.map +1 -1
  197. package/dist/collection/components/ic-skeleton/ic-skeleton.js +16 -43
  198. package/dist/collection/components/ic-skeleton/ic-skeleton.js.map +1 -1
  199. package/dist/collection/components/ic-status-tag/ic-status-tag.js +1 -1
  200. package/dist/collection/components/ic-status-tag/ic-status-tag.js.map +1 -1
  201. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.e2e.js +1 -1
  202. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.e2e.js.map +1 -1
  203. package/dist/collection/components/ic-switch/ic-switch.css +11 -3
  204. package/dist/collection/components/ic-tab/ic-tab.css +17 -5
  205. package/dist/collection/components/ic-text-field/ic-text-field.css +1 -0
  206. package/dist/collection/components/ic-text-field/ic-text-field.js +6 -6
  207. package/dist/collection/components/ic-text-field/ic-text-field.js.map +1 -1
  208. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.input.spec.js +0 -1
  209. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.input.spec.js.map +1 -1
  210. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.textarea.spec.js +15 -15
  211. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.textarea.spec.js.map +1 -1
  212. package/dist/collection/components/ic-theme/ic-theme.js +21 -17
  213. package/dist/collection/components/ic-theme/ic-theme.js.map +1 -1
  214. package/dist/collection/components/ic-theme/test/basic/ic-theme.e2e.js +1 -1
  215. package/dist/collection/components/ic-theme/test/basic/ic-theme.e2e.js.map +1 -1
  216. package/dist/collection/components/ic-toggle-button/ic-toggle-button.css +21 -0
  217. package/dist/collection/components/ic-toggle-button-group/test/ic-toggle-button-group.spec.js +7 -7
  218. package/dist/collection/components/ic-toggle-button-group/test/ic-toggle-button-group.spec.js.map +1 -1
  219. package/dist/collection/components/ic-tooltip/ic-tooltip.css +7 -0
  220. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js +15 -24
  221. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js.map +1 -1
  222. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.spec.js +14 -14
  223. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.spec.js.map +1 -1
  224. package/dist/collection/components/ic-typography/ic-typography.css +11 -2
  225. package/dist/collection/utils/helpers.js +58 -102
  226. package/dist/collection/utils/helpers.js.map +1 -1
  227. package/dist/components/helpers.js +57 -97
  228. package/dist/components/helpers.js.map +1 -1
  229. package/dist/components/ic-accordion-group.js +2 -1
  230. package/dist/components/ic-accordion-group.js.map +1 -1
  231. package/dist/components/ic-back-to-top.js +22 -9
  232. package/dist/components/ic-back-to-top.js.map +1 -1
  233. package/dist/components/ic-badge.js +59 -77
  234. package/dist/components/ic-badge.js.map +1 -1
  235. package/dist/components/ic-breadcrumb-group.js +2 -0
  236. package/dist/components/ic-breadcrumb-group.js.map +1 -1
  237. package/dist/components/ic-button2.js +11 -11
  238. package/dist/components/ic-button2.js.map +1 -1
  239. package/dist/components/ic-card.js.map +1 -1
  240. package/dist/components/ic-checkbox-group.js +26 -16
  241. package/dist/components/ic-checkbox-group.js.map +1 -1
  242. package/dist/components/ic-checkbox.js +33 -31
  243. package/dist/components/ic-checkbox.js.map +1 -1
  244. package/dist/components/ic-chip.js +21 -31
  245. package/dist/components/ic-chip.js.map +1 -1
  246. package/dist/components/ic-dialog.js +4 -2
  247. package/dist/components/ic-dialog.js.map +1 -1
  248. package/dist/components/ic-divider2.js +1 -1
  249. package/dist/components/ic-footer-link-group.js +2 -2
  250. package/dist/components/ic-footer-link-group.js.map +1 -1
  251. package/dist/components/ic-footer-link.js +1 -1
  252. package/dist/components/ic-footer.js +2 -2
  253. package/dist/components/ic-footer.js.map +1 -1
  254. package/dist/components/ic-hero.js +3 -2
  255. package/dist/components/ic-hero.js.map +1 -1
  256. package/dist/components/ic-horizontal-scroll2.js +2 -3
  257. package/dist/components/ic-horizontal-scroll2.js.map +1 -1
  258. package/dist/components/ic-input-component-container2.js +2 -2
  259. package/dist/components/ic-input-component-container2.js.map +1 -1
  260. package/dist/components/ic-link2.js +1 -1
  261. package/dist/components/ic-link2.js.map +1 -1
  262. package/dist/components/ic-loading-indicator2.js +1 -1
  263. package/dist/components/ic-loading-indicator2.js.map +1 -1
  264. package/dist/components/ic-menu-item2.js +4 -10
  265. package/dist/components/ic-menu-item2.js.map +1 -1
  266. package/dist/components/ic-menu2.js +3 -3
  267. package/dist/components/ic-menu2.js.map +1 -1
  268. package/dist/components/ic-navigation-button.js +1 -1
  269. package/dist/components/ic-navigation-group.js +1 -1
  270. package/dist/components/ic-navigation-item.js +2 -2
  271. package/dist/components/ic-navigation-item.js.map +1 -1
  272. package/dist/components/ic-navigation-menu2.js +1 -1
  273. package/dist/components/ic-pagination-item2.js +22 -12
  274. package/dist/components/ic-pagination-item2.js.map +1 -1
  275. package/dist/components/ic-pagination.js +23 -8
  276. package/dist/components/ic-pagination.js.map +1 -1
  277. package/dist/components/ic-popover-menu.js +13 -18
  278. package/dist/components/ic-popover-menu.js.map +1 -1
  279. package/dist/components/ic-radio-group.js +11 -15
  280. package/dist/components/ic-radio-group.js.map +1 -1
  281. package/dist/components/ic-radio-option.js +37 -37
  282. package/dist/components/ic-radio-option.js.map +1 -1
  283. package/dist/components/ic-select.js +9 -5
  284. package/dist/components/ic-select.js.map +1 -1
  285. package/dist/components/ic-side-navigation.js +1 -1
  286. package/dist/components/ic-skeleton.js +17 -40
  287. package/dist/components/ic-skeleton.js.map +1 -1
  288. package/dist/components/ic-status-tag.js.map +1 -1
  289. package/dist/components/ic-switch.js +1 -1
  290. package/dist/components/ic-switch.js.map +1 -1
  291. package/dist/components/ic-tab.js +1 -1
  292. package/dist/components/ic-tab.js.map +1 -1
  293. package/dist/components/ic-text-field2.js +7 -7
  294. package/dist/components/ic-text-field2.js.map +1 -1
  295. package/dist/components/ic-theme.js +13 -15
  296. package/dist/components/ic-theme.js.map +1 -1
  297. package/dist/components/ic-toast.js +1 -1
  298. package/dist/components/ic-toggle-button.js +1 -1
  299. package/dist/components/ic-toggle-button.js.map +1 -1
  300. package/dist/components/ic-tooltip2.js +1 -1
  301. package/dist/components/ic-tooltip2.js.map +1 -1
  302. package/dist/components/ic-top-navigation.js +15 -24
  303. package/dist/components/ic-top-navigation.js.map +1 -1
  304. package/dist/components/ic-typography2.js +1 -1
  305. package/dist/components/ic-typography2.js.map +1 -1
  306. package/dist/core/core.css +2 -2
  307. package/dist/core/core.esm.js +1 -1
  308. package/dist/core/core.esm.js.map +1 -1
  309. package/dist/core/p-063587c6.js +2 -0
  310. package/dist/core/p-063587c6.js.map +1 -0
  311. package/dist/core/{p-346578e4.entry.js → p-099efe2a.entry.js} +2 -2
  312. package/dist/core/p-0a6fbf35.entry.js +2 -0
  313. package/dist/core/p-0a6fbf35.entry.js.map +1 -0
  314. package/dist/core/{p-051583a5.entry.js → p-10dba909.entry.js} +2 -2
  315. package/dist/core/p-10dba909.entry.js.map +1 -0
  316. package/dist/core/p-14dd5b2b.entry.js +2 -0
  317. package/dist/core/p-14dd5b2b.entry.js.map +1 -0
  318. package/dist/core/{p-ba1c3cf7.entry.js → p-1624f4de.entry.js} +2 -2
  319. package/dist/core/{p-1b1270a1.entry.js → p-227a3f22.entry.js} +2 -2
  320. package/dist/core/p-227a3f22.entry.js.map +1 -0
  321. package/dist/core/{p-04cc2b25.entry.js → p-25606a38.entry.js} +2 -2
  322. package/dist/core/{p-328bc6a2.entry.js → p-25edb082.entry.js} +2 -2
  323. package/dist/core/p-25edb082.entry.js.map +1 -0
  324. package/dist/core/{p-4f3fe190.entry.js → p-2965644e.entry.js} +2 -2
  325. package/dist/core/{p-bceaf300.entry.js → p-34d719f8.entry.js} +2 -2
  326. package/dist/core/p-34d719f8.entry.js.map +1 -0
  327. package/dist/core/{p-3f53446c.entry.js → p-35856434.entry.js} +2 -2
  328. package/dist/core/{p-7b720034.entry.js → p-3eda4e14.entry.js} +2 -2
  329. package/dist/core/p-3eda4e14.entry.js.map +1 -0
  330. package/dist/core/{p-6f9dcfb5.entry.js → p-40c508c8.entry.js} +2 -2
  331. package/dist/core/{p-6f9dcfb5.entry.js.map → p-40c508c8.entry.js.map} +1 -1
  332. package/dist/core/p-426a5500.entry.js +2 -0
  333. package/dist/core/p-426a5500.entry.js.map +1 -0
  334. package/dist/core/p-4522e5c0.entry.js +2 -0
  335. package/dist/core/p-4522e5c0.entry.js.map +1 -0
  336. package/dist/core/{p-d7f4779d.entry.js → p-459355ef.entry.js} +2 -2
  337. package/dist/core/p-49cdaddc.entry.js +2 -0
  338. package/dist/core/p-49cdaddc.entry.js.map +1 -0
  339. package/dist/core/{p-f50a57f3.entry.js → p-4a0acd0f.entry.js} +2 -2
  340. package/dist/core/{p-f50a57f3.entry.js.map → p-4a0acd0f.entry.js.map} +1 -1
  341. package/dist/core/{p-32e2ae6f.entry.js → p-4e3a03cb.entry.js} +2 -2
  342. package/dist/core/{p-c919c571.entry.js → p-521cc9c6.entry.js} +2 -2
  343. package/dist/core/{p-c3acbefe.entry.js → p-56b709a1.entry.js} +2 -2
  344. package/dist/core/{p-c3acbefe.entry.js.map → p-56b709a1.entry.js.map} +1 -1
  345. package/dist/core/{p-2f91e86a.entry.js → p-687af4e5.entry.js} +2 -2
  346. package/dist/core/{p-8e37e832.entry.js → p-7dbd0a9f.entry.js} +2 -2
  347. package/dist/core/p-8a0d4ea2.entry.js +2 -0
  348. package/dist/core/p-8a0d4ea2.entry.js.map +1 -0
  349. package/dist/core/p-8bb09d94.entry.js +2 -0
  350. package/dist/core/p-8bb09d94.entry.js.map +1 -0
  351. package/dist/core/{p-e5957ce0.entry.js → p-8e3cc8e9.entry.js} +2 -2
  352. package/dist/core/{p-e68485ee.entry.js → p-8ec2105c.entry.js} +2 -2
  353. package/dist/core/p-8ec2105c.entry.js.map +1 -0
  354. package/dist/core/{p-adf468f4.entry.js → p-94c512d4.entry.js} +2 -2
  355. package/dist/core/p-94c512d4.entry.js.map +1 -0
  356. package/dist/core/p-9e4b8aeb.entry.js +2 -0
  357. package/dist/core/p-9e4b8aeb.entry.js.map +1 -0
  358. package/dist/core/{p-692ccc73.entry.js → p-a049705a.entry.js} +2 -2
  359. package/dist/core/p-a049705a.entry.js.map +1 -0
  360. package/dist/core/{p-731515cf.entry.js → p-a541cf18.entry.js} +2 -2
  361. package/dist/core/{p-52a4c223.entry.js → p-ad6176a2.entry.js} +2 -2
  362. package/dist/core/p-ad932b00.entry.js +2 -0
  363. package/dist/core/p-ad932b00.entry.js.map +1 -0
  364. package/dist/core/{p-5481b048.entry.js → p-adecaedd.entry.js} +2 -2
  365. package/dist/core/{p-2d4e7985.entry.js → p-af5e3bab.entry.js} +2 -2
  366. package/dist/core/p-af5e3bab.entry.js.map +1 -0
  367. package/dist/core/{p-8ed04819.entry.js → p-b6be866c.entry.js} +2 -2
  368. package/dist/core/p-b6be866c.entry.js.map +1 -0
  369. package/dist/core/p-b8d68163.entry.js +2 -0
  370. package/dist/core/p-b8d68163.entry.js.map +1 -0
  371. package/dist/core/{p-8153def1.entry.js → p-c199045d.entry.js} +2 -2
  372. package/dist/core/{p-1197f0d4.entry.js → p-c649689e.entry.js} +2 -2
  373. package/dist/core/{p-1197f0d4.entry.js.map → p-c649689e.entry.js.map} +1 -1
  374. package/dist/core/p-cbba9c7c.entry.js +2 -0
  375. package/dist/core/p-cbba9c7c.entry.js.map +1 -0
  376. package/dist/core/{p-1a6fab3e.entry.js → p-cc9e5b0e.entry.js} +2 -2
  377. package/dist/core/{p-03796d51.entry.js → p-ce4e0e38.entry.js} +2 -2
  378. package/dist/core/p-d3f10067.entry.js +2 -0
  379. package/dist/core/p-d3f10067.entry.js.map +1 -0
  380. package/dist/core/p-dae27567.entry.js +2 -0
  381. package/dist/core/p-dae27567.entry.js.map +1 -0
  382. package/dist/core/{p-a13236ef.entry.js → p-de40b0b1.entry.js} +2 -2
  383. package/dist/core/p-de40b0b1.entry.js.map +1 -0
  384. package/dist/core/{p-af5eacc1.entry.js → p-e5d5b07e.entry.js} +2 -2
  385. package/dist/core/{p-b451f27c.entry.js → p-e70c6b33.entry.js} +2 -2
  386. package/dist/core/{p-8b65be1e.entry.js → p-e776f72a.entry.js} +2 -2
  387. package/dist/core/p-e9ec912f.entry.js +2 -0
  388. package/dist/core/p-e9ec912f.entry.js.map +1 -0
  389. package/dist/core/p-ec77a078.entry.js +2 -0
  390. package/dist/core/p-ec77a078.entry.js.map +1 -0
  391. package/dist/core/{p-2b326b17.entry.js → p-f706798e.entry.js} +2 -2
  392. package/dist/core/{p-2b326b17.entry.js.map → p-f706798e.entry.js.map} +1 -1
  393. package/dist/core/{p-1c3b619f.entry.js → p-fd6f0ef0.entry.js} +2 -2
  394. package/dist/core/p-fd6f0ef0.entry.js.map +1 -0
  395. package/dist/core/{p-ba40f44a.entry.js → p-fe702898.entry.js} +2 -2
  396. package/dist/core/p-fe702898.entry.js.map +1 -0
  397. package/dist/esm/core.js +1 -1
  398. package/dist/esm/{helpers-24ba0b83.js → helpers-c28c228a.js} +58 -98
  399. package/dist/esm/helpers-c28c228a.js.map +1 -0
  400. package/dist/esm/ic-accordion-group.entry.js +3 -1
  401. package/dist/esm/ic-accordion-group.entry.js.map +1 -1
  402. package/dist/esm/ic-accordion.entry.js +1 -1
  403. package/dist/esm/ic-alert.entry.js +1 -1
  404. package/dist/esm/ic-back-to-top.entry.js +15 -9
  405. package/dist/esm/ic-back-to-top.entry.js.map +1 -1
  406. package/dist/esm/ic-badge.entry.js +55 -77
  407. package/dist/esm/ic-badge.entry.js.map +1 -1
  408. package/dist/esm/ic-breadcrumb-group.entry.js +3 -1
  409. package/dist/esm/ic-breadcrumb-group.entry.js.map +1 -1
  410. package/dist/esm/ic-breadcrumb.entry.js +1 -1
  411. package/dist/esm/ic-button_3.entry.js +14 -14
  412. package/dist/esm/ic-button_3.entry.js.map +1 -1
  413. package/dist/esm/ic-card.entry.js +1 -1
  414. package/dist/esm/ic-card.entry.js.map +1 -1
  415. package/dist/esm/ic-checkbox-group.entry.js +23 -16
  416. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  417. package/dist/esm/ic-checkbox.entry.js +33 -31
  418. package/dist/esm/ic-checkbox.entry.js.map +1 -1
  419. package/dist/esm/ic-chip.entry.js +21 -31
  420. package/dist/esm/ic-chip.entry.js.map +1 -1
  421. package/dist/esm/ic-data-row.entry.js +1 -1
  422. package/dist/esm/ic-dialog.entry.js +4 -2
  423. package/dist/esm/ic-dialog.entry.js.map +1 -1
  424. package/dist/esm/ic-divider.entry.js +1 -1
  425. package/dist/esm/ic-empty-state.entry.js +1 -1
  426. package/dist/esm/ic-footer-link-group.entry.js +2 -2
  427. package/dist/esm/ic-footer-link-group.entry.js.map +1 -1
  428. package/dist/esm/ic-footer-link.entry.js +1 -1
  429. package/dist/esm/ic-footer.entry.js +2 -2
  430. package/dist/esm/ic-footer.entry.js.map +1 -1
  431. package/dist/esm/ic-hero.entry.js +3 -2
  432. package/dist/esm/ic-hero.entry.js.map +1 -1
  433. package/dist/esm/ic-horizontal-scroll.entry.js +2 -3
  434. package/dist/esm/ic-horizontal-scroll.entry.js.map +1 -1
  435. package/dist/esm/ic-input-component-container_3.entry.js +5 -5
  436. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -1
  437. package/dist/esm/ic-input-label_2.entry.js +1 -1
  438. package/dist/esm/ic-link.entry.js +2 -2
  439. package/dist/esm/ic-link.entry.js.map +1 -1
  440. package/dist/esm/ic-menu-group.entry.js +1 -1
  441. package/dist/esm/ic-menu-item.entry.js +4 -10
  442. package/dist/esm/ic-menu-item.entry.js.map +1 -1
  443. package/dist/esm/ic-navigation-button.entry.js +1 -1
  444. package/dist/esm/ic-navigation-group.entry.js +1 -1
  445. package/dist/esm/ic-navigation-item.entry.js +2 -2
  446. package/dist/esm/ic-navigation-item.entry.js.map +1 -1
  447. package/dist/esm/ic-navigation-menu.entry.js +1 -1
  448. package/dist/esm/ic-page-header.entry.js +1 -1
  449. package/dist/esm/ic-pagination-item.entry.js +18 -9
  450. package/dist/esm/ic-pagination-item.entry.js.map +1 -1
  451. package/dist/esm/ic-pagination.entry.js +21 -9
  452. package/dist/esm/ic-pagination.entry.js.map +1 -1
  453. package/dist/esm/ic-popover-menu.entry.js +13 -18
  454. package/dist/esm/ic-popover-menu.entry.js.map +1 -1
  455. package/dist/esm/ic-radio-group.entry.js +12 -16
  456. package/dist/esm/ic-radio-group.entry.js.map +1 -1
  457. package/dist/esm/ic-radio-option.entry.js +37 -37
  458. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  459. package/dist/esm/ic-search-bar.entry.js +1 -1
  460. package/dist/esm/ic-select.entry.js +10 -6
  461. package/dist/esm/ic-select.entry.js.map +1 -1
  462. package/dist/esm/ic-side-navigation.entry.js +1 -1
  463. package/dist/esm/ic-skeleton.entry.js +16 -35
  464. package/dist/esm/ic-skeleton.entry.js.map +1 -1
  465. package/dist/esm/ic-status-tag.entry.js +1 -1
  466. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  467. package/dist/esm/ic-step.entry.js +1 -1
  468. package/dist/esm/ic-stepper.entry.js +1 -1
  469. package/dist/esm/ic-switch.entry.js +2 -2
  470. package/dist/esm/ic-switch.entry.js.map +1 -1
  471. package/dist/esm/ic-tab-group.entry.js +1 -1
  472. package/dist/esm/ic-tab-panel.entry.js +1 -1
  473. package/dist/esm/ic-tab.entry.js +2 -2
  474. package/dist/esm/ic-tab.entry.js.map +1 -1
  475. package/dist/esm/ic-text-field.entry.js +8 -8
  476. package/dist/esm/ic-text-field.entry.js.map +1 -1
  477. package/dist/esm/ic-theme.entry.js +13 -15
  478. package/dist/esm/ic-theme.entry.js.map +1 -1
  479. package/dist/esm/ic-toast.entry.js +1 -1
  480. package/dist/esm/ic-toggle-button.entry.js +2 -2
  481. package/dist/esm/ic-toggle-button.entry.js.map +1 -1
  482. package/dist/esm/ic-top-navigation.entry.js +15 -24
  483. package/dist/esm/ic-top-navigation.entry.js.map +1 -1
  484. package/dist/esm/ic-typography.entry.js +2 -2
  485. package/dist/esm/ic-typography.entry.js.map +1 -1
  486. package/dist/esm/loader.js +1 -1
  487. package/dist/types/components/ic-accordion-group/ic-accordion-group.d.ts +3 -0
  488. package/dist/types/components/ic-back-to-top/ic-back-to-top.d.ts +6 -0
  489. package/dist/types/components/ic-back-to-top/ic-back-to-top.types.d.ts +1 -0
  490. package/dist/types/components/ic-badge/ic-badge.d.ts +6 -0
  491. package/dist/types/components/ic-button/ic-button.d.ts +1 -1
  492. package/dist/types/components/ic-button/ic-button.types.d.ts +1 -1
  493. package/dist/types/components/ic-checkbox/ic-checkbox.d.ts +0 -1
  494. package/dist/types/components/ic-checkbox-group/ic-checkbox-group.d.ts +2 -1
  495. package/dist/types/components/ic-chip/ic-chip.d.ts +1 -1
  496. package/dist/types/components/ic-pagination/ic-pagination.d.ts +3 -0
  497. package/dist/types/components/ic-pagination/ic-pagination.types.d.ts +2 -0
  498. package/dist/types/components/ic-pagination-item/ic-pagination-item.d.ts +2 -8
  499. package/dist/types/components/ic-popover-menu/ic-popover-menu.d.ts +4 -1
  500. package/dist/types/components/ic-radio-group/ic-radio-group.d.ts +1 -1
  501. package/dist/types/components/ic-radio-option/ic-radio-option.d.ts +1 -0
  502. package/dist/types/components/ic-skeleton/ic-skeleton.d.ts +0 -5
  503. package/dist/types/components/ic-status-tag/ic-status-tag.d.ts +1 -0
  504. package/dist/types/components/ic-text-field/ic-text-field.d.ts +0 -1
  505. package/dist/types/components/ic-theme/ic-theme.d.ts +2 -3
  506. package/dist/types/components/ic-top-navigation/ic-top-navigation.d.ts +2 -1
  507. package/dist/types/components.d.ts +16 -22
  508. package/dist/types/utils/helpers.d.ts +7 -13
  509. package/hydrate/index.js +398 -472
  510. package/package.json +2 -2
  511. package/vscode-data.json +25 -9
  512. package/dist/cjs/helpers-88e018cf.js.map +0 -1
  513. package/dist/collection/components/ic-tab/test/basic/ic-tab.e2e.js +0 -32
  514. package/dist/collection/components/ic-tab/test/basic/ic-tab.e2e.js.map +0 -1
  515. package/dist/collection/components/ic-tab-context/test/a11y/ic-tab-context.test.a11y.js +0 -19
  516. package/dist/collection/components/ic-tab-context/test/a11y/ic-tab-context.test.a11y.js.map +0 -1
  517. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.e2e.js +0 -354
  518. package/dist/collection/components/ic-tab-context/test/basic/ic-tab-context.e2e.js.map +0 -1
  519. package/dist/collection/components/ic-text-field/test/a11y/ic-text-field.test.a11y.js +0 -33
  520. package/dist/collection/components/ic-text-field/test/a11y/ic-text-field.test.a11y.js.map +0 -1
  521. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.e2e.js +0 -110
  522. package/dist/collection/components/ic-text-field/test/basic/ic-text-field.e2e.js.map +0 -1
  523. package/dist/core/p-00c21dd7.entry.js +0 -2
  524. package/dist/core/p-00c21dd7.entry.js.map +0 -1
  525. package/dist/core/p-02ad4585.entry.js +0 -2
  526. package/dist/core/p-02ad4585.entry.js.map +0 -1
  527. package/dist/core/p-051583a5.entry.js.map +0 -1
  528. package/dist/core/p-078f7f23.entry.js +0 -2
  529. package/dist/core/p-078f7f23.entry.js.map +0 -1
  530. package/dist/core/p-0c097626.entry.js +0 -2
  531. package/dist/core/p-0c097626.entry.js.map +0 -1
  532. package/dist/core/p-1b1270a1.entry.js.map +0 -1
  533. package/dist/core/p-1c3b619f.entry.js.map +0 -1
  534. package/dist/core/p-24bed047.entry.js +0 -2
  535. package/dist/core/p-24bed047.entry.js.map +0 -1
  536. package/dist/core/p-2d4e7985.entry.js.map +0 -1
  537. package/dist/core/p-328bc6a2.entry.js.map +0 -1
  538. package/dist/core/p-44ea7a6d.entry.js +0 -2
  539. package/dist/core/p-44ea7a6d.entry.js.map +0 -1
  540. package/dist/core/p-498273cb.entry.js +0 -2
  541. package/dist/core/p-498273cb.entry.js.map +0 -1
  542. package/dist/core/p-692ccc73.entry.js.map +0 -1
  543. package/dist/core/p-74f9082d.entry.js +0 -2
  544. package/dist/core/p-74f9082d.entry.js.map +0 -1
  545. package/dist/core/p-7b720034.entry.js.map +0 -1
  546. package/dist/core/p-8bc2a670.entry.js +0 -2
  547. package/dist/core/p-8bc2a670.entry.js.map +0 -1
  548. package/dist/core/p-8ed04819.entry.js.map +0 -1
  549. package/dist/core/p-8fe2b073.entry.js +0 -2
  550. package/dist/core/p-8fe2b073.entry.js.map +0 -1
  551. package/dist/core/p-9f29ab99.entry.js +0 -2
  552. package/dist/core/p-9f29ab99.entry.js.map +0 -1
  553. package/dist/core/p-a13236ef.entry.js.map +0 -1
  554. package/dist/core/p-adf468f4.entry.js.map +0 -1
  555. package/dist/core/p-ba40f44a.entry.js.map +0 -1
  556. package/dist/core/p-bceaf300.entry.js.map +0 -1
  557. package/dist/core/p-d19d157d.entry.js +0 -2
  558. package/dist/core/p-d19d157d.entry.js.map +0 -1
  559. package/dist/core/p-e4d0d1fb.js +0 -2
  560. package/dist/core/p-e4d0d1fb.js.map +0 -1
  561. package/dist/core/p-e68485ee.entry.js.map +0 -1
  562. package/dist/core/p-e8e0fa96.entry.js +0 -2
  563. package/dist/core/p-e8e0fa96.entry.js.map +0 -1
  564. package/dist/core/p-f8df0716.entry.js +0 -2
  565. package/dist/core/p-f8df0716.entry.js.map +0 -1
  566. package/dist/core/p-fd737b7e.entry.js +0 -2
  567. package/dist/core/p-fd737b7e.entry.js.map +0 -1
  568. package/dist/esm/helpers-24ba0b83.js.map +0 -1
  569. package/dist/types/components/ic-tab-context/test/a11y/ic-tab-context.test.a11y.d.ts +0 -1
  570. package/dist/types/components/ic-text-field/test/a11y/ic-text-field.test.a11y.d.ts +0 -1
  571. /package/dist/core/{p-346578e4.entry.js.map → p-099efe2a.entry.js.map} +0 -0
  572. /package/dist/core/{p-ba1c3cf7.entry.js.map → p-1624f4de.entry.js.map} +0 -0
  573. /package/dist/core/{p-04cc2b25.entry.js.map → p-25606a38.entry.js.map} +0 -0
  574. /package/dist/core/{p-4f3fe190.entry.js.map → p-2965644e.entry.js.map} +0 -0
  575. /package/dist/core/{p-3f53446c.entry.js.map → p-35856434.entry.js.map} +0 -0
  576. /package/dist/core/{p-d7f4779d.entry.js.map → p-459355ef.entry.js.map} +0 -0
  577. /package/dist/core/{p-32e2ae6f.entry.js.map → p-4e3a03cb.entry.js.map} +0 -0
  578. /package/dist/core/{p-c919c571.entry.js.map → p-521cc9c6.entry.js.map} +0 -0
  579. /package/dist/core/{p-2f91e86a.entry.js.map → p-687af4e5.entry.js.map} +0 -0
  580. /package/dist/core/{p-8e37e832.entry.js.map → p-7dbd0a9f.entry.js.map} +0 -0
  581. /package/dist/core/{p-e5957ce0.entry.js.map → p-8e3cc8e9.entry.js.map} +0 -0
  582. /package/dist/core/{p-731515cf.entry.js.map → p-a541cf18.entry.js.map} +0 -0
  583. /package/dist/core/{p-52a4c223.entry.js.map → p-ad6176a2.entry.js.map} +0 -0
  584. /package/dist/core/{p-5481b048.entry.js.map → p-adecaedd.entry.js.map} +0 -0
  585. /package/dist/core/{p-8153def1.entry.js.map → p-c199045d.entry.js.map} +0 -0
  586. /package/dist/core/{p-1a6fab3e.entry.js.map → p-cc9e5b0e.entry.js.map} +0 -0
  587. /package/dist/core/{p-03796d51.entry.js.map → p-ce4e0e38.entry.js.map} +0 -0
  588. /package/dist/core/{p-af5eacc1.entry.js.map → p-e5d5b07e.entry.js.map} +0 -0
  589. /package/dist/core/{p-b451f27c.entry.js.map → p-e70c6b33.entry.js.map} +0 -0
  590. /package/dist/core/{p-8b65be1e.entry.js.map → p-e776f72a.entry.js.map} +0 -0
@@ -723,6 +723,32 @@ video {
723
723
  background: none;
724
724
  }
725
725
 
726
+ /* Destructive */
727
+
728
+ :host(.button-variant-destructive) .button,
729
+ :host(.button-variant-destructive) ::slotted(a) {
730
+ color: var(--ic-architectural-white);
731
+ background-color: var(--ic-action-destructive);
732
+ text-transform: uppercase;
733
+ }
734
+
735
+ :host(.button-variant-destructive) .button:hover:not(:focus),
736
+ :host(.button-variant-destructive) .button:hover:focus {
737
+ background-color: var(--ic-action-destructive-hover);
738
+ }
739
+
740
+ :host(.button-variant-destructive) .button:active:not(:focus),
741
+ :host(.button-variant-destructive) .button:active:focus,
742
+ :host(.button-variant-destructive.loading) .button {
743
+ background-color: var(--ic-action-destructive-active);
744
+ }
745
+
746
+ :host(.button-variant-destructive.disabled) .button,
747
+ :host(.button-variant-destructive.disabled) ::slotted(a) {
748
+ background: var(--ic-architectural-200);
749
+ color: var(--ic-architectural-300);
750
+ }
751
+
726
752
  /* Icon */
727
753
 
728
754
  :host(.button-variant-icon) .button,
@@ -763,28 +789,252 @@ video {
763
789
  background: none;
764
790
  }
765
791
 
766
- /* Destructive */
792
+ /***********************
793
+ * Icon Variants
794
+ ***********************/
767
795
 
768
- :host(.button-variant-destructive) .button,
769
- :host(.button-variant-destructive) ::slotted(a) {
796
+ /* Icon-primary */
797
+
798
+ :host(.button-variant-icon-primary) .button,
799
+ :host(.button-variant-icon-primary) ::slotted(a) {
800
+ color: var(--ic-architectural-white);
801
+ background-color: var(--button-default);
802
+ min-width: 0;
803
+ gap: var(--ic-space-xs);
804
+ margin: var(--ic-space-1px) 0;
805
+ }
806
+
807
+ :host(.button-variant-icon-primary) .icon-container {
808
+ width: var(--ic-space-lg) !important;
809
+ height: var(--ic-space-lg) !important;
810
+ }
811
+
812
+ :host(.button-variant-icon-primary) .button:hover:not(:focus),
813
+ :host(.button-variant-icon-primary) ::slotted(a:hover:not(:focus)) {
814
+ background-color: var(--button-default-hover);
815
+ }
816
+ :host(.button-variant-icon-primary) .button:hover:focus,
817
+ :host(.button-variant-icon-primary) ::slotted(a:hover:focus) {
818
+ background-color: var(--button-default-hover);
819
+ border-color: var(--button-default-hover);
820
+ }
821
+
822
+ :host(.button-variant-icon-primary) .button:active:not(:focus),
823
+ :host(.button-variant-icon-primary) .button:active:focus,
824
+ :host(.button-variant-icon-primary) .button:active,
825
+ :host(.button-variant-icon-primary) ::slotted(a:active:not(:focus)),
826
+ :host(.button-variant-icon-primary) ::slotted(a:active:focus),
827
+ :host(.button-variant-icon-primary) ::slotted(a:active),
828
+ :host(.button-variant-icon-primary.loading) .button {
829
+ background: var(--button-default-active);
830
+ }
831
+
832
+ :host(.button-variant-icon-primary.loading) .button ic-loading-indicator {
833
+ --inner-color: var(--ic-architectural-white);
834
+ }
835
+
836
+ :host(.button-variant-icon-primary:not(.light)) .button:active,
837
+ :host(.button-variant-icon-primary:not(.light)) ::slotted(a:active) {
838
+ color: var(--ic-architectural-white);
839
+ }
840
+
841
+ :host(.button-variant-icon-primary.disabled) .button,
842
+ :host(.button-variant-icon-primary.disabled) .button:hover,
843
+ :host(.button-variant-icon-primary.disabled) .button:active,
844
+ :host(.button-variant-icon-primary.disabled) ::slotted(a),
845
+ :host(.button-variant-icon-primary.disabled) ::slotted(a:hover),
846
+ :host(.button-variant-icon-primary.disabled) ::slotted(a:active) {
847
+ color: var(--ic-architectural-300);
848
+ background: var(--ic-architectural-200);
849
+ }
850
+
851
+ :host(.button-variant-icon-primary.light) .button,
852
+ :host(.button-variant-icon-primary.light) ::slotted(a) {
853
+ color: var(--ic-color-primary-text);
854
+ }
855
+
856
+ :host(.button-variant-icon-primary.light) .button,
857
+ :host(.button-variant-icon-primary.light) ::slotted(a) {
858
+ color: var(--ic-color-primary-text);
859
+ }
860
+
861
+ :host(.button-variant-icon-primary.light) .button:hover,
862
+ :host(.button-variant-icon-primary.light) ::slotted(a:hover) {
863
+ background: var(--ic-action-light-hover);
864
+ }
865
+
866
+ :host(.button-variant-icon-primary.light) .button:active,
867
+ :host(.button-variant-icon-primary.light) ::slotted(a:active),
868
+ :host(.button-variant-icon-primary.light.loading) .button,
869
+ :host(.button-variant-icon-primary.light.loading) ::slotted(a) {
870
+ background: var(--ic-architectural-300);
871
+ }
872
+
873
+ :host(.button-variant-icon-primary.dark) .button,
874
+ :host(.button-variant-icon-primary.dark) ::slotted(a) {
875
+ color: var(--ic-architectural-white);
876
+ }
877
+
878
+ :host(.button-variant-icon-primary.dark) .button:hover,
879
+ :host(.button-variant-icon-primary.dark) ::slotted(a:hover) {
880
+ background: var(--ic-action-dark-hover);
881
+ }
882
+
883
+ :host(.button-variant-icon-primary.dark) .button:active,
884
+ :host(.button-variant-icon-primary.dark) ::slotted(a:active),
885
+ :host(.button-variant-icon-primary.dark.loading) .button,
886
+ :host(.button-variant-icon-primary.dark.loading) ::slotted(a) {
887
+ background: var(--ic-action-dark-active);
888
+ }
889
+
890
+ /* Icon-secondary */
891
+
892
+ :host(.button-variant-icon-secondary) .button,
893
+ :host(.button-variant-icon-secondary) ::slotted(a) {
894
+ border: var(--ic-border-width) solid var(--button-default);
895
+ color: var(--button-default);
896
+ min-width: 0;
897
+ gap: var(--ic-space-xs);
898
+ margin: var(--ic-space-1px) 0;
899
+ }
900
+
901
+ :host(.button-variant-icon-secondary) .icon-container {
902
+ width: var(--ic-space-lg) !important;
903
+ height: var(--ic-space-lg) !important;
904
+ }
905
+
906
+ :host(.button-variant-icon-secondary) .button:hover:not(:focus),
907
+ :host(.button-variant-icon-secondary) ::slotted(a:hover:not(:focus)),
908
+ :host(.button-variant-icon-secondary) .button:hover:focus,
909
+ :host(.button-variant-icon-secondary) ::slotted(a:hover:focus) {
910
+ background-color: var(--button-default-background-hover);
911
+ border-color: var(--button-default-hover);
912
+ color: var(--button-default-hover);
913
+ }
914
+
915
+ :host(.button-variant-icon-secondary) .button:active:not(:focus),
916
+ :host(.button-variant-icon-secondary) .button:active:focus,
917
+ :host(.button-variant-icon-secondary) .button:active,
918
+ :host(.button-variant-icon-secondary) ::slotted(a:active:not(:focus)),
919
+ :host(.button-variant-icon-secondary) ::slotted(a:active:focus),
920
+ :host(.button-variant-icon-secondary) ::slotted(a:active) {
921
+ border-color: var(--button-default-active);
922
+ background-color: var(--button-default-background-active);
923
+ color: var(--button-default-active);
924
+ }
925
+
926
+ :host(.button-variant-icon-secondary.loading) .button {
927
+ border-color: var(--button-default-active);
928
+ background: var(--button-default-background-active);
929
+ color: var(--button-default-active);
930
+ }
931
+
932
+ :host(.button-variant-icon-secondary.disabled) .button,
933
+ :host(.button-variant-icon-secondary.disabled) .button:hover,
934
+ :host(.button-variant-icon-secondary.disabled) .button:active,
935
+ :host(.button-variant-icon-secondary.disabled) ::slotted(a),
936
+ :host(.button-variant-icon-secondary.disabled) ::slotted(a:hover),
937
+ :host(.button-variant-icon-secondary.disabled) ::slotted(a:active) {
938
+ border-color: var(--ic-architectural-300);
939
+ color: var(--ic-architectural-300);
940
+ background: none;
941
+ }
942
+
943
+ :host(.button-variant-icon-secondary.light.disabled) .button,
944
+ :host(.button-variant-icon-secondary.light.disabled) .button:hover,
945
+ :host(.button-variant-icon-secondary.light.disabled) .button:active,
946
+ :host(.button-variant-icon-secondary.light.disabled) ::slotted(a),
947
+ :host(.button-variant-icon-secondary.light.disabled) ::slotted(a:hover),
948
+ :host(.button-variant-icon-secondary.light.disabled) ::slotted(a:active) {
949
+ border-color: var(--ic-architectural-500);
950
+ color: var(--ic-architectural-500);
951
+ background: none;
952
+ }
953
+
954
+ /* Icon-tertiary */
955
+
956
+ :host(.button-variant-icon-tertiary) .button,
957
+ :host(.button-variant-icon-tertiary) ::slotted(a) {
958
+ color: var(--button-default);
959
+ min-width: 0;
960
+ gap: var(--ic-space-xs);
961
+ margin: var(--ic-space-1px) 0;
962
+ }
963
+
964
+ :host(.button-variant-icon-tertiary) .icon-container {
965
+ width: var(--ic-space-lg) !important;
966
+ height: var(--ic-space-lg) !important;
967
+ }
968
+
969
+ :host(.button-variant-icon-tertiary) .button:hover:not(:focus),
970
+ :host(.button-variant-icon-tertiary) .button:hover:focus,
971
+ :host(.button-variant-icon-tertiary) ::slotted(a:hover:not(:focus)),
972
+ :host(.button-variant-icon-tertiary) ::slotted(a:hover:focus) {
973
+ background-color: var(--button-default-background-hover);
974
+ color: var(--button-default-hover);
975
+ }
976
+
977
+ :host(.button-variant-icon-tertiary) .button:active:not(:focus),
978
+ :host(.button-variant-icon-tertiary) .button:active:focus,
979
+ :host(.button-variant-icon-tertiary) .button:active,
980
+ :host(.button-variant-icon-tertiary) ::slotted(a:active:not(:focus)),
981
+ :host(.button-variant-icon-tertiary) ::slotted(a:active:focus),
982
+ :host(.button-variant-icon-tertiary) ::slotted(a:active),
983
+ :host(.button-variant-icon-tertiary.loading) .button {
984
+ background-color: var(--button-default-background-active);
985
+ color: var(--button-default-active);
986
+ }
987
+
988
+ :host(.button-variant-icon-tertiary.disabled) .button,
989
+ :host(.button-variant-icon-tertiary.disabled) .button:hover,
990
+ :host(.button-variant-icon-tertiary.disabled) .button:active,
991
+ :host(.button-variant-icon-tertiary.disabled) ::slotted(a),
992
+ :host(.button-variant-icon-tertiary.disabled) ::slotted(a:hover),
993
+ :host(.button-variant-icon-tertiary.disabled) ::slotted(a:active) {
994
+ color: var(--ic-architectural-300);
995
+ background: none;
996
+ }
997
+
998
+ /* Icon-destructive */
999
+
1000
+ :host(.button-variant-icon-destructive) .button,
1001
+ :host(.button-variant-icon-destructive) ::slotted(a) {
770
1002
  color: var(--ic-architectural-white);
771
1003
  background-color: var(--ic-action-destructive);
772
- text-transform: uppercase;
1004
+ min-width: 0;
1005
+ gap: var(--ic-space-xs);
1006
+ margin: var(--ic-space-1px) 0;
773
1007
  }
774
1008
 
775
- :host(.button-variant-destructive) .button:hover:not(:focus),
776
- :host(.button-variant-destructive) .button:hover:focus {
1009
+ :host(.button-variant-icon-destructive) .icon-container {
1010
+ width: var(--ic-space-lg) !important;
1011
+ height: var(--ic-space-lg) !important;
1012
+ }
1013
+
1014
+ :host(.button-variant-icon-destructive) .button:hover:not(:focus),
1015
+ :host(.button-variant-icon-destructive) .button:hover:focus,
1016
+ :host(.button-variant-icon-destructive) ::slotted(a:hover:not(:focus)),
1017
+ :host(.button-variant-icon-destructive) ::slotted(a:hover:focus) {
777
1018
  background-color: var(--ic-action-destructive-hover);
778
1019
  }
779
1020
 
780
- :host(.button-variant-destructive) .button:active:not(:focus),
781
- :host(.button-variant-destructive) .button:active:focus,
782
- :host(.button-variant-destructive.loading) .button {
1021
+ :host(.button-variant-icon-destructive) .button:active:not(:focus),
1022
+ :host(.button-variant-icon-destructive) .button:active:focus,
1023
+ :host(.button-variant-icon-destructive) ::slotted(a:active:not(:focus)),
1024
+ :host(.button-variant-icon-destructive.loading) .button {
783
1025
  background-color: var(--ic-action-destructive-active);
784
1026
  }
785
1027
 
786
- :host(.button-variant-destructive.disabled) .button,
787
- :host(.button-variant-destructive.disabled) ::slotted(a) {
1028
+ :host(.button-variant-icon-destructive.loading) .button ic-loading-indicator {
1029
+ --inner-color: var(--ic-architectural-white);
1030
+ }
1031
+
1032
+ :host(.button-variant-icon-destructive.disabled) .button,
1033
+ :host(.button-variant-icon-destructive.disabled) .button:hover,
1034
+ :host(.button-variant-icon-destructive.disabled) .button:active,
1035
+ :host(.button-variant-icon-destructive.disabled) ::slotted(a),
1036
+ :host(.button-variant-icon-destructive.disabled) ::slotted(a:hover),
1037
+ :host(.button-variant-icon-destructive.disabled) ::slotted(a:active) {
788
1038
  background: var(--ic-architectural-200);
789
1039
  color: var(--ic-architectural-300);
790
1040
  }
@@ -807,6 +1057,14 @@ video {
807
1057
  }
808
1058
 
809
1059
  :host(.button-size-default.button-variant-icon) .button,
1060
+ :host(.button-size-default.button-variant-icon-primary) .button,
1061
+ :host(.button-size-default.button-variant-icon-secondary) .button,
1062
+ :host(.button-size-default.button-variant-icon-tertiary) .button,
1063
+ :host(.button-size-default.button-variant-icon-destructive) .button,
1064
+ :host(.button-size-default.button-variant-icon-primary) ::slotted(a),
1065
+ :host(.button-size-default.button-variant-icon-secondary) ::slotted(a),
1066
+ :host(.button-size-default.button-variant-icon-tertiary) ::slotted(a),
1067
+ :host(.button-size-default.button-variant-icon-destructive) ::slotted(a),
810
1068
  :host(.button-size-default.button-variant-icon) ::slotted(a) {
811
1069
  height: var(--height, var(--ic-space-xl));
812
1070
  width: var(--ic-space-xl);
@@ -814,6 +1072,14 @@ video {
814
1072
  }
815
1073
 
816
1074
  :host(.button-size-small.button-variant-icon) .button,
1075
+ :host(.button-size-small.button-variant-icon-primary) .button,
1076
+ :host(.button-size-small.button-variant-icon-secondary) .button,
1077
+ :host(.button-size-small.button-variant-icon-tertiary) .button,
1078
+ :host(.button-size-small.button-variant-icon-destructive) .button,
1079
+ :host(.button-size-small.button-variant-icon-primary) ::slotted(a),
1080
+ :host(.button-size-small.button-variant-icon-secondary) ::slotted(a),
1081
+ :host(.button-size-small.button-variant-icon-tertiary) ::slotted(a),
1082
+ :host(.button-size-small.button-variant-icon-destructive) ::slotted(a),
817
1083
  :host(.button-size-small.button-variant-icon) ::slotted(a) {
818
1084
  height: var(--height, var(--ic-space-lg));
819
1085
  width: var(--ic-space-lg);
@@ -821,6 +1087,14 @@ video {
821
1087
  }
822
1088
 
823
1089
  :host(.button-size-large.button-variant-icon) .button,
1090
+ :host(.button-size-large.button-variant-icon-primary) .button,
1091
+ :host(.button-size-large.button-variant-icon-secondary) .button,
1092
+ :host(.button-size-large.button-variant-icon-tertiary) .button,
1093
+ :host(.button-size-large.button-variant-icon-destructive) .button,
1094
+ :host(.button-size-large.button-variant-icon-primary) ::slotted(a),
1095
+ :host(.button-size-large.button-variant-icon-secondary) ::slotted(a),
1096
+ :host(.button-size-large.button-variant-icon-tertiary) ::slotted(a),
1097
+ :host(.button-size-large.button-variant-icon-destructive) ::slotted(a),
824
1098
  :host(.button-size-large.button-variant-icon) ::slotted(a) {
825
1099
  height: var(--height, 2.5rem);
826
1100
  width: 2.5rem;
@@ -893,6 +1167,10 @@ div.right-icon {
893
1167
  margin-left: var(--ic-space-xs);
894
1168
  }
895
1169
 
1170
+ :host(.full-width) .right-icon {
1171
+ margin-right: var(--ic-space-xs);
1172
+ }
1173
+
896
1174
  ::slotted(:not(ic-badge)) {
897
1175
  width: var(--icon-width) !important;
898
1176
  height: var(--icon-height) !important;
@@ -29,7 +29,7 @@ export class Button {
29
29
  this.buttonIdNum = buttonIds++;
30
30
  this.hasTooltip = false;
31
31
  this.inheritedAttributes = {};
32
- this.describedByEl = null;
32
+ this.describedbyEl = null;
33
33
  this.describedById = null;
34
34
  this.mutationObserver = null;
35
35
  this.hostMutationObserver = null;
@@ -53,7 +53,7 @@ export class Button {
53
53
  };
54
54
  // triggered when text content of sibling element in light DOM changes
55
55
  this.mutationCallback = () => {
56
- this.describedByContent = this.describedByEl.innerText;
56
+ this.describedByContent = this.describedbyEl.innerText;
57
57
  };
58
58
  // triggered when attributes of host element change
59
59
  this.hostMutationCallback = (mutationList) => {
@@ -146,7 +146,7 @@ export class Button {
146
146
  const el = this.el.parentElement.querySelector(`#${describedById}`);
147
147
  if (el) {
148
148
  this.describedByContent = el.innerText;
149
- this.describedByEl = el;
149
+ this.describedbyEl = el;
150
150
  }
151
151
  }
152
152
  }
@@ -156,7 +156,7 @@ export class Button {
156
156
  if (typeof MutationObserver !== "undefined") {
157
157
  if (this.describedById) {
158
158
  this.mutationObserver = new MutationObserver(this.mutationCallback);
159
- this.mutationObserver.observe(this.describedByEl, {
159
+ this.mutationObserver.observe(this.describedbyEl, {
160
160
  characterData: true,
161
161
  childList: true,
162
162
  subtree: true,
@@ -238,23 +238,23 @@ export class Button {
238
238
  referrerpolicy: this.referrerpolicy,
239
239
  hreflang: this.hreflang,
240
240
  };
241
- let describedBy = null;
241
+ let describedby = null;
242
242
  let buttonId = null;
243
243
  if (this.hasTooltip) {
244
244
  buttonId =
245
245
  this.id !== null
246
246
  ? `ic-button-with-tooltip-${this.id}`
247
247
  : `ic-button-with-tooltip-${this.buttonIdNum}`;
248
- describedBy =
248
+ describedby =
249
249
  this.variant === "icon" && !!ariaLabel
250
250
  ? null
251
251
  : `ic-tooltip-${buttonId}`;
252
252
  }
253
253
  else {
254
- describedBy = this.describedById;
254
+ describedby = this.describedById;
255
255
  }
256
256
  const ButtonContent = () => {
257
- return (h(TagType, Object.assign({ class: "button", "aria-disabled": this.loading || this.disabled ? "true" : null, "aria-label": this.loading ? "Loading" : ariaLabel, "aria-expanded": this.dropdown && `${this.dropdownExpanded}` }, buttonAttrs, inheritedAttributes, { onFocus: this.onFocus, onBlur: this.onBlur, ref: (el) => (this.buttonEl = el), "aria-describedby": describedBy, part: "button" }), this.hasIconSlot() && !this.loading && (h("div", { class: "icon-container" }, h("slot", { name: "icon" }))), this.hasIconSlot("left") && !this.loading && (h("div", { class: "icon-container" }, h("slot", { name: "left-icon" }))), this.hasIconSlot("top") &&
257
+ return (h(TagType, Object.assign({ class: "button", "aria-disabled": this.loading || this.disabled ? "true" : null, "aria-label": this.loading ? "Loading" : ariaLabel, "aria-expanded": this.dropdown && `${this.dropdownExpanded}` }, buttonAttrs, inheritedAttributes, { onFocus: this.onFocus, onBlur: this.onBlur, ref: (el) => (this.buttonEl = el), "aria-describedby": describedby, part: "button" }), this.hasIconSlot() && !this.loading && (h("div", { class: "icon-container" }, h("slot", { name: "icon" }))), this.hasIconSlot("left") && !this.loading && (h("div", { class: "icon-container" }, h("slot", { name: "left-icon" }))), this.hasIconSlot("top") &&
258
258
  !this.hasIconSlot("left") &&
259
259
  !this.hasIconSlot("right") &&
260
260
  !this.loading && (h("div", { class: "icon-container" }, h("slot", { name: "top-icon" }))), this.loading ? (h("div", { class: "loading-container" }, h("ic-loading-indicator", { type: "linear", appearance: this.variant === "primary" ||
@@ -286,8 +286,8 @@ export class Button {
286
286
  ["white-background"]: this.variant === "secondary" &&
287
287
  !this.transparentBackground &&
288
288
  this.appearance !== "light",
289
- }, onClick: this.handleClick, "aria-owns": this.ariaOwnsId, "aria-controls": this.ariaControlsId, "aria-expanded": this.dropdown && `${this.dropdownExpanded}` }, this.hasTooltip && (h("ic-tooltip", { id: describedBy, label: title || ariaLabel, target: buttonId, placement: this.tooltipPlacement, silent: this.variant === "icon" && (!!title || !!ariaLabel) }, this.hasRouterSlot() ? (h("slot", { name: "router-item" })) : (h(ButtonContent, null)))), isSlotUsed(this.el, "badge") && h("slot", { name: "badge" }), !this.hasTooltip &&
290
- (this.hasRouterSlot() ? (h("slot", { name: "router-item" })) : (h(ButtonContent, null))), this.describedByContent && (h("span", { id: describedBy, class: "ic-button-describedby" }, this.describedByContent))));
289
+ }, onClick: this.handleClick, "aria-owns": this.ariaOwnsId, "aria-controls": this.ariaControlsId, "aria-expanded": this.dropdown && `${this.dropdownExpanded}` }, this.hasTooltip && (h("ic-tooltip", { id: describedby, label: title || ariaLabel, target: buttonId, placement: this.tooltipPlacement, silent: this.variant === "icon" && !!ariaLabel }, this.hasRouterSlot() ? (h("slot", { name: "router-item" })) : (h(ButtonContent, null)))), isSlotUsed(this.el, "badge") && h("slot", { name: "badge" }), !this.hasTooltip &&
290
+ (this.hasRouterSlot() ? (h("slot", { name: "router-item" })) : (h(ButtonContent, null))), this.describedByContent && (h("span", { id: describedby, class: "ic-button-describedby" }, this.describedByContent))));
291
291
  }
292
292
  static get is() { return "ic-button"; }
293
293
  static get encapsulation() { return "shadow"; }
@@ -873,7 +873,7 @@ export class Button {
873
873
  "mutable": false,
874
874
  "complexType": {
875
875
  "original": "IcButtonVariants",
876
- "resolved": "\"destructive\" | \"icon\" | \"primary\" | \"secondary\" | \"tertiary\"",
876
+ "resolved": "\"destructive\" | \"icon\" | \"icon-destructive\" | \"icon-primary\" | \"icon-secondary\" | \"icon-tertiary\" | \"primary\" | \"secondary\" | \"tertiary\"",
877
877
  "references": {
878
878
  "IcButtonVariants": {
879
879
  "location": "import",
@@ -1 +1 @@
1
- {"version":3,"file":"ic-button.js","sourceRoot":"","sources":["../../../src/components/ic-button/ic-button.tsx"],"names":[],"mappings":"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CACnB,CACR,CACI,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import {\n Component,\n Element,\n Event,\n EventEmitter,\n Host,\n Listen,\n Method,\n Prop,\n State,\n forceUpdate,\n h,\n Watch,\n} from \"@stencil/core\";\n\nimport {\n getThemeFromContext,\n inheritAttributes,\n isSlotUsed,\n removeDisabledFalse,\n renderFileHiddenInput,\n} from \"../../utils/helpers\";\nimport { IC_INHERITED_ARIA } from \"../../utils/constants\";\nimport {\n IcButtonTypes,\n IcButtonVariants,\n IcButtonTooltipPlacement,\n} from \"./ic-button.types\";\nimport {\n IcSizes,\n IcTheme,\n IcThemeForeground,\n IcThemeForegroundEnum,\n} from \"../../utils/types\";\nimport arrowDropdown from \"../../assets/arrow-dropdown.svg\";\n\nlet buttonIds = 0;\n\n/**\n * @slot icon - Deprecated. This slot should not be used anymore. Use left-icon or right-icon slot instead.\n * @slot left-icon - Content will be placed to the left of the button label.\n * @slot right-icon - Content will be placed to the right of the button label.\n * @slot top-icon - Content will be placed above the button label.\n * @slot badge - Badge component overlaying the top right of the button.\n * @slot router-item - Handle routing by nesting your routes in this slot. Setting loading to true will have no impact on this slot.\n */\n@Component({\n tag: \"ic-button\",\n styleUrl: \"ic-button.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class Button {\n private buttonEl: HTMLElement;\n private buttonIdNum = buttonIds++;\n private hasTooltip: boolean = false;\n private id: string;\n private inheritedAttributes: { [k: string]: string } = {};\n private describedByEl: HTMLElement = null;\n private describedById: string = null;\n private mutationObserver: MutationObserver = null;\n private hostMutationObserver: MutationObserver = null;\n private routerSlot: HTMLElement;\n\n @Element() el: HTMLIcButtonElement;\n\n @State() ariaLabel: string = null;\n @State() describedByContent: string = null;\n @State() title: string = null;\n\n /**\n * If `fileUpload` is set to `true`, this is the accepted list of file types.\n */\n @Prop() accept?: string = \"*\";\n\n /**\n * The appearance of the button, e.g. dark, light, or the default.\n */\n @Prop({ mutable: true }) appearance?: IcThemeForeground = \"default\";\n\n /**\n * @internal Used to identify any related child component\n */\n @Prop() ariaControlsId: string | boolean;\n\n /**\n * @internal Used to identify any related child component\n */\n @Prop() ariaOwnsId: string | boolean;\n\n /**\n * If `true`, the button will be in disabled state.\n */\n @Prop() disabled?: boolean = false;\n @Watch(\"disabled\")\n watchDisabledHandler(): void {\n removeDisabledFalse(this.disabled, this.el);\n }\n\n /**\n * If `true`, the ic-tooltip which is shown for icon variant will be disabled. Title or aria-label must be set if this prop is not applied.\n */\n @Prop() disableTooltip?: boolean = false;\n\n /**\n * If `true`, the user can save the linked URL instead of navigating to it.\n */\n @Prop() download?: string | boolean = false;\n\n /**\n * If `true`, the button will show a dropdown icon.\n */\n @Prop() dropdown?: boolean = false;\n\n /**\n * If `true`, the aria-expanded value will be set to true. This is only applied if the dropdown prop is also true.\n */\n @Prop({ mutable: true, reflect: true }) dropdownExpanded?: boolean = false;\n\n /**\n * If `true`, when the button is clicked the native file explorer will be launched.\n */\n @Prop() fileUpload?: boolean = false;\n\n /**\n * The name of the control for the file input, which is submitted with the form data.\n */\n @Prop() fileInputName: string = `ic-button-file-upload-input-${buttonIds++}`;\n\n /**\n * The <form> element to associate the button with.\n */\n @Prop() form?: string;\n\n /**\n * The URL that processes the information submitted by the button. It overrides the action attribute of the button's form owner. Does nothing if there is no form owner.\n */\n @Prop() formaction?: string;\n\n /**\n * The way the submitted form data is encoded.\n */\n @Prop() formenctype?: string;\n\n /**\n * The HTTP method used to submit the form.\n */\n @Prop() formmethod?: string;\n\n /**\n * If `true`, the form will not be validated when submitted.\n */\n @Prop() formnovalidate?: boolean;\n\n /**\n * The place to display the response from submitting the form. It overrides the target attribute of the button's form owner.\n */\n @Prop() formtarget?: string;\n\n /**\n * If `true`, the button will fill the width of the container.\n */\n @Prop() fullWidth?: boolean = false;\n\n /**\n * The URL that the link points to. This will render the button as an \"a\" tag.\n */\n @Prop() href?: string;\n\n /**\n * The human language of the linked URL.\n */\n @Prop() hreflang?: string;\n\n /**\n * If `true`, the button will be in loading state.\n */\n @Prop() loading?: boolean = false;\n\n /**\n * If `fileUpload` is set to `true`, this boolean determines whether multiple files are accepted.\n */\n @Prop() multiple?: boolean = false;\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 list of the files that have been selected by a user.\n */\n @Prop() selectedFiles: FileList;\n\n /**\n * The size of the button to be displayed.\n */\n @Prop() size?: IcSizes = \"default\";\n\n /**\n * The place to display the linked URL, as the name for a browsing context (a tab, window, or iframe).\n */\n @Prop() target?: string;\n\n /**\n * The position of the tooltip in relation to the button.\n */\n @Prop() tooltipPlacement?: IcButtonTooltipPlacement = \"bottom\";\n\n /**\n * If `true`, the secondary variant of button will have a transparent background rather than white.\n */\n @Prop() transparentBackground?: boolean = true;\n\n /**\n * The type of the button.\n */\n @Prop() type?: IcButtonTypes = \"button\";\n\n /**\n * The variant of the button to be displayed.\n */\n @Prop() variant?: IcButtonVariants = \"primary\";\n\n /**\n * Emitted when button has blur\n */\n @Event() icBlur!: EventEmitter<void>;\n\n /**\n * If `fileUpload` is set to `true`, this will be emitted when a file is selected in the native explorer.\n */\n @Event() icFileSelection!: EventEmitter<FileList>;\n\n /**\n * Emitted when button has focus\n */\n @Event() icFocus!: EventEmitter<void>;\n\n disconnectedCallback(): void {\n if (this.mutationObserver !== null && this.mutationObserver !== undefined) {\n this.mutationObserver.disconnect();\n }\n if (\n this.hostMutationObserver !== null &&\n this.hostMutationObserver !== undefined\n ) {\n this.hostMutationObserver.disconnect();\n }\n }\n\n componentWillUpdate(): void {\n if (this.loading) {\n this.el.style.setProperty(\n \"--min-width\",\n `${this.el.getBoundingClientRect().width}px`\n );\n }\n this.setHasTooltip();\n }\n\n componentWillLoad(): void {\n const {\n title,\n \"aria-label\": ariaLabel,\n ...restInheritedAttributes\n } = inheritAttributes(this.el, [...IC_INHERITED_ARIA, \"title\"]);\n\n this.title = title;\n this.ariaLabel = ariaLabel;\n this.inheritedAttributes = restInheritedAttributes;\n\n removeDisabledFalse(this.disabled, this.el);\n\n this.el.setAttribute(\"exportparts\", \"button\");\n\n this.id = this.el.id || null;\n this.setHasTooltip();\n\n if (!this.hasTooltip) {\n const describedById = this.inheritedAttributes[\"aria-describedby\"];\n if (describedById !== undefined) {\n this.describedById = describedById;\n const el = this.el.parentElement.querySelector<HTMLElement>(\n `#${describedById}`\n );\n if (el) {\n this.describedByContent = el.innerText;\n this.describedByEl = el;\n }\n }\n }\n }\n\n componentDidLoad(): void {\n this.updateTheme();\n\n if (typeof MutationObserver !== \"undefined\") {\n if (this.describedById) {\n this.mutationObserver = new MutationObserver(this.mutationCallback);\n this.mutationObserver.observe(this.describedByEl, {\n characterData: true,\n childList: true,\n subtree: true,\n });\n }\n\n this.hostMutationObserver = new MutationObserver(\n this.hostMutationCallback\n );\n this.hostMutationObserver.observe(this.el, {\n attributes: true,\n });\n }\n }\n\n componentWillRender(): void {\n const iconEl = this.hasIconSlot(\"left\")\n ? this.el.querySelector(`[slot=\"left-icon\"]`)\n : this.hasIconSlot(\"right\")\n ? this.el.querySelector(`[slot=\"right-icon\"]`)\n : null;\n iconEl?.setAttribute(\"viewBox\", \"0 0 24 24\");\n }\n\n @Listen(\"click\", { capture: true })\n handleHostClick(event: Event): void {\n if (!this.hasRouterSlot()) {\n if (this.fileUpload) {\n renderFileHiddenInput(\n this.icFileSelection,\n this.el,\n this.multiple,\n this.fileInputName,\n this.selectedFiles,\n this.disabled,\n this.accept\n );\n }\n if (this.disabled || this.loading) {\n event.stopImmediatePropagation();\n }\n if (this.dropdown) {\n this.dropdownExpanded = !this.dropdownExpanded;\n }\n }\n }\n\n @Listen(\"themeChange\", { target: \"document\" })\n themeChangeHandler({ detail }: CustomEvent<IcTheme>): void {\n this.updateTheme(detail.mode);\n }\n\n /**\n * Sets focus on the native `button`.\n */\n @Method()\n async setFocus(): Promise<void> {\n this.buttonEl?.focus();\n }\n\n private hasIconSlot(position?: \"left\" | \"right\" | \"top\"): boolean {\n const selectorPrefix = position ? `${position}-` : \"\";\n return this.el.querySelector(`[slot=\"${selectorPrefix}icon\"]`) !== null;\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 private handleClick = (): void => {\n if (\n (this.el.type === \"submit\" || this.el.type === \"reset\") &&\n !this.hasRouterSlot() &&\n !!this.el.closest(\"FORM\")\n ) {\n const hiddenFormButton = document.createElement(\"button\");\n\n hiddenFormButton.setAttribute(\"type\", this.el.type);\n hiddenFormButton.style.display = \"none\";\n\n this.el.closest(\"FORM\").appendChild(hiddenFormButton);\n\n hiddenFormButton.click();\n hiddenFormButton.remove();\n }\n };\n\n private onFocus = () => {\n this.icFocus.emit();\n };\n\n private onBlur = () => {\n this.icBlur.emit();\n };\n\n private updateTheme(newTheme: IcThemeForeground = null): void {\n const foregroundColor = getThemeFromContext(this.el, newTheme);\n\n if (foregroundColor !== IcThemeForegroundEnum.Default) {\n this.appearance = foregroundColor;\n }\n }\n\n // triggered when text content of sibling element in light DOM changes\n private mutationCallback = (): void => {\n this.describedByContent = this.describedByEl.innerText;\n };\n\n // triggered when attributes of host element change\n private hostMutationCallback = (mutationList: MutationRecord[]): void => {\n let forceComponentUpdate = false;\n mutationList.forEach(({ attributeName }) => {\n const attribute = this.el.getAttribute(attributeName);\n if (attributeName === \"title\") this.title = attribute;\n else if (attributeName === \"aria-label\") this.ariaLabel = attribute;\n\n if (IC_INHERITED_ARIA.includes(attributeName)) {\n this.inheritedAttributes[attributeName] = attribute;\n forceComponentUpdate = true;\n }\n });\n if (forceComponentUpdate) {\n forceUpdate(this);\n }\n };\n\n private setHasTooltip = (): void => {\n this.hasTooltip =\n !this.disableTooltip && (!!this.title || this.variant === \"icon\");\n };\n\n render() {\n const TagType = (this.href && \"a\") || \"button\";\n const { title, ariaLabel, inheritedAttributes } = this;\n const buttonAttrs =\n TagType === \"button\"\n ? {\n type: this.type,\n disabled: this.disabled,\n form: this.form,\n formaction: this.formaction,\n formenctype: this.formenctype,\n formmethod: this.formmethod,\n formnovalidate: this.formnovalidate,\n formtarget: this.formtarget,\n }\n : {\n download: this.download !== false ? this.download : null,\n href: this.href,\n rel: this.rel,\n target: this.target,\n referrerpolicy: this.referrerpolicy,\n hreflang: this.hreflang,\n };\n\n let describedBy: string = null;\n let buttonId: string = null;\n if (this.hasTooltip) {\n buttonId =\n this.id !== null\n ? `ic-button-with-tooltip-${this.id}`\n : `ic-button-with-tooltip-${this.buttonIdNum}`;\n describedBy =\n this.variant === \"icon\" && !!ariaLabel\n ? null\n : `ic-tooltip-${buttonId}`;\n } else {\n describedBy = this.describedById;\n }\n\n const ButtonContent = () => {\n return (\n <TagType\n class=\"button\"\n aria-disabled={this.loading || this.disabled ? \"true\" : null}\n aria-label={this.loading ? \"Loading\" : ariaLabel}\n aria-expanded={this.dropdown && `${this.dropdownExpanded}`}\n {...buttonAttrs}\n {...inheritedAttributes}\n onFocus={this.onFocus}\n onBlur={this.onBlur}\n ref={(el) => (this.buttonEl = el)}\n aria-describedby={describedBy}\n part=\"button\"\n >\n {this.hasIconSlot() && !this.loading && (\n <div class=\"icon-container\">\n <slot name=\"icon\" />\n </div>\n )}\n {this.hasIconSlot(\"left\") && !this.loading && (\n <div class=\"icon-container\">\n <slot name=\"left-icon\" />\n </div>\n )}\n {this.hasIconSlot(\"top\") &&\n !this.hasIconSlot(\"left\") &&\n !this.hasIconSlot(\"right\") &&\n !this.loading && (\n <div class=\"icon-container\">\n <slot name=\"top-icon\" />\n </div>\n )}\n {this.loading ? (\n <div class=\"loading-container\">\n <ic-loading-indicator\n type=\"linear\"\n appearance={\n this.variant === \"primary\" ||\n this.variant === \"destructive\" ||\n this.appearance === IcThemeForegroundEnum.Dark ||\n this.appearance === IcThemeForegroundEnum.Light\n ? \"light\"\n : \"dark\"\n }\n ></ic-loading-indicator>\n </div>\n ) : (\n <slot />\n )}\n {this.hasIconSlot(\"right\") && !this.loading && !this.dropdown && (\n <div class={{ \"icon-container\": true, \"right-icon\": true }}>\n <slot name=\"right-icon\" />\n </div>\n )}\n {this.dropdown &&\n !this.loading &&\n this.variant !== \"icon\" &&\n this.variant !== \"destructive\" && (\n <span\n class={{\n [\"arrow-dropdown\"]: !this.dropdownExpanded,\n [\"dropdown-expanded\"]: this.dropdownExpanded,\n }}\n innerHTML={arrowDropdown}\n />\n )}\n </TagType>\n );\n };\n\n return (\n <Host\n class={{\n [\"disabled\"]: this.disabled && !this.loading,\n [`button-variant-${this.variant}`]: true,\n [`button-size-${this.size}`]: true,\n [\"loading\"]: this.loading,\n [\"dark\"]: this.appearance === IcThemeForegroundEnum.Dark,\n [\"light\"]: this.appearance === IcThemeForegroundEnum.Light,\n [\"full-width\"]: this.fullWidth,\n [\"with-badge\"]: isSlotUsed(this.el, \"badge\"),\n [\"dropdown-no-icon\"]:\n this.dropdown &&\n !isSlotUsed(this.el, \"icon\") &&\n !isSlotUsed(this.el, \"left-icon\"),\n [\"top-icon\"]: isSlotUsed(this.el, \"top-icon\"),\n [\"white-background\"]:\n this.variant === \"secondary\" &&\n !this.transparentBackground &&\n this.appearance !== \"light\",\n }}\n onClick={this.handleClick}\n aria-owns={this.ariaOwnsId}\n aria-controls={this.ariaControlsId}\n aria-expanded={this.dropdown && `${this.dropdownExpanded}`}\n >\n {this.hasTooltip && (\n <ic-tooltip\n id={describedBy}\n label={title || ariaLabel}\n target={buttonId}\n placement={this.tooltipPlacement}\n silent={this.variant === \"icon\" && (!!title || !!ariaLabel)}\n >\n {this.hasRouterSlot() ? (\n <slot name=\"router-item\"></slot>\n ) : (\n <ButtonContent />\n )}\n </ic-tooltip>\n )}\n {isSlotUsed(this.el, \"badge\") && <slot name=\"badge\"></slot>}\n {!this.hasTooltip &&\n (this.hasRouterSlot() ? (\n <slot name=\"router-item\"></slot>\n ) : (\n <ButtonContent />\n ))}\n {this.describedByContent && (\n <span id={describedBy} class=\"ic-button-describedby\">\n {this.describedByContent}\n </span>\n )}\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"ic-button.js","sourceRoot":"","sources":["../../../src/components/ic-button/ic-button.tsx"],"names":[],"mappings":"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,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import {\n Component,\n Element,\n Event,\n EventEmitter,\n Host,\n Listen,\n Method,\n Prop,\n State,\n forceUpdate,\n h,\n Watch,\n} from \"@stencil/core\";\n\nimport {\n getThemeFromContext,\n inheritAttributes,\n isSlotUsed,\n removeDisabledFalse,\n renderFileHiddenInput,\n} from \"../../utils/helpers\";\nimport { IC_INHERITED_ARIA } from \"../../utils/constants\";\nimport {\n IcButtonTypes,\n IcButtonVariants,\n IcButtonTooltipPlacement,\n} from \"./ic-button.types\";\nimport {\n IcSizes,\n IcTheme,\n IcThemeForeground,\n IcThemeForegroundEnum,\n} from \"../../utils/types\";\nimport arrowDropdown from \"../../assets/arrow-dropdown.svg\";\n\nlet buttonIds = 0;\n\n/**\n * @slot icon - Deprecated. This slot should not be used anymore. Use left-icon or right-icon slot instead.\n * @slot left-icon - Content will be placed to the left of the button label.\n * @slot right-icon - Content will be placed to the right of the button label.\n * @slot top-icon - Content will be placed above the button label.\n * @slot badge - Badge component overlaying the top right of the button.\n * @slot router-item - Handle routing by nesting your routes in this slot. Setting loading to true will have no impact on this slot.\n */\n@Component({\n tag: \"ic-button\",\n styleUrl: \"ic-button.css\",\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class Button {\n private buttonEl: HTMLElement;\n private buttonIdNum = buttonIds++;\n private hasTooltip: boolean = false;\n private id: string;\n private inheritedAttributes: { [k: string]: string } = {};\n private describedbyEl: HTMLElement = null;\n private describedById: string = null;\n private mutationObserver: MutationObserver = null;\n private hostMutationObserver: MutationObserver = null;\n private routerSlot: HTMLElement;\n\n @Element() el: HTMLIcButtonElement;\n\n @State() ariaLabel: string = null;\n @State() describedByContent: string = null;\n @State() title: string = null;\n\n /**\n * If `fileUpload` is set to `true`, this is the accepted list of file types.\n */\n @Prop() accept?: string = \"*\";\n\n /**\n * The appearance of the button, e.g. dark, light, or the default.\n */\n @Prop({ mutable: true }) appearance?: IcThemeForeground = \"default\";\n\n /**\n * @internal Used to identify any related child component\n */\n @Prop() ariaControlsId: string | boolean;\n\n /**\n * @internal Used to identify any related child component\n */\n @Prop() ariaOwnsId: string | boolean;\n\n /**\n * If `true`, the button will be in disabled state.\n */\n @Prop() disabled?: boolean = false;\n @Watch(\"disabled\")\n watchDisabledHandler(): void {\n removeDisabledFalse(this.disabled, this.el);\n }\n\n /**\n * If `true`, the ic-tooltip which is shown for icon variant will be disabled. Title or aria-label must be set if this prop is not applied.\n */\n @Prop() disableTooltip?: boolean = false;\n\n /**\n * If `true`, the user can save the linked URL instead of navigating to it.\n */\n @Prop() download?: string | boolean = false;\n\n /**\n * If `true`, the button will show a dropdown icon.\n */\n @Prop() dropdown?: boolean = false;\n\n /**\n * If `true`, the aria-expanded value will be set to true. This is only applied if the dropdown prop is also true.\n */\n @Prop({ mutable: true, reflect: true }) dropdownExpanded?: boolean = false;\n\n /**\n * If `true`, when the button is clicked the native file explorer will be launched.\n */\n @Prop() fileUpload?: boolean = false;\n\n /**\n * The name of the control for the file input, which is submitted with the form data.\n */\n @Prop() fileInputName: string = `ic-button-file-upload-input-${buttonIds++}`;\n\n /**\n * The <form> element to associate the button with.\n */\n @Prop() form?: string;\n\n /**\n * The URL that processes the information submitted by the button. It overrides the action attribute of the button's form owner. Does nothing if there is no form owner.\n */\n @Prop() formaction?: string;\n\n /**\n * The way the submitted form data is encoded.\n */\n @Prop() formenctype?: string;\n\n /**\n * The HTTP method used to submit the form.\n */\n @Prop() formmethod?: string;\n\n /**\n * If `true`, the form will not be validated when submitted.\n */\n @Prop() formnovalidate?: boolean;\n\n /**\n * The place to display the response from submitting the form. It overrides the target attribute of the button's form owner.\n */\n @Prop() formtarget?: string;\n\n /**\n * If `true`, the button will fill the width of the container.\n */\n @Prop() fullWidth?: boolean = false;\n\n /**\n * The URL that the link points to. This will render the button as an \"a\" tag.\n */\n @Prop() href?: string;\n\n /**\n * The human language of the linked URL.\n */\n @Prop() hreflang?: string;\n\n /**\n * If `true`, the button will be in loading state.\n */\n @Prop() loading?: boolean = false;\n\n /**\n * If `fileUpload` is set to `true`, this boolean determines whether multiple files are accepted.\n */\n @Prop() multiple?: boolean = false;\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 list of the files that have been selected by a user.\n */\n @Prop() selectedFiles: FileList;\n\n /**\n * The size of the button to be displayed.\n */\n @Prop() size?: IcSizes = \"default\";\n\n /**\n * The place to display the linked URL, as the name for a browsing context (a tab, window, or iframe).\n */\n @Prop() target?: string;\n\n /**\n * The position of the tooltip in relation to the button.\n */\n @Prop() tooltipPlacement?: IcButtonTooltipPlacement = \"bottom\";\n\n /**\n * If `true`, the secondary variant of button will have a transparent background rather than white.\n */\n @Prop() transparentBackground?: boolean = true;\n\n /**\n * The type of the button.\n */\n @Prop() type?: IcButtonTypes = \"button\";\n\n /**\n * The variant of the button to be displayed.\n */\n @Prop() variant?: IcButtonVariants = \"primary\";\n\n /**\n * Emitted when button has blur\n */\n @Event() icBlur!: EventEmitter<void>;\n\n /**\n * If `fileUpload` is set to `true`, this will be emitted when a file is selected in the native explorer.\n */\n @Event() icFileSelection!: EventEmitter<FileList>;\n\n /**\n * Emitted when button has focus\n */\n @Event() icFocus!: EventEmitter<void>;\n\n disconnectedCallback(): void {\n if (this.mutationObserver !== null && this.mutationObserver !== undefined) {\n this.mutationObserver.disconnect();\n }\n if (\n this.hostMutationObserver !== null &&\n this.hostMutationObserver !== undefined\n ) {\n this.hostMutationObserver.disconnect();\n }\n }\n\n componentWillUpdate(): void {\n if (this.loading) {\n this.el.style.setProperty(\n \"--min-width\",\n `${this.el.getBoundingClientRect().width}px`\n );\n }\n this.setHasTooltip();\n }\n\n componentWillLoad(): void {\n const {\n title,\n \"aria-label\": ariaLabel,\n ...restInheritedAttributes\n } = inheritAttributes(this.el, [...IC_INHERITED_ARIA, \"title\"]);\n\n this.title = title;\n this.ariaLabel = ariaLabel;\n this.inheritedAttributes = restInheritedAttributes;\n\n removeDisabledFalse(this.disabled, this.el);\n\n this.el.setAttribute(\"exportparts\", \"button\");\n\n this.id = this.el.id || null;\n this.setHasTooltip();\n\n if (!this.hasTooltip) {\n const describedById = this.inheritedAttributes[\"aria-describedby\"];\n if (describedById !== undefined) {\n this.describedById = describedById;\n const el = this.el.parentElement.querySelector<HTMLElement>(\n `#${describedById}`\n );\n if (el) {\n this.describedByContent = el.innerText;\n this.describedbyEl = el;\n }\n }\n }\n }\n\n componentDidLoad(): void {\n this.updateTheme();\n\n if (typeof MutationObserver !== \"undefined\") {\n if (this.describedById) {\n this.mutationObserver = new MutationObserver(this.mutationCallback);\n this.mutationObserver.observe(this.describedbyEl, {\n characterData: true,\n childList: true,\n subtree: true,\n });\n }\n\n this.hostMutationObserver = new MutationObserver(\n this.hostMutationCallback\n );\n this.hostMutationObserver.observe(this.el, {\n attributes: true,\n });\n }\n }\n\n componentWillRender(): void {\n const iconEl = this.hasIconSlot(\"left\")\n ? this.el.querySelector(`[slot=\"left-icon\"]`)\n : this.hasIconSlot(\"right\")\n ? this.el.querySelector(`[slot=\"right-icon\"]`)\n : null;\n iconEl?.setAttribute(\"viewBox\", \"0 0 24 24\");\n }\n\n @Listen(\"click\", { capture: true })\n handleHostClick(event: Event): void {\n if (!this.hasRouterSlot()) {\n if (this.fileUpload) {\n renderFileHiddenInput(\n this.icFileSelection,\n this.el,\n this.multiple,\n this.fileInputName,\n this.selectedFiles,\n this.disabled,\n this.accept\n );\n }\n if (this.disabled || this.loading) {\n event.stopImmediatePropagation();\n }\n if (this.dropdown) {\n this.dropdownExpanded = !this.dropdownExpanded;\n }\n }\n }\n\n @Listen(\"themeChange\", { target: \"document\" })\n themeChangeHandler({ detail }: CustomEvent<IcTheme>): void {\n this.updateTheme(detail.mode);\n }\n\n /**\n * Sets focus on the native `button`.\n */\n @Method()\n async setFocus(): Promise<void> {\n this.buttonEl?.focus();\n }\n\n private hasIconSlot(position?: \"left\" | \"right\" | \"top\"): boolean {\n const selectorPrefix = position ? `${position}-` : \"\";\n return this.el.querySelector(`[slot=\"${selectorPrefix}icon\"]`) !== null;\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 private handleClick = (): void => {\n if (\n (this.el.type === \"submit\" || this.el.type === \"reset\") &&\n !this.hasRouterSlot() &&\n !!this.el.closest(\"FORM\")\n ) {\n const hiddenFormButton = document.createElement(\"button\");\n\n hiddenFormButton.setAttribute(\"type\", this.el.type);\n hiddenFormButton.style.display = \"none\";\n\n this.el.closest(\"FORM\").appendChild(hiddenFormButton);\n\n hiddenFormButton.click();\n hiddenFormButton.remove();\n }\n };\n\n private onFocus = () => {\n this.icFocus.emit();\n };\n\n private onBlur = () => {\n this.icBlur.emit();\n };\n\n private updateTheme(newTheme: IcThemeForeground = null): void {\n const foregroundColor = getThemeFromContext(this.el, newTheme);\n\n if (foregroundColor !== IcThemeForegroundEnum.Default) {\n this.appearance = foregroundColor;\n }\n }\n\n // triggered when text content of sibling element in light DOM changes\n private mutationCallback = (): void => {\n this.describedByContent = this.describedbyEl.innerText;\n };\n\n // triggered when attributes of host element change\n private hostMutationCallback = (mutationList: MutationRecord[]): void => {\n let forceComponentUpdate = false;\n mutationList.forEach(({ attributeName }) => {\n const attribute = this.el.getAttribute(attributeName);\n if (attributeName === \"title\") this.title = attribute;\n else if (attributeName === \"aria-label\") this.ariaLabel = attribute;\n\n if (IC_INHERITED_ARIA.includes(attributeName)) {\n this.inheritedAttributes[attributeName] = attribute;\n forceComponentUpdate = true;\n }\n });\n if (forceComponentUpdate) {\n forceUpdate(this);\n }\n };\n\n private setHasTooltip = (): void => {\n this.hasTooltip =\n !this.disableTooltip && (!!this.title || this.variant === \"icon\");\n };\n\n render() {\n const TagType = (this.href && \"a\") || \"button\";\n const { title, ariaLabel, inheritedAttributes } = this;\n const buttonAttrs =\n TagType === \"button\"\n ? {\n type: this.type,\n disabled: this.disabled,\n form: this.form,\n formaction: this.formaction,\n formenctype: this.formenctype,\n formmethod: this.formmethod,\n formnovalidate: this.formnovalidate,\n formtarget: this.formtarget,\n }\n : {\n download: this.download !== false ? this.download : null,\n href: this.href,\n rel: this.rel,\n target: this.target,\n referrerpolicy: this.referrerpolicy,\n hreflang: this.hreflang,\n };\n\n let describedby: string = null;\n let buttonId: string = null;\n if (this.hasTooltip) {\n buttonId =\n this.id !== null\n ? `ic-button-with-tooltip-${this.id}`\n : `ic-button-with-tooltip-${this.buttonIdNum}`;\n describedby =\n this.variant === \"icon\" && !!ariaLabel\n ? null\n : `ic-tooltip-${buttonId}`;\n } else {\n describedby = this.describedById;\n }\n\n const ButtonContent = () => {\n return (\n <TagType\n class=\"button\"\n aria-disabled={this.loading || this.disabled ? \"true\" : null}\n aria-label={this.loading ? \"Loading\" : ariaLabel}\n aria-expanded={this.dropdown && `${this.dropdownExpanded}`}\n {...buttonAttrs}\n {...inheritedAttributes}\n onFocus={this.onFocus}\n onBlur={this.onBlur}\n ref={(el) => (this.buttonEl = el)}\n aria-describedby={describedby}\n part=\"button\"\n >\n {this.hasIconSlot() && !this.loading && (\n <div class=\"icon-container\">\n <slot name=\"icon\" />\n </div>\n )}\n {this.hasIconSlot(\"left\") && !this.loading && (\n <div class=\"icon-container\">\n <slot name=\"left-icon\" />\n </div>\n )}\n {this.hasIconSlot(\"top\") &&\n !this.hasIconSlot(\"left\") &&\n !this.hasIconSlot(\"right\") &&\n !this.loading && (\n <div class=\"icon-container\">\n <slot name=\"top-icon\" />\n </div>\n )}\n {this.loading ? (\n <div class=\"loading-container\">\n <ic-loading-indicator\n type=\"linear\"\n appearance={\n this.variant === \"primary\" ||\n this.variant === \"destructive\" ||\n this.appearance === IcThemeForegroundEnum.Dark ||\n this.appearance === IcThemeForegroundEnum.Light\n ? \"light\"\n : \"dark\"\n }\n ></ic-loading-indicator>\n </div>\n ) : (\n <slot />\n )}\n {this.hasIconSlot(\"right\") && !this.loading && !this.dropdown && (\n <div class={{ \"icon-container\": true, \"right-icon\": true }}>\n <slot name=\"right-icon\" />\n </div>\n )}\n {this.dropdown &&\n !this.loading &&\n this.variant !== \"icon\" &&\n this.variant !== \"destructive\" && (\n <span\n class={{\n [\"arrow-dropdown\"]: !this.dropdownExpanded,\n [\"dropdown-expanded\"]: this.dropdownExpanded,\n }}\n innerHTML={arrowDropdown}\n />\n )}\n </TagType>\n );\n };\n\n return (\n <Host\n class={{\n [\"disabled\"]: this.disabled && !this.loading,\n [`button-variant-${this.variant}`]: true,\n [`button-size-${this.size}`]: true,\n [\"loading\"]: this.loading,\n [\"dark\"]: this.appearance === IcThemeForegroundEnum.Dark,\n [\"light\"]: this.appearance === IcThemeForegroundEnum.Light,\n [\"full-width\"]: this.fullWidth,\n [\"with-badge\"]: isSlotUsed(this.el, \"badge\"),\n [\"dropdown-no-icon\"]:\n this.dropdown &&\n !isSlotUsed(this.el, \"icon\") &&\n !isSlotUsed(this.el, \"left-icon\"),\n [\"top-icon\"]: isSlotUsed(this.el, \"top-icon\"),\n [\"white-background\"]:\n this.variant === \"secondary\" &&\n !this.transparentBackground &&\n this.appearance !== \"light\",\n }}\n onClick={this.handleClick}\n aria-owns={this.ariaOwnsId}\n aria-controls={this.ariaControlsId}\n aria-expanded={this.dropdown && `${this.dropdownExpanded}`}\n >\n {this.hasTooltip && (\n <ic-tooltip\n id={describedby}\n label={title || ariaLabel}\n target={buttonId}\n placement={this.tooltipPlacement}\n silent={this.variant === \"icon\" && !!ariaLabel}\n >\n {this.hasRouterSlot() ? (\n <slot name=\"router-item\"></slot>\n ) : (\n <ButtonContent />\n )}\n </ic-tooltip>\n )}\n {isSlotUsed(this.el, \"badge\") && <slot name=\"badge\"></slot>}\n {!this.hasTooltip &&\n (this.hasRouterSlot() ? (\n <slot name=\"router-item\"></slot>\n ) : (\n <ButtonContent />\n ))}\n {this.describedByContent && (\n <span id={describedby} class=\"ic-button-describedby\">\n {this.describedByContent}\n </span>\n )}\n </Host>\n );\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"ic-button.types.js","sourceRoot":"","sources":["../../../src/components/ic-button/ic-button.types.ts"],"names":[],"mappings":"","sourcesContent":["export type IcButtonTypes = \"reset\" | \"submit\" | \"button\";\n\nexport type IcButtonVariants =\n | \"primary\"\n | \"secondary\"\n | \"tertiary\"\n | \"icon\"\n | \"destructive\";\n\nexport type IcButtonTooltipPlacement = \"top\" | \"right\" | \"bottom\" | \"left\";\n"]}
1
+ {"version":3,"file":"ic-button.types.js","sourceRoot":"","sources":["../../../src/components/ic-button/ic-button.types.ts"],"names":[],"mappings":"","sourcesContent":["export type IcButtonTypes = \"reset\" | \"submit\" | \"button\";\n\nexport type IcButtonVariants =\n | \"primary\"\n | \"secondary\"\n | \"tertiary\"\n | \"destructive\"\n | \"icon\"\n | \"icon-primary\"\n | \"icon-secondary\"\n | \"icon-tertiary\"\n | \"icon-destructive\";\n\nexport type IcButtonTooltipPlacement = \"top\" | \"right\" | \"bottom\" | \"left\";\n"]}
@@ -685,3 +685,11 @@ button {
685
685
  color: GrayText;
686
686
  }
687
687
  }
688
+
689
+ /* Add back in after storybook has the `color-scheme: light dark` code */
690
+
691
+ /* @media (prefers-color-scheme: dark) and (not (forced-colors: active)) {
692
+ ::slotted([slot="icon"]) {
693
+ fill: var(--ic-architectural-white);
694
+ }
695
+ } */
@@ -470,7 +470,7 @@ video {
470
470
  height: var(--ic-space-lg);
471
471
  width: var(--ic-space-lg);
472
472
  background-color: var(--ic-architectural-white);
473
- border: var(--ic-border-width) solid var(--ic-architectural-300);
473
+ border: var(--ic-border-width) solid var(--ic-architectural-400);
474
474
  border-radius: var(--ic-border-radius);
475
475
  outline: none;
476
476
  cursor: pointer;