@ukic/web-components 2.9.0 → 2.11.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (505) hide show
  1. package/dist/cjs/core.cjs.js +3 -3
  2. package/dist/cjs/core.cjs.js.map +1 -1
  3. package/dist/cjs/{helpers-3f91f63a.js → helpers-56e80cc9.js} +6 -6
  4. package/dist/cjs/{helpers-3f91f63a.js.map → helpers-56e80cc9.js.map} +1 -1
  5. package/dist/cjs/ic-accordion-group.cjs.entry.js +1 -1
  6. package/dist/cjs/ic-accordion.cjs.entry.js +2 -2
  7. package/dist/cjs/ic-alert.cjs.entry.js +2 -2
  8. package/dist/cjs/ic-back-to-top.cjs.entry.js +5 -9
  9. package/dist/cjs/ic-back-to-top.cjs.entry.js.map +1 -1
  10. package/dist/cjs/ic-badge.cjs.entry.js +2 -2
  11. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +2 -2
  12. package/dist/cjs/ic-breadcrumb.cjs.entry.js +2 -2
  13. package/dist/cjs/ic-button_3.cjs.entry.js +70 -36
  14. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  15. package/dist/cjs/ic-card.cjs.entry.js +2 -2
  16. package/dist/cjs/ic-checkbox-group.cjs.entry.js +2 -2
  17. package/dist/cjs/ic-checkbox.cjs.entry.js +2 -2
  18. package/dist/cjs/ic-chip.cjs.entry.js +2 -2
  19. package/dist/cjs/ic-classification-banner.cjs.entry.js +1 -1
  20. package/dist/cjs/ic-data-entity.cjs.entry.js +1 -1
  21. package/dist/cjs/ic-data-row.cjs.entry.js +2 -2
  22. package/dist/cjs/ic-dialog.cjs.entry.js +2 -2
  23. package/dist/cjs/ic-divider.cjs.entry.js +2 -2
  24. package/dist/cjs/ic-empty-state.cjs.entry.js +2 -2
  25. package/dist/cjs/ic-footer-link-group.cjs.entry.js +2 -2
  26. package/dist/cjs/ic-footer-link.cjs.entry.js +2 -2
  27. package/dist/cjs/ic-footer.cjs.entry.js +2 -2
  28. package/dist/cjs/ic-hero.cjs.entry.js +2 -2
  29. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +2 -2
  30. package/dist/cjs/ic-input-component-container_3.cjs.entry.js +16 -24
  31. package/dist/cjs/ic-input-component-container_3.cjs.entry.js.map +1 -1
  32. package/dist/cjs/ic-input-label_2.cjs.entry.js +2 -2
  33. package/dist/cjs/ic-link.cjs.entry.js +2 -2
  34. package/dist/cjs/ic-menu-group.cjs.entry.js +2 -2
  35. package/dist/cjs/ic-menu-item.cjs.entry.js +3 -3
  36. package/dist/cjs/ic-menu-item.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ic-navigation-button.cjs.entry.js +2 -2
  38. package/dist/cjs/ic-navigation-group.cjs.entry.js +6 -9
  39. package/dist/cjs/ic-navigation-group.cjs.entry.js.map +1 -1
  40. package/dist/cjs/ic-navigation-item.cjs.entry.js +2 -2
  41. package/dist/cjs/ic-navigation-item.cjs.entry.js.map +1 -1
  42. package/dist/cjs/ic-navigation-menu.cjs.entry.js +2 -2
  43. package/dist/cjs/ic-page-header.cjs.entry.js +7 -4
  44. package/dist/cjs/ic-page-header.cjs.entry.js.map +1 -1
  45. package/dist/cjs/ic-pagination-item.cjs.entry.js +2 -2
  46. package/dist/cjs/ic-pagination.cjs.entry.js +2 -2
  47. package/dist/cjs/ic-popover-menu.cjs.entry.js +4 -2
  48. package/dist/cjs/ic-popover-menu.cjs.entry.js.map +1 -1
  49. package/dist/cjs/ic-radio-group.cjs.entry.js +2 -2
  50. package/dist/cjs/ic-radio-option.cjs.entry.js +2 -2
  51. package/dist/cjs/ic-search-bar.cjs.entry.js +2 -2
  52. package/dist/cjs/ic-section-container.cjs.entry.js +1 -1
  53. package/dist/cjs/ic-select.cjs.entry.js +3 -3
  54. package/dist/cjs/ic-select.cjs.entry.js.map +1 -1
  55. package/dist/cjs/ic-side-navigation.cjs.entry.js +33 -62
  56. package/dist/cjs/ic-side-navigation.cjs.entry.js.map +1 -1
  57. package/dist/cjs/ic-skeleton.cjs.entry.js +1 -1
  58. package/dist/cjs/ic-status-tag.cjs.entry.js +4 -3
  59. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -1
  60. package/dist/cjs/ic-step.cjs.entry.js +2 -2
  61. package/dist/cjs/ic-stepper.cjs.entry.js +2 -2
  62. package/dist/cjs/ic-switch.cjs.entry.js +2 -2
  63. package/dist/cjs/ic-tab-context.cjs.entry.js +1 -1
  64. package/dist/cjs/ic-tab-group.cjs.entry.js +2 -2
  65. package/dist/cjs/ic-tab-panel.cjs.entry.js +2 -2
  66. package/dist/cjs/ic-tab.cjs.entry.js +2 -2
  67. package/dist/cjs/ic-text-field.cjs.entry.js +4 -4
  68. package/dist/cjs/ic-text-field.cjs.entry.js.map +1 -1
  69. package/dist/cjs/ic-theme.cjs.entry.js +2 -2
  70. package/dist/cjs/ic-toast-region.cjs.entry.js +1 -1
  71. package/dist/cjs/ic-toast.cjs.entry.js +13 -16
  72. package/dist/cjs/ic-toast.cjs.entry.js.map +1 -1
  73. package/dist/cjs/ic-toggle-button.cjs.entry.js +69 -0
  74. package/dist/cjs/ic-toggle-button.cjs.entry.js.map +1 -0
  75. package/dist/cjs/ic-top-navigation.cjs.entry.js +4 -3
  76. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -1
  77. package/dist/cjs/ic-typography.cjs.entry.js +2 -2
  78. package/dist/cjs/{index-152d1fe5.js → index-f982899d.js} +6 -12
  79. package/dist/cjs/index-f982899d.js.map +1 -0
  80. package/dist/cjs/loader.cjs.js +2 -2
  81. package/dist/collection/assets/arrow-dropdown.svg +3 -0
  82. package/dist/collection/collection-manifest.json +3 -2
  83. package/dist/collection/components/ic-accordion/ic-accordion.js.map +1 -1
  84. package/dist/collection/components/ic-accordion-group/ic-accordion-group.js.map +1 -1
  85. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js +3 -7
  86. package/dist/collection/components/ic-back-to-top/ic-back-to-top.js.map +1 -1
  87. package/dist/collection/components/ic-badge/ic-badge.js.map +1 -1
  88. package/dist/collection/components/ic-breadcrumb/ic-breadcrumb.js.map +1 -1
  89. package/dist/collection/components/ic-breadcrumb-group/ic-breadcrumb-group.js.map +1 -1
  90. package/dist/collection/components/ic-button/ic-button.css +31 -2
  91. package/dist/collection/components/ic-button/ic-button.js +63 -3
  92. package/dist/collection/components/ic-button/ic-button.js.map +1 -1
  93. package/dist/collection/components/ic-card/ic-card.js.map +1 -1
  94. package/dist/collection/components/ic-checkbox/ic-checkbox.js.map +1 -1
  95. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js.map +1 -1
  96. package/dist/collection/components/ic-chip/ic-chip.js.map +1 -1
  97. package/dist/collection/components/ic-data-entity/ic-data-entity.js.map +1 -1
  98. package/dist/collection/components/ic-data-row/ic-data-row.js.map +1 -1
  99. package/dist/collection/components/ic-dialog/ic-dialog.js.map +1 -1
  100. package/dist/collection/components/ic-footer/ic-footer.js.map +1 -1
  101. package/dist/collection/components/ic-footer-link/ic-footer-link.js.map +1 -1
  102. package/dist/collection/components/ic-footer-link-group/ic-footer-link-group.js.map +1 -1
  103. package/dist/collection/components/ic-hero/ic-hero.js.map +1 -1
  104. package/dist/collection/components/ic-horizontal-scroll/ic-horizontal-scroll.js.map +1 -1
  105. package/dist/collection/components/ic-link/ic-link.js.map +1 -1
  106. package/dist/collection/components/ic-loading-indicator/ic-loading-indicator.js.map +1 -1
  107. package/dist/collection/components/ic-menu/ic-menu.js +14 -22
  108. package/dist/collection/components/ic-menu/ic-menu.js.map +1 -1
  109. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js +60 -2
  110. package/dist/collection/components/ic-menu/test/basic/ic-menu.spec.js.map +1 -1
  111. package/dist/collection/components/ic-menu-item/ic-menu-item.css +16 -16
  112. package/dist/collection/components/ic-menu-item/ic-menu-item.js.map +1 -1
  113. package/dist/collection/components/ic-navigation-button/ic-navigation-button.js.map +1 -1
  114. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js +4 -7
  115. package/dist/collection/components/ic-navigation-group/ic-navigation-group.js.map +1 -1
  116. package/dist/collection/components/ic-navigation-item/ic-navigation-item.css +28 -7
  117. package/dist/collection/components/ic-navigation-item/ic-navigation-item.js.map +1 -1
  118. package/dist/collection/components/ic-navigation-menu/ic-navigation-menu.js.map +1 -1
  119. package/dist/collection/components/ic-page-header/ic-page-header.css +1 -1
  120. package/dist/collection/components/ic-page-header/ic-page-header.js +4 -1
  121. package/dist/collection/components/ic-page-header/ic-page-header.js.map +1 -1
  122. package/dist/collection/components/ic-pagination/ic-pagination.js.map +1 -1
  123. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js +19 -0
  124. package/dist/collection/components/ic-popover-menu/ic-popover-menu.js.map +1 -1
  125. package/dist/collection/components/ic-radio-group/ic-radio-group.js.map +1 -1
  126. package/dist/collection/components/ic-radio-option/ic-radio-option.js.map +1 -1
  127. package/dist/collection/components/ic-search-bar/ic-search-bar.js.map +1 -1
  128. package/dist/collection/components/ic-search-bar/test/basic/ic-search-bar.e2e.js.map +1 -1
  129. package/dist/collection/components/ic-select/ic-select.css +1 -0
  130. package/dist/collection/components/ic-select/ic-select.js.map +1 -1
  131. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js +31 -60
  132. package/dist/collection/components/ic-side-navigation/ic-side-navigation.js.map +1 -1
  133. package/dist/collection/components/ic-skeleton/ic-skeleton.js.map +1 -1
  134. package/dist/collection/components/ic-status-tag/ic-status-tag.css +9 -0
  135. package/dist/collection/components/ic-status-tag/ic-status-tag.js +1 -0
  136. package/dist/collection/components/ic-status-tag/ic-status-tag.js.map +1 -1
  137. package/dist/collection/components/ic-step/ic-step.js.map +1 -1
  138. package/dist/collection/components/ic-stepper/ic-stepper.js.map +1 -1
  139. package/dist/collection/components/ic-stepper/test/basic/ic-stepper.spec.js.map +1 -1
  140. package/dist/collection/components/ic-switch/ic-switch.js.map +1 -1
  141. package/dist/collection/components/ic-tab/ic-tab.js.map +1 -1
  142. package/dist/collection/components/ic-tab-context/ic-tab-context.js.map +1 -1
  143. package/dist/collection/components/ic-tab-panel/ic-tab-panel.js.map +1 -1
  144. package/dist/collection/components/ic-text-field/ic-text-field.js +2 -2
  145. package/dist/collection/components/ic-text-field/ic-text-field.js.map +1 -1
  146. package/dist/collection/components/ic-theme/ic-theme.js.map +1 -1
  147. package/dist/collection/components/ic-toast/ic-toast.js +11 -14
  148. package/dist/collection/components/ic-toast/ic-toast.js.map +1 -1
  149. package/dist/collection/components/ic-toast-region/ic-toast-region.js.map +1 -1
  150. package/dist/collection/components/ic-toggle-button/ic-toggle-button.css +555 -0
  151. package/dist/collection/components/ic-toggle-button/ic-toggle-button.js +291 -0
  152. package/dist/collection/components/ic-toggle-button/ic-toggle-button.js.map +1 -0
  153. package/dist/collection/components/ic-toggle-button/test/basic/ic-toggle-button.spec.js +116 -0
  154. package/dist/collection/components/ic-toggle-button/test/basic/ic-toggle-button.spec.js.map +1 -0
  155. package/dist/collection/components/ic-tooltip/ic-tooltip.js +59 -30
  156. package/dist/collection/components/ic-tooltip/ic-tooltip.js.map +1 -1
  157. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.spec.js +11 -0
  158. package/dist/collection/components/ic-tooltip/test/basic/ic-tooltip.spec.js.map +1 -1
  159. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js +2 -1
  160. package/dist/collection/components/ic-top-navigation/ic-top-navigation.js.map +1 -1
  161. package/dist/collection/components/ic-typography/ic-typography.js.map +1 -1
  162. package/dist/collection/utils/helpers.js +5 -5
  163. package/dist/collection/utils/helpers.js.map +1 -1
  164. package/dist/components/helpers.js +5 -5
  165. package/dist/components/ic-back-to-top.js +3 -7
  166. package/dist/components/ic-back-to-top.js.map +1 -1
  167. package/dist/components/ic-button2.js +32 -4
  168. package/dist/components/ic-button2.js.map +1 -1
  169. package/dist/components/ic-menu-item2.js +1 -1
  170. package/dist/components/ic-menu-item2.js.map +1 -1
  171. package/dist/components/ic-menu2.js +14 -22
  172. package/dist/components/ic-menu2.js.map +1 -1
  173. package/dist/components/ic-navigation-group.js +4 -7
  174. package/dist/components/ic-navigation-group.js.map +1 -1
  175. package/dist/components/ic-navigation-item.js.map +1 -1
  176. package/dist/components/ic-page-header.js +5 -2
  177. package/dist/components/ic-page-header.js.map +1 -1
  178. package/dist/components/ic-popover-menu.js +3 -1
  179. package/dist/components/ic-popover-menu.js.map +1 -1
  180. package/dist/components/ic-select.js +1 -1
  181. package/dist/components/ic-select.js.map +1 -1
  182. package/dist/components/ic-side-navigation.js +31 -60
  183. package/dist/components/ic-side-navigation.js.map +1 -1
  184. package/dist/components/ic-status-tag.js +2 -1
  185. package/dist/components/ic-status-tag.js.map +1 -1
  186. package/dist/components/ic-text-field2.js +2 -2
  187. package/dist/components/ic-text-field2.js.map +1 -1
  188. package/dist/components/ic-toast.js +11 -14
  189. package/dist/components/ic-toast.js.map +1 -1
  190. package/dist/components/ic-toggle-button.d.ts +11 -0
  191. package/dist/components/ic-toggle-button.js +117 -0
  192. package/dist/components/ic-toggle-button.js.map +1 -0
  193. package/dist/components/ic-tooltip2.js +39 -30
  194. package/dist/components/ic-tooltip2.js.map +1 -1
  195. package/dist/components/ic-top-navigation.js +2 -1
  196. package/dist/components/ic-top-navigation.js.map +1 -1
  197. package/dist/core/core.css +1 -1
  198. package/dist/core/core.esm.js +1 -1
  199. package/dist/core/core.esm.js.map +1 -1
  200. package/dist/core/{p-daebb58a.entry.js → p-003c44bd.entry.js} +2 -2
  201. package/dist/core/{p-b6a575c3.entry.js → p-049bf5e3.entry.js} +2 -2
  202. package/dist/core/p-0713230f.entry.js +2 -0
  203. package/dist/core/p-0713230f.entry.js.map +1 -0
  204. package/dist/core/{p-ea17e371.entry.js → p-0a0b748c.entry.js} +2 -2
  205. package/dist/core/{p-d18450f9.entry.js → p-0d2eb765.entry.js} +2 -2
  206. package/dist/core/{p-6d3f9501.entry.js → p-0ee13da0.entry.js} +2 -2
  207. package/dist/core/{p-15466b42.entry.js → p-1145e33c.entry.js} +2 -2
  208. package/dist/core/{p-056f8a67.entry.js → p-171e25c9.entry.js} +2 -2
  209. package/dist/core/{p-51f9f329.entry.js → p-1e809ecd.entry.js} +2 -2
  210. package/dist/core/p-1e809ecd.entry.js.map +1 -0
  211. package/dist/core/{p-5f9d69ef.entry.js → p-22208df0.entry.js} +2 -2
  212. package/dist/core/p-22208df0.entry.js.map +1 -0
  213. package/dist/core/{p-ad36a704.entry.js → p-26334b3a.entry.js} +2 -2
  214. package/dist/core/{p-dbb5b008.entry.js → p-29b812c0.entry.js} +2 -2
  215. package/dist/core/{p-b9736cf4.entry.js → p-2e7f22af.entry.js} +2 -2
  216. package/dist/core/{p-aa0a9870.entry.js → p-357eaebe.entry.js} +2 -2
  217. package/dist/core/{p-9639e33f.entry.js → p-38bf02aa.entry.js} +2 -2
  218. package/dist/core/{p-b99f9e89.entry.js → p-3c752bca.entry.js} +2 -2
  219. package/dist/core/{p-3a0ef91e.entry.js → p-3cc52cbc.entry.js} +2 -2
  220. package/dist/core/{p-e278242f.entry.js → p-3ebe5fa3.entry.js} +2 -2
  221. package/dist/core/p-3ebe5fa3.entry.js.map +1 -0
  222. package/dist/core/{p-5c7e339f.entry.js → p-3f07c471.entry.js} +2 -2
  223. package/dist/core/p-3f07c471.entry.js.map +1 -0
  224. package/dist/core/{p-c770e7a2.entry.js → p-42c0e318.entry.js} +2 -2
  225. package/dist/core/{p-2b24b4bf.entry.js → p-4421203e.entry.js} +2 -2
  226. package/dist/core/{p-11736fbe.entry.js → p-4f1792a6.entry.js} +2 -2
  227. package/dist/core/{p-b39ecae2.entry.js → p-4f8b7aa3.entry.js} +2 -2
  228. package/dist/core/{p-8a83f391.entry.js → p-525323ab.entry.js} +2 -2
  229. package/dist/core/{p-c2452388.entry.js → p-5894f6aa.entry.js} +2 -2
  230. package/dist/core/{p-e9738c74.entry.js → p-59c4bc0a.entry.js} +2 -2
  231. package/dist/core/{p-60c4604f.entry.js → p-5adaf5c3.entry.js} +2 -2
  232. package/dist/core/{p-95a864bf.js → p-671b7cac.js} +1 -1
  233. package/dist/core/p-6b5e91e2.js +3 -0
  234. package/dist/core/p-6b5e91e2.js.map +1 -0
  235. package/dist/core/p-6bbe0550.entry.js +2 -0
  236. package/dist/core/p-6bbe0550.entry.js.map +1 -0
  237. package/dist/core/{p-fdb4b48f.entry.js → p-783c2ced.entry.js} +2 -2
  238. package/dist/core/{p-f2e6b9ef.entry.js → p-7b720034.entry.js} +2 -2
  239. package/dist/core/{p-22c024ee.entry.js → p-7c724f2c.entry.js} +2 -2
  240. package/dist/core/{p-335fc5e4.entry.js → p-8146336b.entry.js} +2 -2
  241. package/dist/core/{p-cd8de4c5.entry.js → p-8931210a.entry.js} +2 -2
  242. package/dist/core/{p-529d8955.entry.js → p-8a66cab4.entry.js} +2 -2
  243. package/dist/core/{p-ca48e97a.entry.js → p-8be3ec3d.entry.js} +2 -2
  244. package/dist/core/{p-180e36b1.entry.js → p-8c2322a9.entry.js} +2 -2
  245. package/dist/core/{p-31969be6.entry.js → p-8f97463f.entry.js} +2 -2
  246. package/dist/core/p-8f97463f.entry.js.map +1 -0
  247. package/dist/core/{p-edd29edc.entry.js → p-9184e385.entry.js} +2 -2
  248. package/dist/core/p-9808f7c9.entry.js +2 -0
  249. package/dist/core/p-9808f7c9.entry.js.map +1 -0
  250. package/dist/core/p-9b8ab047.entry.js +2 -0
  251. package/dist/core/p-9b8ab047.entry.js.map +1 -0
  252. package/dist/core/{p-366bcb17.entry.js → p-9ee138e7.entry.js} +2 -2
  253. package/dist/core/p-a6143c94.entry.js +2 -0
  254. package/dist/core/p-a6143c94.entry.js.map +1 -0
  255. package/dist/core/{p-15ef0674.entry.js → p-b74f92b6.entry.js} +2 -2
  256. package/dist/core/p-b74f92b6.entry.js.map +1 -0
  257. package/dist/core/{p-e5abfadd.entry.js → p-b7a2e604.entry.js} +2 -2
  258. package/dist/core/{p-b0088956.entry.js → p-bb41b637.entry.js} +2 -2
  259. package/dist/core/{p-02159742.entry.js → p-bf93455b.entry.js} +2 -2
  260. package/dist/core/{p-02159742.entry.js.map → p-bf93455b.entry.js.map} +1 -1
  261. package/dist/core/p-c1109ec7.entry.js +2 -0
  262. package/dist/core/p-c1109ec7.entry.js.map +1 -0
  263. package/dist/core/{p-cfc930f6.entry.js → p-c75d6022.entry.js} +2 -2
  264. package/dist/core/{p-f0809037.entry.js → p-c786d62f.entry.js} +2 -2
  265. package/dist/core/{p-edec0936.entry.js → p-c7a08024.entry.js} +2 -2
  266. package/dist/core/{p-6eb0421d.entry.js → p-cf798ea7.entry.js} +2 -2
  267. package/dist/core/p-d3e54a29.entry.js +2 -0
  268. package/dist/core/p-d3e54a29.entry.js.map +1 -0
  269. package/dist/core/{p-287ab47c.entry.js → p-de87d585.entry.js} +2 -2
  270. package/dist/core/{p-15624e08.entry.js → p-e4d827d4.entry.js} +2 -2
  271. package/dist/core/{p-765bdd98.entry.js → p-e9723eaa.entry.js} +2 -2
  272. package/dist/core/{p-498eb7ad.entry.js → p-eb2d06c1.entry.js} +2 -2
  273. package/dist/core/{p-ee97e2a5.entry.js → p-f62982ae.entry.js} +2 -2
  274. package/dist/core/p-f62982ae.entry.js.map +1 -0
  275. package/dist/core/{p-94e88827.entry.js → p-f9452975.entry.js} +2 -2
  276. package/dist/esm/core.js +4 -4
  277. package/dist/esm/core.js.map +1 -1
  278. package/dist/esm/{helpers-c597f246.js → helpers-821dcdf2.js} +6 -6
  279. package/dist/esm/{helpers-c597f246.js.map → helpers-821dcdf2.js.map} +1 -1
  280. package/dist/esm/ic-accordion-group.entry.js +1 -1
  281. package/dist/esm/ic-accordion.entry.js +2 -2
  282. package/dist/esm/ic-alert.entry.js +2 -2
  283. package/dist/esm/ic-back-to-top.entry.js +5 -9
  284. package/dist/esm/ic-back-to-top.entry.js.map +1 -1
  285. package/dist/esm/ic-badge.entry.js +2 -2
  286. package/dist/esm/ic-breadcrumb-group.entry.js +2 -2
  287. package/dist/esm/ic-breadcrumb.entry.js +2 -2
  288. package/dist/esm/ic-button_3.entry.js +70 -36
  289. package/dist/esm/ic-button_3.entry.js.map +1 -1
  290. package/dist/esm/ic-card.entry.js +2 -2
  291. package/dist/esm/ic-checkbox-group.entry.js +2 -2
  292. package/dist/esm/ic-checkbox.entry.js +2 -2
  293. package/dist/esm/ic-chip.entry.js +2 -2
  294. package/dist/esm/ic-classification-banner.entry.js +1 -1
  295. package/dist/esm/ic-data-entity.entry.js +1 -1
  296. package/dist/esm/ic-data-row.entry.js +2 -2
  297. package/dist/esm/ic-dialog.entry.js +2 -2
  298. package/dist/esm/ic-divider.entry.js +2 -2
  299. package/dist/esm/ic-empty-state.entry.js +2 -2
  300. package/dist/esm/ic-footer-link-group.entry.js +2 -2
  301. package/dist/esm/ic-footer-link.entry.js +2 -2
  302. package/dist/esm/ic-footer.entry.js +2 -2
  303. package/dist/esm/ic-hero.entry.js +2 -2
  304. package/dist/esm/ic-horizontal-scroll.entry.js +2 -2
  305. package/dist/esm/ic-input-component-container_3.entry.js +16 -24
  306. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -1
  307. package/dist/esm/ic-input-label_2.entry.js +2 -2
  308. package/dist/esm/ic-link.entry.js +2 -2
  309. package/dist/esm/ic-menu-group.entry.js +2 -2
  310. package/dist/esm/ic-menu-item.entry.js +3 -3
  311. package/dist/esm/ic-menu-item.entry.js.map +1 -1
  312. package/dist/esm/ic-navigation-button.entry.js +2 -2
  313. package/dist/esm/ic-navigation-group.entry.js +6 -9
  314. package/dist/esm/ic-navigation-group.entry.js.map +1 -1
  315. package/dist/esm/ic-navigation-item.entry.js +2 -2
  316. package/dist/esm/ic-navigation-item.entry.js.map +1 -1
  317. package/dist/esm/ic-navigation-menu.entry.js +2 -2
  318. package/dist/esm/ic-page-header.entry.js +7 -4
  319. package/dist/esm/ic-page-header.entry.js.map +1 -1
  320. package/dist/esm/ic-pagination-item.entry.js +2 -2
  321. package/dist/esm/ic-pagination.entry.js +2 -2
  322. package/dist/esm/ic-popover-menu.entry.js +4 -2
  323. package/dist/esm/ic-popover-menu.entry.js.map +1 -1
  324. package/dist/esm/ic-radio-group.entry.js +2 -2
  325. package/dist/esm/ic-radio-option.entry.js +2 -2
  326. package/dist/esm/ic-search-bar.entry.js +2 -2
  327. package/dist/esm/ic-section-container.entry.js +1 -1
  328. package/dist/esm/ic-select.entry.js +3 -3
  329. package/dist/esm/ic-select.entry.js.map +1 -1
  330. package/dist/esm/ic-side-navigation.entry.js +33 -62
  331. package/dist/esm/ic-side-navigation.entry.js.map +1 -1
  332. package/dist/esm/ic-skeleton.entry.js +1 -1
  333. package/dist/esm/ic-status-tag.entry.js +4 -3
  334. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  335. package/dist/esm/ic-step.entry.js +2 -2
  336. package/dist/esm/ic-stepper.entry.js +2 -2
  337. package/dist/esm/ic-switch.entry.js +2 -2
  338. package/dist/esm/ic-tab-context.entry.js +1 -1
  339. package/dist/esm/ic-tab-group.entry.js +2 -2
  340. package/dist/esm/ic-tab-panel.entry.js +2 -2
  341. package/dist/esm/ic-tab.entry.js +2 -2
  342. package/dist/esm/ic-text-field.entry.js +4 -4
  343. package/dist/esm/ic-text-field.entry.js.map +1 -1
  344. package/dist/esm/ic-theme.entry.js +2 -2
  345. package/dist/esm/ic-toast-region.entry.js +1 -1
  346. package/dist/esm/ic-toast.entry.js +13 -16
  347. package/dist/esm/ic-toast.entry.js.map +1 -1
  348. package/dist/esm/ic-toggle-button.entry.js +65 -0
  349. package/dist/esm/ic-toggle-button.entry.js.map +1 -0
  350. package/dist/esm/ic-top-navigation.entry.js +4 -3
  351. package/dist/esm/ic-top-navigation.entry.js.map +1 -1
  352. package/dist/esm/ic-typography.entry.js +2 -2
  353. package/dist/esm/{index-05003e1c.js → index-d1d2c456.js} +6 -12
  354. package/dist/esm/index-d1d2c456.js.map +1 -0
  355. package/dist/esm/loader.js +3 -3
  356. package/dist/types/components/ic-button/ic-button.d.ts +10 -0
  357. package/dist/types/components/ic-menu/ic-menu.d.ts +1 -0
  358. package/dist/types/components/ic-popover-menu/ic-popover-menu.d.ts +5 -0
  359. package/dist/types/components/ic-side-navigation/ic-side-navigation.d.ts +1 -1
  360. package/dist/types/components/ic-toggle-button/ic-toggle-button.d.ts +60 -0
  361. package/dist/types/components/ic-tooltip/ic-tooltip.d.ts +4 -0
  362. package/dist/types/components.d.ts +152 -0
  363. package/dist/types/interface.d.ts +3 -0
  364. package/hydrate/index.d.ts +1 -1
  365. package/hydrate/index.js +276 -197
  366. package/package.json +26 -17
  367. package/vscode-data.json +98 -0
  368. package/dist/cjs/index-152d1fe5.js.map +0 -1
  369. package/dist/collection/components/ic-accordion/test/basic/ic-accordion.e2e.js +0 -57
  370. package/dist/collection/components/ic-accordion/test/basic/ic-accordion.e2e.js.map +0 -1
  371. package/dist/collection/components/ic-accordion-group/test/a11y/ic-accordion-group.test.a11y.js +0 -31
  372. package/dist/collection/components/ic-accordion-group/test/a11y/ic-accordion-group.test.a11y.js.map +0 -1
  373. package/dist/collection/components/ic-accordion-group/test/basic/ic-accordion-group.e2e.js +0 -117
  374. package/dist/collection/components/ic-accordion-group/test/basic/ic-accordion-group.e2e.js.map +0 -1
  375. package/dist/collection/components/ic-alert/test/a11y/ic-alert.test.a11y.js +0 -11
  376. package/dist/collection/components/ic-alert/test/a11y/ic-alert.test.a11y.js.map +0 -1
  377. package/dist/collection/components/ic-alert/test/basic/ic-alert.e2e.js +0 -16
  378. package/dist/collection/components/ic-alert/test/basic/ic-alert.e2e.js.map +0 -1
  379. package/dist/collection/components/ic-back-to-top/test/a11y/ic-back-to-top.test.a11y.js +0 -28
  380. package/dist/collection/components/ic-back-to-top/test/a11y/ic-back-to-top.test.a11y.js.map +0 -1
  381. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.e2e.js +0 -68
  382. package/dist/collection/components/ic-back-to-top/test/basic/ic-back-to-top.e2e.js.map +0 -1
  383. package/dist/collection/components/ic-badge/test/a11y/ic-badge.test.a11y.js +0 -16
  384. package/dist/collection/components/ic-badge/test/a11y/ic-badge.test.a11y.js.map +0 -1
  385. package/dist/collection/components/ic-breadcrumb-group/test/a11y/ic-breadcrumb-group.test.a11y.js +0 -21
  386. package/dist/collection/components/ic-breadcrumb-group/test/a11y/ic-breadcrumb-group.test.a11y.js.map +0 -1
  387. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group-test-examples.js +0 -35
  388. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group-test-examples.js.map +0 -1
  389. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.e2e.js +0 -41
  390. package/dist/collection/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group.e2e.js.map +0 -1
  391. package/dist/collection/components/ic-button/test/a11y/ic-button.test.a11y.js +0 -11
  392. package/dist/collection/components/ic-button/test/a11y/ic-button.test.a11y.js.map +0 -1
  393. package/dist/collection/components/ic-button/test/basic/ic-button.e2e.js +0 -198
  394. package/dist/collection/components/ic-button/test/basic/ic-button.e2e.js.map +0 -1
  395. package/dist/collection/components/ic-checkbox-group/test/a11y/ic-checkbox-group.test.a11y.js +0 -16
  396. package/dist/collection/components/ic-checkbox-group/test/a11y/ic-checkbox-group.test.a11y.js.map +0 -1
  397. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.e2e.js +0 -201
  398. package/dist/collection/components/ic-checkbox-group/test/basic/ic-checkbox-group.e2e.js.map +0 -1
  399. package/dist/collection/components/ic-classification-banner/test/a11y/ic-classification-banner.test.a11y.js +0 -11
  400. package/dist/collection/components/ic-classification-banner/test/a11y/ic-classification-banner.test.a11y.js.map +0 -1
  401. package/dist/collection/components/ic-dialog/test/a11y/ic-dialog.test.a11y.js +0 -28
  402. package/dist/collection/components/ic-dialog/test/a11y/ic-dialog.test.a11y.js.map +0 -1
  403. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.e2e.js +0 -288
  404. package/dist/collection/components/ic-dialog/test/basic/ic-dialog.e2e.js.map +0 -1
  405. package/dist/collection/components/ic-select/test/a11y/ic-select.test.a11y.js +0 -28
  406. package/dist/collection/components/ic-select/test/a11y/ic-select.test.a11y.js.map +0 -1
  407. package/dist/collection/components/ic-select/test/basic/ic-select.e2e.js +0 -1825
  408. package/dist/collection/components/ic-select/test/basic/ic-select.e2e.js.map +0 -1
  409. package/dist/collection/components/ic-side-navigation/test/a11y/ic-side-navigation.test.a11y.js +0 -14
  410. package/dist/collection/components/ic-side-navigation/test/a11y/ic-side-navigation.test.a11y.js.map +0 -1
  411. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation-test-examples.js +0 -582
  412. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation-test-examples.js.map +0 -1
  413. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.e2e.js +0 -475
  414. package/dist/collection/components/ic-side-navigation/test/basic/ic-side-navigation.e2e.js.map +0 -1
  415. package/dist/collection/components/ic-toast/test/a11y/ic-toast.test.a11y.js +0 -16
  416. package/dist/collection/components/ic-toast/test/a11y/ic-toast.test.a11y.js.map +0 -1
  417. package/dist/collection/components/ic-toast/test/basic/ic-toast.e2e.js +0 -82
  418. package/dist/collection/components/ic-toast/test/basic/ic-toast.e2e.js.map +0 -1
  419. package/dist/collection/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.js +0 -32
  420. package/dist/collection/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.js.map +0 -1
  421. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.e2e.js +0 -61
  422. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.e2e.js.map +0 -1
  423. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.mobile.e2e.js +0 -244
  424. package/dist/collection/components/ic-top-navigation/test/basic/ic-top-navigation.mobile.e2e.js.map +0 -1
  425. package/dist/core/p-15ef0674.entry.js.map +0 -1
  426. package/dist/core/p-31969be6.entry.js.map +0 -1
  427. package/dist/core/p-51f9f329.entry.js.map +0 -1
  428. package/dist/core/p-52e063d3.js +0 -3
  429. package/dist/core/p-52e063d3.js.map +0 -1
  430. package/dist/core/p-5c7e339f.entry.js.map +0 -1
  431. package/dist/core/p-5f9d69ef.entry.js.map +0 -1
  432. package/dist/core/p-6bc431b2.entry.js +0 -2
  433. package/dist/core/p-6bc431b2.entry.js.map +0 -1
  434. package/dist/core/p-7f887c1e.entry.js +0 -2
  435. package/dist/core/p-7f887c1e.entry.js.map +0 -1
  436. package/dist/core/p-96da1e85.entry.js +0 -2
  437. package/dist/core/p-96da1e85.entry.js.map +0 -1
  438. package/dist/core/p-988991d3.entry.js +0 -2
  439. package/dist/core/p-988991d3.entry.js.map +0 -1
  440. package/dist/core/p-9c30720d.entry.js +0 -2
  441. package/dist/core/p-9c30720d.entry.js.map +0 -1
  442. package/dist/core/p-ca178add.entry.js +0 -2
  443. package/dist/core/p-ca178add.entry.js.map +0 -1
  444. package/dist/core/p-e278242f.entry.js.map +0 -1
  445. package/dist/core/p-ee97e2a5.entry.js.map +0 -1
  446. package/dist/esm/index-05003e1c.js.map +0 -1
  447. package/dist/types/components/ic-accordion-group/test/a11y/ic-accordion-group.test.a11y.d.ts +0 -1
  448. package/dist/types/components/ic-alert/test/a11y/ic-alert.test.a11y.d.ts +0 -1
  449. package/dist/types/components/ic-back-to-top/test/a11y/ic-back-to-top.test.a11y.d.ts +0 -1
  450. package/dist/types/components/ic-badge/test/a11y/ic-badge.test.a11y.d.ts +0 -1
  451. package/dist/types/components/ic-breadcrumb-group/test/a11y/ic-breadcrumb-group.test.a11y.d.ts +0 -1
  452. package/dist/types/components/ic-breadcrumb-group/test/basic/ic-breadcrumb-group-test-examples.d.ts +0 -2
  453. package/dist/types/components/ic-button/test/a11y/ic-button.test.a11y.d.ts +0 -1
  454. package/dist/types/components/ic-checkbox-group/test/a11y/ic-checkbox-group.test.a11y.d.ts +0 -1
  455. package/dist/types/components/ic-classification-banner/test/a11y/ic-classification-banner.test.a11y.d.ts +0 -1
  456. package/dist/types/components/ic-dialog/test/a11y/ic-dialog.test.a11y.d.ts +0 -1
  457. package/dist/types/components/ic-select/test/a11y/ic-select.test.a11y.d.ts +0 -1
  458. package/dist/types/components/ic-side-navigation/test/a11y/ic-side-navigation.test.a11y.d.ts +0 -1
  459. package/dist/types/components/ic-side-navigation/test/basic/ic-side-navigation-test-examples.d.ts +0 -8
  460. package/dist/types/components/ic-toast/test/a11y/ic-toast.test.a11y.d.ts +0 -1
  461. package/dist/types/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.d.ts +0 -1
  462. /package/dist/core/{p-daebb58a.entry.js.map → p-003c44bd.entry.js.map} +0 -0
  463. /package/dist/core/{p-b6a575c3.entry.js.map → p-049bf5e3.entry.js.map} +0 -0
  464. /package/dist/core/{p-ea17e371.entry.js.map → p-0a0b748c.entry.js.map} +0 -0
  465. /package/dist/core/{p-d18450f9.entry.js.map → p-0d2eb765.entry.js.map} +0 -0
  466. /package/dist/core/{p-6d3f9501.entry.js.map → p-0ee13da0.entry.js.map} +0 -0
  467. /package/dist/core/{p-15466b42.entry.js.map → p-1145e33c.entry.js.map} +0 -0
  468. /package/dist/core/{p-056f8a67.entry.js.map → p-171e25c9.entry.js.map} +0 -0
  469. /package/dist/core/{p-ad36a704.entry.js.map → p-26334b3a.entry.js.map} +0 -0
  470. /package/dist/core/{p-dbb5b008.entry.js.map → p-29b812c0.entry.js.map} +0 -0
  471. /package/dist/core/{p-b9736cf4.entry.js.map → p-2e7f22af.entry.js.map} +0 -0
  472. /package/dist/core/{p-aa0a9870.entry.js.map → p-357eaebe.entry.js.map} +0 -0
  473. /package/dist/core/{p-9639e33f.entry.js.map → p-38bf02aa.entry.js.map} +0 -0
  474. /package/dist/core/{p-b99f9e89.entry.js.map → p-3c752bca.entry.js.map} +0 -0
  475. /package/dist/core/{p-3a0ef91e.entry.js.map → p-3cc52cbc.entry.js.map} +0 -0
  476. /package/dist/core/{p-c770e7a2.entry.js.map → p-42c0e318.entry.js.map} +0 -0
  477. /package/dist/core/{p-2b24b4bf.entry.js.map → p-4421203e.entry.js.map} +0 -0
  478. /package/dist/core/{p-11736fbe.entry.js.map → p-4f1792a6.entry.js.map} +0 -0
  479. /package/dist/core/{p-b39ecae2.entry.js.map → p-4f8b7aa3.entry.js.map} +0 -0
  480. /package/dist/core/{p-8a83f391.entry.js.map → p-525323ab.entry.js.map} +0 -0
  481. /package/dist/core/{p-c2452388.entry.js.map → p-5894f6aa.entry.js.map} +0 -0
  482. /package/dist/core/{p-e9738c74.entry.js.map → p-59c4bc0a.entry.js.map} +0 -0
  483. /package/dist/core/{p-60c4604f.entry.js.map → p-5adaf5c3.entry.js.map} +0 -0
  484. /package/dist/core/{p-95a864bf.js.map → p-671b7cac.js.map} +0 -0
  485. /package/dist/core/{p-fdb4b48f.entry.js.map → p-783c2ced.entry.js.map} +0 -0
  486. /package/dist/core/{p-f2e6b9ef.entry.js.map → p-7b720034.entry.js.map} +0 -0
  487. /package/dist/core/{p-22c024ee.entry.js.map → p-7c724f2c.entry.js.map} +0 -0
  488. /package/dist/core/{p-335fc5e4.entry.js.map → p-8146336b.entry.js.map} +0 -0
  489. /package/dist/core/{p-cd8de4c5.entry.js.map → p-8931210a.entry.js.map} +0 -0
  490. /package/dist/core/{p-529d8955.entry.js.map → p-8a66cab4.entry.js.map} +0 -0
  491. /package/dist/core/{p-ca48e97a.entry.js.map → p-8be3ec3d.entry.js.map} +0 -0
  492. /package/dist/core/{p-180e36b1.entry.js.map → p-8c2322a9.entry.js.map} +0 -0
  493. /package/dist/core/{p-edd29edc.entry.js.map → p-9184e385.entry.js.map} +0 -0
  494. /package/dist/core/{p-366bcb17.entry.js.map → p-9ee138e7.entry.js.map} +0 -0
  495. /package/dist/core/{p-e5abfadd.entry.js.map → p-b7a2e604.entry.js.map} +0 -0
  496. /package/dist/core/{p-b0088956.entry.js.map → p-bb41b637.entry.js.map} +0 -0
  497. /package/dist/core/{p-cfc930f6.entry.js.map → p-c75d6022.entry.js.map} +0 -0
  498. /package/dist/core/{p-f0809037.entry.js.map → p-c786d62f.entry.js.map} +0 -0
  499. /package/dist/core/{p-edec0936.entry.js.map → p-c7a08024.entry.js.map} +0 -0
  500. /package/dist/core/{p-6eb0421d.entry.js.map → p-cf798ea7.entry.js.map} +0 -0
  501. /package/dist/core/{p-287ab47c.entry.js.map → p-de87d585.entry.js.map} +0 -0
  502. /package/dist/core/{p-15624e08.entry.js.map → p-e4d827d4.entry.js.map} +0 -0
  503. /package/dist/core/{p-765bdd98.entry.js.map → p-e9723eaa.entry.js.map} +0 -0
  504. /package/dist/core/{p-498eb7ad.entry.js.map → p-eb2d06c1.entry.js.map} +0 -0
  505. /package/dist/core/{p-94e88827.entry.js.map → p-f9452975.entry.js.map} +0 -0
@@ -1,82 +0,0 @@
1
- import { newE2EPage } from "@stencil/core/testing";
2
- describe("ic-toast component", () => {
3
- it("should close on dismiss icon click", async () => {
4
- const page = await newE2EPage();
5
- await page.setContent(`<ic-toast heading="Heading"></ic-toast>`);
6
- await page.waitForChanges();
7
- let toast = await page.find("ic-toast");
8
- await toast.callMethod("setVisible");
9
- await page.waitForChanges();
10
- expect(toast).not.toHaveClass("hidden");
11
- const dismissButton = await page.find("ic-toast >>> ic-button");
12
- expect(dismissButton).not.toBeNull();
13
- await dismissButton.click();
14
- toast = await page.find("ic-toast");
15
- expect(toast).toHaveClass("hidden");
16
- });
17
- it("should focus slotted action element when opened if an action is provided", async () => {
18
- const page = await newE2EPage();
19
- await page.setContent(`<ic-toast heading="Heading"><ic-button id="button1" slot="action">Button</ic-button></ic-toast>`);
20
- await page.waitForChanges();
21
- const toast = await page.find("ic-toast");
22
- await toast.callMethod("setVisible");
23
- await page.waitForChanges();
24
- await page.waitForTimeout(300);
25
- const slottedButton = await page.find("ic-button");
26
- expect(slottedButton).not.toBeNull;
27
- const activeElement = await page.evaluate(() => document.activeElement.id);
28
- expect(activeElement).toBe("button1");
29
- });
30
- it("should focus the dismiss button when opened if no action is provided", async () => {
31
- const page = await newE2EPage();
32
- await page.setContent(`<ic-toast heading="Heading"></ic-toast>`);
33
- await page.waitForChanges();
34
- const toast = await page.find("ic-toast");
35
- await toast.callMethod("setVisible");
36
- await page.waitForChanges();
37
- await page.waitForTimeout(300);
38
- const activeElement = await page.$eval("ic-toast", (el) => el.shadowRoot.activeElement.id);
39
- expect(activeElement).toBe("dismiss-button");
40
- });
41
- it("should set the dimissMode to manual if the action slot is used on an autoDismiss toast", async () => {
42
- const page = await newE2EPage();
43
- await page.setContent(`<ic-toast heading="Heading" dismiss-mode="automatic"><ic-button slot="action">Button</ic-button></ic-toast>`);
44
- await page.waitForChanges();
45
- const dismissMode = await page.$eval("ic-toast", (el) => el.dismissMode);
46
- expect(dismissMode).toBe("manual");
47
- });
48
- it("should set the variant to neutral if the neutral-icon slot is used when the variant isn't set", async () => {
49
- const page = await newE2EPage();
50
- await page.setContent(`<ic-toast heading="Heading">
51
- <svg
52
- slot="neutral-icon"
53
- width="24"
54
- height="24"
55
- viewBox="0 0 24 24"
56
- fill="none"
57
- xmlns="http://www.w3.org/2000/svg"
58
- >
59
- <path
60
- d="M8.79502 15.875L4.62502 11.705L3.20502 13.115L8.79502 18.705L20.795 6.70501L19.385 5.29501L8.79502 15.875Z"
61
- />
62
- </svg></ic-toast>`);
63
- await page.waitForChanges();
64
- const variant = await page.$eval("ic-toast", (el) => el.variant);
65
- expect(variant).toBe("neutral");
66
- });
67
- it("should set the autoDismissTimeout to 5000ms if the prop provided is below", async () => {
68
- const page = await newE2EPage();
69
- await page.setContent(`<ic-toast heading="Heading" auto-dismiss-timeout="100"></ic-toast>`);
70
- await page.waitForChanges();
71
- const variant = await page.$eval("ic-toast", (el) => el.autoDismissTimeout);
72
- expect(variant).toBe(5000);
73
- });
74
- it("should not render an icon if the variant is neutral and the neutral-icon slot is not used", async () => {
75
- const page = await newE2EPage();
76
- await page.setContent(`<ic-toast heading="Heading" variant="neutral"></ic-toast>`);
77
- await page.waitForChanges();
78
- const icon = await page.find("ic-toast >>> span");
79
- expect(icon).toBeNull();
80
- });
81
- });
82
- //# sourceMappingURL=ic-toast.e2e.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ic-toast.e2e.js","sourceRoot":"","sources":["../../../../../src/components/ic-toast/test/basic/ic-toast.e2e.ts"],"names":[],"mappings":"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","sourcesContent":["import { newE2EPage } from \"@stencil/core/testing\";\n\ndescribe(\"ic-toast component\", () => {\n it(\"should close on dismiss icon click\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-toast heading=\"Heading\"></ic-toast>`);\n await page.waitForChanges();\n\n let toast = await page.find(\"ic-toast\");\n await toast.callMethod(\"setVisible\");\n\n await page.waitForChanges();\n expect(toast).not.toHaveClass(\"hidden\");\n\n const dismissButton = await page.find(\"ic-toast >>> ic-button\");\n expect(dismissButton).not.toBeNull();\n\n await dismissButton.click();\n\n toast = await page.find(\"ic-toast\");\n expect(toast).toHaveClass(\"hidden\");\n });\n\n it(\"should focus slotted action element when opened if an action is provided\", async () => {\n const page = await newE2EPage();\n await page.setContent(\n `<ic-toast heading=\"Heading\"><ic-button id=\"button1\" slot=\"action\">Button</ic-button></ic-toast>`\n );\n await page.waitForChanges();\n\n const toast = await page.find(\"ic-toast\");\n await toast.callMethod(\"setVisible\");\n\n await page.waitForChanges();\n await page.waitForTimeout(300);\n\n const slottedButton = await page.find(\"ic-button\");\n expect(slottedButton).not.toBeNull;\n\n const activeElement = await page.evaluate(() => document.activeElement.id);\n expect(activeElement).toBe(\"button1\");\n });\n\n it(\"should focus the dismiss button when opened if no action is provided\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-toast heading=\"Heading\"></ic-toast>`);\n await page.waitForChanges();\n\n const toast = await page.find(\"ic-toast\");\n await toast.callMethod(\"setVisible\");\n\n await page.waitForChanges();\n await page.waitForTimeout(300);\n\n const activeElement = await page.$eval(\n \"ic-toast\",\n (el) => el.shadowRoot.activeElement.id\n );\n expect(activeElement).toBe(\"dismiss-button\");\n });\n\n it(\"should set the dimissMode to manual if the action slot is used on an autoDismiss toast\", async () => {\n const page = await newE2EPage();\n await page.setContent(\n `<ic-toast heading=\"Heading\" dismiss-mode=\"automatic\"><ic-button slot=\"action\">Button</ic-button></ic-toast>`\n );\n await page.waitForChanges();\n\n const dismissMode = await page.$eval(\n \"ic-toast\",\n (el) => (el as HTMLIcToastElement).dismissMode\n );\n expect(dismissMode).toBe(\"manual\");\n });\n\n it(\"should set the variant to neutral if the neutral-icon slot is used when the variant isn't set\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-toast heading=\"Heading\">\n <svg\n slot=\"neutral-icon\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M8.79502 15.875L4.62502 11.705L3.20502 13.115L8.79502 18.705L20.795 6.70501L19.385 5.29501L8.79502 15.875Z\"\n />\n </svg></ic-toast>`);\n await page.waitForChanges();\n\n const variant = await page.$eval(\n \"ic-toast\",\n (el) => (el as HTMLIcToastElement).variant\n );\n expect(variant).toBe(\"neutral\");\n });\n\n it(\"should set the autoDismissTimeout to 5000ms if the prop provided is below\", async () => {\n const page = await newE2EPage();\n await page.setContent(\n `<ic-toast heading=\"Heading\" auto-dismiss-timeout=\"100\"></ic-toast>`\n );\n await page.waitForChanges();\n\n const variant = await page.$eval(\n \"ic-toast\",\n (el) => (el as HTMLIcToastElement).autoDismissTimeout\n );\n expect(variant).toBe(5000);\n });\n\n it(\"should not render an icon if the variant is neutral and the neutral-icon slot is not used\", async () => {\n const page = await newE2EPage();\n await page.setContent(\n `<ic-toast heading=\"Heading\" variant=\"neutral\"></ic-toast>`\n );\n await page.waitForChanges();\n\n const icon = await page.find(\"ic-toast >>> span\");\n expect(icon).toBeNull();\n });\n});\n"]}
@@ -1,32 +0,0 @@
1
- import { fixture } from "@open-wc/testing-helpers";
2
- import { axe } from "jest-axe";
3
- import { checkShadowElementRendersCorrectly } from "../../../../utils/testa11y.helpers";
4
- beforeEach(() => {
5
- // IntersectionObserver isn't available in test environment
6
- const mockResizeObserver = jest.fn();
7
- mockResizeObserver.mockReturnValue({
8
- observe: jest.fn().mockReturnValue(null),
9
- unobserve: jest.fn().mockReturnValue(null),
10
- disconnect: jest.fn().mockReturnValue(null),
11
- });
12
- window.ResizeObserver = mockResizeObserver;
13
- const matchMedia = jest.fn().mockReturnValue(true);
14
- window.matchMedia = matchMedia;
15
- });
16
- describe("ic-top-navigation", () => {
17
- it("passes accessibility", async () => {
18
- const el = await fixture(`
19
- <ic-top-navigation app-title="A11y test title"/>
20
- `);
21
- checkShadowElementRendersCorrectly(el);
22
- expect(await axe(el)).toHaveNoViolations();
23
- });
24
- it("passes accessibility with short title prop set", async () => {
25
- const el = await fixture(`
26
- <ic-top-navigation app-title="A11y test title" short-app-title="A11y"/>
27
- `);
28
- checkShadowElementRendersCorrectly(el);
29
- expect(await axe(el)).toHaveNoViolations();
30
- });
31
- });
32
- //# sourceMappingURL=ic-top-navigation.test.a11y.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ic-top-navigation.test.a11y.js","sourceRoot":"","sources":["../../../../../src/components/ic-top-navigation/test/a11y/ic-top-navigation.test.a11y.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,kCAAkC,EAAE,MAAM,oCAAoC,CAAC;AAExF,UAAU,CAAC,GAAG,EAAE;IACd,2DAA2D;IAC3D,MAAM,kBAAkB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;IACrC,kBAAkB,CAAC,eAAe,CAAC;QACjC,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC;QACxC,SAAS,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC;QAC1C,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC;KAC5C,CAAC,CAAC;IACH,MAAM,CAAC,cAAc,GAAG,kBAAkB,CAAC;IAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;IACnD,MAAM,CAAC,UAAU,GAAG,UAAU,CAAC;AACjC,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,EAAE,CAAC,sBAAsB,EAAE,KAAK,IAAI,EAAE;QACpC,MAAM,EAAE,GAAG,MAAM,OAAO,CAAC;;KAExB,CAAC,CAAC;QACH,kCAAkC,CAAC,EAAE,CAAC,CAAC;QACvC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,kBAAkB,EAAE,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,KAAK,IAAI,EAAE;QAC9D,MAAM,EAAE,GAAG,MAAM,OAAO,CAAC;;KAExB,CAAC,CAAC;QACH,kCAAkC,CAAC,EAAE,CAAC,CAAC;QACvC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,kBAAkB,EAAE,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { fixture } from \"@open-wc/testing-helpers\";\nimport { axe } from \"jest-axe\";\nimport { checkShadowElementRendersCorrectly } from \"../../../../utils/testa11y.helpers\";\n\nbeforeEach(() => {\n // IntersectionObserver isn't available in test environment\n const mockResizeObserver = jest.fn();\n mockResizeObserver.mockReturnValue({\n observe: jest.fn().mockReturnValue(null),\n unobserve: jest.fn().mockReturnValue(null),\n disconnect: jest.fn().mockReturnValue(null),\n });\n window.ResizeObserver = mockResizeObserver;\n const matchMedia = jest.fn().mockReturnValue(true);\n window.matchMedia = matchMedia;\n});\n\ndescribe(\"ic-top-navigation\", () => {\n it(\"passes accessibility\", async () => {\n const el = await fixture(`\n <ic-top-navigation app-title=\"A11y test title\"/>\n `);\n checkShadowElementRendersCorrectly(el);\n expect(await axe(el)).toHaveNoViolations();\n });\n\n it(\"passes accessibility with short title prop set\", async () => {\n const el = await fixture(`\n <ic-top-navigation app-title=\"A11y test title\" short-app-title=\"A11y\"/>\n `);\n checkShadowElementRendersCorrectly(el);\n expect(await axe(el)).toHaveNoViolations();\n });\n});\n"]}
@@ -1,61 +0,0 @@
1
- import { newE2EPage } from "@stencil/core/testing";
2
- const pageWidth = 1200;
3
- const pageHeight = 600;
4
- describe("ic-top-navigation", () => {
5
- it("renders", async () => {
6
- const page = await newE2EPage();
7
- await page.setContent(`<ic-top-navigation app-title="ApplicationName" status="alpha"
8
- version="v0.0.7"></ic-top-navigation>`);
9
- const element = await page.find("ic-top-navigation");
10
- expect(element).toHaveClass("hydrated");
11
- });
12
- it("should hide dropdown menu when nav item clicked", async () => {
13
- const page = await newE2EPage();
14
- await page.setContent(`<ic-top-navigation app-title="ApplicationName" status="alpha"
15
- version="v0.0.7">
16
- <ic-navigation-group slot="navigation" label="Navigation group" expandable="true">
17
- <ic-navigation-item
18
- label="Navigation"
19
- slot="navigation"
20
- ></ic-navigation-item>
21
- </ic-navigation-group>
22
- </ic-top-navigation>`);
23
- await page.setViewport({
24
- width: pageWidth,
25
- height: pageHeight,
26
- });
27
- await page.waitForChanges();
28
- const navGroup = await page.find("ic-top-navigation ic-navigation-group");
29
- await navGroup.press("Enter");
30
- await page.waitForChanges();
31
- let dropDownDiv = await page.find("ic-navigation-group >>> .navigation-group-dropdown");
32
- expect(dropDownDiv).not.toBeNull();
33
- await page.evaluate(() => {
34
- const navItemComp = document.querySelector("ic-navigation-item");
35
- navItemComp.click();
36
- });
37
- await page.waitForChanges();
38
- dropDownDiv = await page.find("ic-navigation-group >>> .navigation-group-dropdown");
39
- expect(dropDownDiv).toBeNull();
40
- });
41
- it("should toggle to short title at small screen sizes", async () => {
42
- const page = await newE2EPage();
43
- await page.setContent(`<ic-top-navigation app-title="ApplicationName" short-app-title="AppName">
44
- </ic-top-navigation>`);
45
- await page.setViewport({
46
- width: 576,
47
- height: pageHeight,
48
- });
49
- await page.waitForChanges();
50
- let appTitle = await page.find("ic-top-navigation >>> .title-link ic-typography");
51
- expect(appTitle.textContent).toBe("AppName");
52
- await page.setViewport({
53
- width: 1200,
54
- height: pageHeight,
55
- });
56
- await page.waitForChanges();
57
- appTitle = await page.find("ic-top-navigation >>> .title-link ic-typography");
58
- expect(appTitle.textContent).toBe("ApplicationName");
59
- });
60
- });
61
- //# sourceMappingURL=ic-top-navigation.e2e.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ic-top-navigation.e2e.js","sourceRoot":"","sources":["../../../../../src/components/ic-top-navigation/test/basic/ic-top-navigation.e2e.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAEnD,MAAM,SAAS,GAAG,IAAI,CAAC;AACvB,MAAM,UAAU,GAAG,GAAG,CAAC;AAEvB,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,EAAE,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;QACvB,MAAM,IAAI,GAAG,MAAM,UAAU,EAAE,CAAC;QAChC,MAAM,IAAI,CAAC,UAAU,CAAC;0CACgB,CAAC,CAAC;QAExC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAErD,MAAM,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,IAAI,GAAG,MAAM,UAAU,EAAE,CAAC;QAChC,MAAM,IAAI,CAAC,UAAU,CAAC;;;;;;;;yBAQD,CAAC,CAAC;QAEvB,MAAM,IAAI,CAAC,WAAW,CAAC;YACrB,KAAK,EAAE,SAAS;YAChB,MAAM,EAAE,UAAU;SACnB,CAAC,CAAC;QAEH,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5B,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,uCAAuC,CAAC,CAAC;QAE1E,MAAM,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAE9B,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5B,IAAI,WAAW,GAAG,MAAM,IAAI,CAAC,IAAI,CAC/B,oDAAoD,CACrD,CAAC;QACF,MAAM,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAEnC,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE;YACvB,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC;YACjE,WAAW,CAAC,KAAK,EAAE,CAAC;QACtB,CAAC,CAAC,CAAC;QAEH,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5B,WAAW,GAAG,MAAM,IAAI,CAAC,IAAI,CAC3B,oDAAoD,CACrD,CAAC;QACF,MAAM,CAAC,WAAW,CAAC,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE,KAAK,IAAI,EAAE;QAClE,MAAM,IAAI,GAAG,MAAM,UAAU,EAAE,CAAC;QAChC,MAAM,IAAI,CAAC,UAAU,CAAC;yBACD,CAAC,CAAC;QAEvB,MAAM,IAAI,CAAC,WAAW,CAAC;YACrB,KAAK,EAAE,GAAG;YACV,MAAM,EAAE,UAAU;SACnB,CAAC,CAAC;QAEH,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5B,IAAI,QAAQ,GAAG,MAAM,IAAI,CAAC,IAAI,CAC5B,iDAAiD,CAClD,CAAC;QAEF,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAE7C,MAAM,IAAI,CAAC,WAAW,CAAC;YACrB,KAAK,EAAE,IAAI;YACX,MAAM,EAAE,UAAU;SACnB,CAAC,CAAC;QAEH,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5B,QAAQ,GAAG,MAAM,IAAI,CAAC,IAAI,CACxB,iDAAiD,CAClD,CAAC;QAEF,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newE2EPage } from \"@stencil/core/testing\";\n\nconst pageWidth = 1200;\nconst pageHeight = 600;\n\ndescribe(\"ic-top-navigation\", () => {\n it(\"renders\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-top-navigation app-title=\"ApplicationName\" status=\"alpha\"\n version=\"v0.0.7\"></ic-top-navigation>`);\n\n const element = await page.find(\"ic-top-navigation\");\n\n expect(element).toHaveClass(\"hydrated\");\n });\n\n it(\"should hide dropdown menu when nav item clicked\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-top-navigation app-title=\"ApplicationName\" status=\"alpha\"\n version=\"v0.0.7\">\n <ic-navigation-group slot=\"navigation\" label=\"Navigation group\" expandable=\"true\">\n <ic-navigation-item\n label=\"Navigation\"\n slot=\"navigation\"\n ></ic-navigation-item>\n </ic-navigation-group>\n </ic-top-navigation>`);\n\n await page.setViewport({\n width: pageWidth,\n height: pageHeight,\n });\n\n await page.waitForChanges();\n\n const navGroup = await page.find(\"ic-top-navigation ic-navigation-group\");\n\n await navGroup.press(\"Enter\");\n\n await page.waitForChanges();\n\n let dropDownDiv = await page.find(\n \"ic-navigation-group >>> .navigation-group-dropdown\"\n );\n expect(dropDownDiv).not.toBeNull();\n\n await page.evaluate(() => {\n const navItemComp = document.querySelector(\"ic-navigation-item\");\n navItemComp.click();\n });\n\n await page.waitForChanges();\n\n dropDownDiv = await page.find(\n \"ic-navigation-group >>> .navigation-group-dropdown\"\n );\n expect(dropDownDiv).toBeNull();\n });\n\n it(\"should toggle to short title at small screen sizes\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-top-navigation app-title=\"ApplicationName\" short-app-title=\"AppName\">\n </ic-top-navigation>`);\n\n await page.setViewport({\n width: 576,\n height: pageHeight,\n });\n\n await page.waitForChanges();\n\n let appTitle = await page.find(\n \"ic-top-navigation >>> .title-link ic-typography\"\n );\n\n expect(appTitle.textContent).toBe(\"AppName\");\n\n await page.setViewport({\n width: 1200,\n height: pageHeight,\n });\n\n await page.waitForChanges();\n\n appTitle = await page.find(\n \"ic-top-navigation >>> .title-link ic-typography\"\n );\n\n expect(appTitle.textContent).toBe(\"ApplicationName\");\n });\n});\n"]}
@@ -1,244 +0,0 @@
1
- import { newE2EPage } from "@stencil/core/testing";
2
- const pageWidth = 640;
3
- const pageHeight = 480;
4
- const searchBarVisibleHeight = 40;
5
- const searchBarHiddenHeight = 0;
6
- describe("ic-top-navigation on mobile", () => {
7
- it("renders", async () => {
8
- const page = await newE2EPage();
9
- await page.setContent(`<ic-top-navigation app-title="ApplicationName" status="alpha"
10
- version="v0.0.7"></ic-top-navigation>`);
11
- await page.setViewport({
12
- width: pageWidth,
13
- height: pageHeight,
14
- });
15
- const menuBtn = await page.find("ic-top-navigation >>> .menu-button-container ic-button");
16
- expect(menuBtn).not.toBeNull();
17
- });
18
- it("should open and close menu", async () => {
19
- const page = await newE2EPage();
20
- await page.setContent(`<ic-top-navigation app-title="ApplicationName" status="alpha"
21
- version="v0.0.7"></ic-top-navigation>`);
22
- await page.setViewport({
23
- width: pageWidth,
24
- height: pageHeight,
25
- });
26
- const menuBtn = await page.find("ic-top-navigation >>> .menu-button-container ic-button");
27
- expect(menuBtn).not.toBeNull();
28
- const icNavigationMenuOpened = await page.spyOnEvent("icNavigationMenuOpened");
29
- await menuBtn.click();
30
- await page.waitForChanges();
31
- let menu = await page.find("ic-top-navigation >>> ic-navigation-menu");
32
- expect(menu).not.toBeNull();
33
- expect(icNavigationMenuOpened).toHaveReceivedEvent();
34
- const activeElId = await page.$eval("ic-top-navigation", (el) => {
35
- const menu = el.shadowRoot.querySelector("ic-navigation-menu");
36
- return menu.shadowRoot.activeElement.id;
37
- });
38
- expect(activeElId).toBe("menu-close-button");
39
- const icNavigationMenuClosed = await page.spyOnEvent("icNavigationMenuClosed");
40
- await page.evaluate(() => {
41
- const navbar = document.querySelector("ic-top-navigation");
42
- const menu = navbar.shadowRoot.querySelector("ic-navigation-menu");
43
- const closeBtn = menu.shadowRoot.querySelector("ic-button");
44
- closeBtn.click();
45
- });
46
- await page.waitForChanges();
47
- menu = await page.find("ic-top-navigation >>> ic-navigation-menu");
48
- expect(menu).toBeNull();
49
- expect(icNavigationMenuClosed).toHaveReceivedEvent();
50
- });
51
- it("should close menu when nav item clicked", async () => {
52
- const page = await newE2EPage();
53
- await page.setContent(`<ic-top-navigation app-title="ApplicationName" status="alpha"
54
- version="v0.0.7">
55
- <ic-navigation-item
56
- label="Navigation"
57
- slot="navigation"
58
- href="#"
59
- ></ic-navigation-item>
60
- </ic-top-navigation>`);
61
- await page.setViewport({
62
- width: pageWidth,
63
- height: pageHeight,
64
- });
65
- const menuBtn = await page.find("ic-top-navigation >>> .menu-button-container ic-button");
66
- expect(menuBtn).not.toBeNull();
67
- const icNavigationMenuOpened = await page.spyOnEvent("icNavigationMenuOpened");
68
- await menuBtn.click();
69
- await page.waitForChanges();
70
- let menu = await page.find("ic-top-navigation >>> ic-navigation-menu");
71
- expect(menu).not.toBeNull();
72
- expect(icNavigationMenuOpened).toHaveReceivedEvent();
73
- const icNavigationMenuClosed = await page.spyOnEvent("icNavigationMenuClosed");
74
- const navItem = await page.find("ic-navigation-item");
75
- await page.waitForTimeout(5000);
76
- await navItem.click();
77
- await page.waitForChanges();
78
- menu = await page.find("ic-top-navigation >>> ic-navigation-menu");
79
- expect(menu).toBeNull();
80
- expect(icNavigationMenuClosed).toHaveReceivedEvent();
81
- });
82
- it("should keep tab focus in menu - button as last el", async () => {
83
- const page = await newE2EPage();
84
- await page.setContent(`<ic-top-navigation app-title="ApplicationName" status="alpha"
85
- version="v0.0.7">
86
- <ic-navigation-button
87
- label="button1"
88
- slot="buttons"
89
- onclick="alert('test')"
90
- >
91
- <svg
92
- slot="icon"
93
- xmlns="http://www.w3.org/2000/svg"
94
- height="24px"
95
- viewBox="0 0 24 24"
96
- width="24px"
97
- fill="#000000"
98
- >
99
- <path d="M0 0h24v24H0V0z" fill="none" />
100
- <path
101
- d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zm-5.5-2.5l7.51-3.49L17.5 6.5 9.99 9.99 6.5 17.5zm5.5-6.6c.61 0 1.1.49 1.1 1.1s-.49 1.1-1.1 1.1-1.1-.49-1.1-1.1.49-1.1 1.1-1.1z"
102
- />
103
- </svg>
104
- </ic-navigation-button>
105
- </ic-top-navigation>`);
106
- await page.setViewport({
107
- width: pageWidth,
108
- height: pageHeight,
109
- });
110
- const menuBtn = await page.find("ic-top-navigation >>> .menu-button-container ic-button");
111
- expect(menuBtn).not.toBeNull();
112
- await menuBtn.click();
113
- await page.waitForChanges();
114
- const menu = await page.find("ic-top-navigation >>> ic-navigation-menu");
115
- expect(menu).not.toBeNull();
116
- let activeElId = await page.$eval("ic-top-navigation", (el) => {
117
- const menu = el.shadowRoot.querySelector("ic-navigation-menu");
118
- return menu.shadowRoot.activeElement.id;
119
- });
120
- expect(activeElId).toBe("menu-close-button");
121
- await page.keyboard.press("Tab");
122
- await page.waitForChanges();
123
- activeElId = await page.$eval("ic-navigation-button", (el) => {
124
- const button = el.shadowRoot.querySelector("ic-button");
125
- return button.shadowRoot.activeElement.getAttribute("aria-label");
126
- });
127
- expect(activeElId).toBe("button1");
128
- await page.keyboard.press("Tab");
129
- await page.waitForChanges();
130
- activeElId = await page.$eval("ic-top-navigation", (el) => {
131
- const menu = el.shadowRoot.querySelector("ic-navigation-menu");
132
- return menu.shadowRoot.activeElement.id;
133
- });
134
- expect(activeElId).toBe("menu-close-button");
135
- page.keyboard.down("Shift");
136
- await page.keyboard.press("Tab");
137
- await page.waitForChanges();
138
- activeElId = await page.$eval("ic-navigation-button", (el) => {
139
- const button = el.shadowRoot.querySelector("ic-button");
140
- return button.shadowRoot.activeElement.getAttribute("aria-label");
141
- });
142
- expect(activeElId).toBe("button1");
143
- });
144
- it("should keep tab focus in menu - nav item as last el", async () => {
145
- const page = await newE2EPage();
146
- await page.setContent(`<ic-top-navigation app-title="ApplicationName" status="alpha"
147
- version="v0.0.7">
148
- <ic-navigation-item
149
- label="Navigation"
150
- href="/"
151
- slot="navigation"
152
- ></ic-navigation-item>
153
- </ic-top-navigation>`);
154
- await page.setViewport({
155
- width: pageWidth,
156
- height: pageHeight,
157
- });
158
- const menuBtn = await page.find("ic-top-navigation >>> .menu-button-container ic-button");
159
- expect(menuBtn).not.toBeNull();
160
- await menuBtn.click();
161
- await page.waitForChanges();
162
- const menu = await page.find("ic-top-navigation >>> ic-navigation-menu");
163
- expect(menu).not.toBeNull();
164
- let activeElId = await page.$eval("ic-top-navigation", (el) => {
165
- const menu = el.shadowRoot.querySelector("ic-navigation-menu");
166
- return menu.shadowRoot.activeElement.id;
167
- });
168
- expect(activeElId).toBe("menu-close-button");
169
- await page.keyboard.press("Tab");
170
- await page.waitForChanges();
171
- activeElId = await page.$eval("ic-navigation-item", (el) => {
172
- return el.shadowRoot.activeElement.textContent;
173
- });
174
- expect(activeElId).toBe("Navigation");
175
- await page.keyboard.press("Tab");
176
- await page.waitForChanges();
177
- activeElId = await page.$eval("ic-top-navigation", (el) => {
178
- const menu = el.shadowRoot.querySelector("ic-navigation-menu");
179
- return menu.shadowRoot.activeElement.id;
180
- });
181
- expect(activeElId).toBe("menu-close-button");
182
- page.keyboard.down("Shift");
183
- await page.keyboard.press("Tab");
184
- await page.waitForChanges();
185
- activeElId = await page.$eval("ic-navigation-item", (el) => {
186
- return el.shadowRoot.activeElement.textContent;
187
- });
188
- expect(activeElId).toBe("Navigation");
189
- });
190
- it("should toggle search bar when clicking on button", async () => {
191
- const page = await newE2EPage();
192
- await page.setContent(`<ic-top-navigation app-title="ApplicationName" status="alpha"
193
- version="v0.0.7">
194
- <ic-search-bar slot="search" label="Search" placeholder="Search" focusOnLoad="true"></ic-search-bar>
195
- </ic-top-navigation>`);
196
- await page.setViewport({
197
- width: pageWidth,
198
- height: pageHeight,
199
- });
200
- const searchBtn = await page.find("ic-top-navigation >>> .search-actions-container ic-button");
201
- expect(searchBtn).not.toBeNull();
202
- await searchBtn.click();
203
- await page.waitForChanges();
204
- let searchBarHeight = await page.$eval("ic-search-bar", (el) => {
205
- return el.clientHeight;
206
- });
207
- expect(searchBarHeight).toBe(searchBarVisibleHeight);
208
- await searchBtn.click();
209
- await page.waitForChanges();
210
- searchBarHeight = await page.$eval("ic-search-bar", (el) => {
211
- return el.clientHeight;
212
- });
213
- expect(searchBarHeight).toBe(searchBarHiddenHeight);
214
- });
215
- it("should hide search bar when loses focus", async () => {
216
- const page = await newE2EPage();
217
- await page.setContent(`<ic-top-navigation app-title="ApplicationName" status="alpha"
218
- version="v0.0.7">
219
- <ic-search-bar slot="search" label="Search" placeholder="Search" focusOnLoad="true"></ic-search-bar>
220
- </ic-top-navigation>
221
- <span id='othercontent'>some other content</span>`);
222
- await page.setViewport({
223
- width: pageWidth,
224
- height: pageHeight,
225
- });
226
- const searchBtn = await page.find("ic-top-navigation >>> .search-actions-container ic-button");
227
- expect(searchBtn).not.toBeNull();
228
- await searchBtn.click();
229
- await page.waitForChanges();
230
- let searchBarHeight = await page.$eval("ic-search-bar", (el) => {
231
- return el.clientHeight;
232
- });
233
- expect(searchBarHeight).toBe(searchBarVisibleHeight);
234
- // Test hides when another page element clicked
235
- const spanEl = await page.find("#othercontent");
236
- await spanEl.click();
237
- await page.waitForChanges();
238
- searchBarHeight = await page.$eval("ic-search-bar", (el) => {
239
- return el.clientHeight;
240
- });
241
- expect(searchBarHeight).toBe(searchBarHiddenHeight);
242
- });
243
- });
244
- //# sourceMappingURL=ic-top-navigation.mobile.e2e.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ic-top-navigation.mobile.e2e.js","sourceRoot":"","sources":["../../../../../src/components/ic-top-navigation/test/basic/ic-top-navigation.mobile.e2e.ts"],"names":[],"mappings":"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","sourcesContent":["import { newE2EPage } from \"@stencil/core/testing\";\n\nconst pageWidth = 640;\nconst pageHeight = 480;\nconst searchBarVisibleHeight = 40;\nconst searchBarHiddenHeight = 0;\n\ndescribe(\"ic-top-navigation on mobile\", () => {\n it(\"renders\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-top-navigation app-title=\"ApplicationName\" status=\"alpha\"\n version=\"v0.0.7\"></ic-top-navigation>`);\n\n await page.setViewport({\n width: pageWidth,\n height: pageHeight,\n });\n\n const menuBtn = await page.find(\n \"ic-top-navigation >>> .menu-button-container ic-button\"\n );\n expect(menuBtn).not.toBeNull();\n });\n\n it(\"should open and close menu\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-top-navigation app-title=\"ApplicationName\" status=\"alpha\"\n version=\"v0.0.7\"></ic-top-navigation>`);\n\n await page.setViewport({\n width: pageWidth,\n height: pageHeight,\n });\n\n const menuBtn = await page.find(\n \"ic-top-navigation >>> .menu-button-container ic-button\"\n );\n expect(menuBtn).not.toBeNull();\n\n const icNavigationMenuOpened = await page.spyOnEvent(\n \"icNavigationMenuOpened\"\n );\n await menuBtn.click();\n await page.waitForChanges();\n let menu = await page.find(\"ic-top-navigation >>> ic-navigation-menu\");\n expect(menu).not.toBeNull();\n expect(icNavigationMenuOpened).toHaveReceivedEvent();\n\n const activeElId = await page.$eval(\"ic-top-navigation\", (el) => {\n const menu = el.shadowRoot.querySelector(\"ic-navigation-menu\");\n return menu.shadowRoot.activeElement.id;\n });\n\n expect(activeElId).toBe(\"menu-close-button\");\n\n const icNavigationMenuClosed = await page.spyOnEvent(\n \"icNavigationMenuClosed\"\n );\n\n await page.evaluate(() => {\n const navbar = document.querySelector(\"ic-top-navigation\");\n const menu = navbar.shadowRoot.querySelector(\"ic-navigation-menu\");\n const closeBtn = menu.shadowRoot.querySelector(\"ic-button\");\n closeBtn.click();\n });\n\n await page.waitForChanges();\n menu = await page.find(\"ic-top-navigation >>> ic-navigation-menu\");\n expect(menu).toBeNull();\n expect(icNavigationMenuClosed).toHaveReceivedEvent();\n });\n\n it(\"should close menu when nav item clicked\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-top-navigation app-title=\"ApplicationName\" status=\"alpha\"\n version=\"v0.0.7\">\n <ic-navigation-item\n label=\"Navigation\"\n slot=\"navigation\"\n href=\"#\"\n ></ic-navigation-item>\n </ic-top-navigation>`);\n\n await page.setViewport({\n width: pageWidth,\n height: pageHeight,\n });\n\n const menuBtn = await page.find(\n \"ic-top-navigation >>> .menu-button-container ic-button\"\n );\n expect(menuBtn).not.toBeNull();\n\n const icNavigationMenuOpened = await page.spyOnEvent(\n \"icNavigationMenuOpened\"\n );\n await menuBtn.click();\n await page.waitForChanges();\n\n let menu = await page.find(\"ic-top-navigation >>> ic-navigation-menu\");\n expect(menu).not.toBeNull();\n expect(icNavigationMenuOpened).toHaveReceivedEvent();\n\n const icNavigationMenuClosed = await page.spyOnEvent(\n \"icNavigationMenuClosed\"\n );\n\n const navItem = await page.find(\"ic-navigation-item\");\n await page.waitForTimeout(5000);\n await navItem.click();\n await page.waitForChanges();\n\n menu = await page.find(\"ic-top-navigation >>> ic-navigation-menu\");\n expect(menu).toBeNull();\n expect(icNavigationMenuClosed).toHaveReceivedEvent();\n });\n\n it(\"should keep tab focus in menu - button as last el\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-top-navigation app-title=\"ApplicationName\" status=\"alpha\"\n version=\"v0.0.7\">\n <ic-navigation-button\n label=\"button1\"\n slot=\"buttons\"\n onclick=\"alert('test')\"\n >\n <svg\n slot=\"icon\"\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24px\"\n viewBox=\"0 0 24 24\"\n width=\"24px\"\n fill=\"#000000\"\n >\n <path d=\"M0 0h24v24H0V0z\" fill=\"none\" />\n <path\n d=\"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zm-5.5-2.5l7.51-3.49L17.5 6.5 9.99 9.99 6.5 17.5zm5.5-6.6c.61 0 1.1.49 1.1 1.1s-.49 1.1-1.1 1.1-1.1-.49-1.1-1.1.49-1.1 1.1-1.1z\"\n />\n </svg>\n </ic-navigation-button>\n </ic-top-navigation>`);\n\n await page.setViewport({\n width: pageWidth,\n height: pageHeight,\n });\n\n const menuBtn = await page.find(\n \"ic-top-navigation >>> .menu-button-container ic-button\"\n );\n expect(menuBtn).not.toBeNull();\n\n await menuBtn.click();\n await page.waitForChanges();\n const menu = await page.find(\"ic-top-navigation >>> ic-navigation-menu\");\n expect(menu).not.toBeNull();\n\n let activeElId = await page.$eval(\"ic-top-navigation\", (el) => {\n const menu = el.shadowRoot.querySelector(\"ic-navigation-menu\");\n return menu.shadowRoot.activeElement.id;\n });\n\n expect(activeElId).toBe(\"menu-close-button\");\n\n await page.keyboard.press(\"Tab\");\n await page.waitForChanges();\n\n activeElId = await page.$eval(\"ic-navigation-button\", (el) => {\n const button = el.shadowRoot.querySelector(\"ic-button\");\n return button.shadowRoot.activeElement.getAttribute(\"aria-label\");\n });\n\n expect(activeElId).toBe(\"button1\");\n\n await page.keyboard.press(\"Tab\");\n await page.waitForChanges();\n\n activeElId = await page.$eval(\"ic-top-navigation\", (el) => {\n const menu = el.shadowRoot.querySelector(\"ic-navigation-menu\");\n return menu.shadowRoot.activeElement.id;\n });\n\n expect(activeElId).toBe(\"menu-close-button\");\n\n page.keyboard.down(\"Shift\");\n await page.keyboard.press(\"Tab\");\n await page.waitForChanges();\n\n activeElId = await page.$eval(\"ic-navigation-button\", (el) => {\n const button = el.shadowRoot.querySelector(\"ic-button\");\n return button.shadowRoot.activeElement.getAttribute(\"aria-label\");\n });\n\n expect(activeElId).toBe(\"button1\");\n });\n\n it(\"should keep tab focus in menu - nav item as last el\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-top-navigation app-title=\"ApplicationName\" status=\"alpha\"\n version=\"v0.0.7\">\n <ic-navigation-item\n label=\"Navigation\"\n href=\"/\"\n slot=\"navigation\"\n ></ic-navigation-item> \n </ic-top-navigation>`);\n\n await page.setViewport({\n width: pageWidth,\n height: pageHeight,\n });\n\n const menuBtn = await page.find(\n \"ic-top-navigation >>> .menu-button-container ic-button\"\n );\n expect(menuBtn).not.toBeNull();\n\n await menuBtn.click();\n await page.waitForChanges();\n const menu = await page.find(\"ic-top-navigation >>> ic-navigation-menu\");\n expect(menu).not.toBeNull();\n\n let activeElId = await page.$eval(\"ic-top-navigation\", (el) => {\n const menu = el.shadowRoot.querySelector(\"ic-navigation-menu\");\n return menu.shadowRoot.activeElement.id;\n });\n\n expect(activeElId).toBe(\"menu-close-button\");\n\n await page.keyboard.press(\"Tab\");\n await page.waitForChanges();\n\n activeElId = await page.$eval(\"ic-navigation-item\", (el) => {\n return el.shadowRoot.activeElement.textContent;\n });\n\n expect(activeElId).toBe(\"Navigation\");\n\n await page.keyboard.press(\"Tab\");\n await page.waitForChanges();\n\n activeElId = await page.$eval(\"ic-top-navigation\", (el) => {\n const menu = el.shadowRoot.querySelector(\"ic-navigation-menu\");\n return menu.shadowRoot.activeElement.id;\n });\n\n expect(activeElId).toBe(\"menu-close-button\");\n\n page.keyboard.down(\"Shift\");\n await page.keyboard.press(\"Tab\");\n await page.waitForChanges();\n\n activeElId = await page.$eval(\"ic-navigation-item\", (el) => {\n return el.shadowRoot.activeElement.textContent;\n });\n\n expect(activeElId).toBe(\"Navigation\");\n });\n\n it(\"should toggle search bar when clicking on button\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-top-navigation app-title=\"ApplicationName\" status=\"alpha\"\n version=\"v0.0.7\">\n <ic-search-bar slot=\"search\" label=\"Search\" placeholder=\"Search\" focusOnLoad=\"true\"></ic-search-bar>\n </ic-top-navigation>`);\n\n await page.setViewport({\n width: pageWidth,\n height: pageHeight,\n });\n\n const searchBtn = await page.find(\n \"ic-top-navigation >>> .search-actions-container ic-button\"\n );\n expect(searchBtn).not.toBeNull();\n\n await searchBtn.click();\n await page.waitForChanges();\n\n let searchBarHeight = await page.$eval(\"ic-search-bar\", (el) => {\n return el.clientHeight;\n });\n\n expect(searchBarHeight).toBe(searchBarVisibleHeight);\n\n await searchBtn.click();\n await page.waitForChanges();\n\n searchBarHeight = await page.$eval(\"ic-search-bar\", (el) => {\n return el.clientHeight;\n });\n\n expect(searchBarHeight).toBe(searchBarHiddenHeight);\n });\n\n it(\"should hide search bar when loses focus\", async () => {\n const page = await newE2EPage();\n await page.setContent(`<ic-top-navigation app-title=\"ApplicationName\" status=\"alpha\"\n version=\"v0.0.7\">\n <ic-search-bar slot=\"search\" label=\"Search\" placeholder=\"Search\" focusOnLoad=\"true\"></ic-search-bar>\n </ic-top-navigation>\n <span id='othercontent'>some other content</span>`);\n\n await page.setViewport({\n width: pageWidth,\n height: pageHeight,\n });\n\n const searchBtn = await page.find(\n \"ic-top-navigation >>> .search-actions-container ic-button\"\n );\n expect(searchBtn).not.toBeNull();\n\n await searchBtn.click();\n await page.waitForChanges();\n\n let searchBarHeight = await page.$eval(\"ic-search-bar\", (el) => {\n return el.clientHeight;\n });\n\n expect(searchBarHeight).toBe(searchBarVisibleHeight);\n\n // Test hides when another page element clicked\n const spanEl = await page.find(\"#othercontent\");\n await spanEl.click();\n await page.waitForChanges();\n\n searchBarHeight = await page.$eval(\"ic-search-bar\", (el) => {\n return el.clientHeight;\n });\n\n expect(searchBarHeight).toBe(searchBarHiddenHeight);\n });\n});\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["icToastCss","AUTO_DISMISS_TIMER_REFRESH_RATE_MS","TOAST_HEADING_CHAR_LIMIT","TOAST_MESSAGE_CHAR_LIMIT","Toast","this","interactiveElements","dismissAction","icDismiss","emit","handleProgressChange","timerProgress","autoDismissTimeout","disconnectedCallback","window","clearTimeout","dismissTimeout","clearInterval","timerRefreshInterval","componentWillLoad","handleLongText","heading","length","_a","message","isSlotUsed","el","dismissMode","isManual","variant","neutralVariantLabel","_b","neutralIconAriaLabel","VARIANT_ICONS","ariaLabel","toastMessage","isPropDefined","setAttribute","componentDidLoad","onComponentRequiredPropUndefined","prop","propName","actionContent","getSlot","dismissButton","shadowRoot","querySelector","push","handleDismiss","visible","handleKeyboard","ev","key","preventDefault","findNextInteractiveElement","shiftKey","setFocus","repeat","stopImmediatePropagation","handleTimer","type","setTimeout","setInterval","setVisible","document","activeElement","headingTooLong","messageTooLong","console","error","isBackwards","first","last","source","target","isActive","currentIndex","found","some","index","targetEl","render","dismissButtonAriaLabel","h","Host","class","role","name","innerHTML","icon","appearance","size","progress","id","closeIcon","onClick","IcThemeForegroundEnum","Light"],"sources":["src/components/ic-toast/ic-toast.css?tag=ic-toast&encapsulation=shadow","src/components/ic-toast/ic-toast.tsx"],"sourcesContent":["@import \"../../global/normalize.css\";\n\n/**\n * @prop --ic-z-index-toast: z-index of toast\n */\n\n:host {\n --bottom-position: var(--ic-space-xl);\n\n position: fixed;\n bottom: var(--bottom-position);\n left: 50%;\n transform: translate(-50%);\n animation: fadein var(--ic-transition-duration-slow) ease-in-out;\n z-index: var(--ic-z-index-toast);\n}\n\n:host(.hidden) {\n display: none;\n animation: fadeout var(--ic-transition-duration-slow) ease-in-out;\n}\n\n.container {\n max-width: 32.5rem;\n min-width: 18rem;\n box-shadow: var(--ic-elevation-overlay);\n min-height: 3.5rem;\n background-color: var(--ic-architectural-800);\n color: var(--ic-color-white-text);\n display: flex;\n align-items: center;\n position: relative;\n border-radius: var(--ic-border-radius);\n}\n\n.toast-icon-container {\n height: 100%;\n display: flex;\n align-items: center;\n}\n\n.divider {\n height: 100%;\n width: var(--ic-space-xs);\n position: absolute;\n border-radius: var(--ic-space-xxxs) 0 0 var(--ic-space-xxxs);\n}\n\n.divider-neutral {\n background-color: var(--ic-status-unknown);\n}\n\n.divider-info {\n background-color: var(--ic-status-info-contrast);\n}\n\n.divider-warning {\n background-color: var(--ic-status-warning-contrast);\n}\n\n.divider-error {\n background-color: var(--ic-status-error-contrast);\n}\n\n.divider-success {\n background-color: var(--ic-status-success-contrast);\n}\n\n.toast-icon,\n::slotted(svg) {\n height: var(--ic-space-lg);\n width: var(--ic-space-lg);\n margin-left: var(--ic-space-md);\n}\n\n:host([variant=\"neutral\"]) .toast-icon svg,\n::slotted(svg) {\n fill: var(--ic-status-unknown);\n}\n\n:host([variant=\"info\"]) .toast-icon svg {\n fill: var(--ic-status-info-contrast);\n}\n\n:host([variant=\"warning\"]) .toast-icon svg {\n fill: var(--ic-status-warning-contrast);\n}\n\n:host([variant=\"error\"]) .toast-icon svg {\n fill: var(--ic-status-error-contrast);\n}\n\n:host([variant=\"success\"]) .toast-icon svg {\n fill: var(--ic-status-success-contrast);\n}\n\n.toast-content {\n margin-left: var(--ic-space-xs);\n width: 100%;\n}\n\n.no-icon {\n margin-left: var(--ic-space-md);\n}\n\n.toast-message {\n padding: var(--ic-space-xs) var(--ic-space-xs) var(--ic-space-xs) 0;\n}\n\n.toast-action-container {\n padding-bottom: var(--ic-space-md);\n}\n\nic-button,\n.toast-dismiss-timer {\n padding: var(--ic-space-xs);\n}\n\n@media (max-width: 576px) {\n :host {\n --bottom-position: var(--ic-space-lg);\n\n width: calc(100% - 2 * var(--ic-space-md));\n }\n}\n\n@media (min-width: 993px) {\n :host {\n --bottom-position: calc(var(--ic-space-xl) + var(--ic-space-xs));\n }\n}\n\n@media (forced-colors: active) {\n .container {\n border: var(--ic-hc-border);\n }\n}\n\n@keyframes fadein {\n from {\n bottom: 0;\n opacity: 0;\n }\n\n to {\n bottom: var(--bottom-position);\n opacity: 1;\n }\n}\n\n@keyframes fadeout {\n from {\n bottom: var(--bottom-position);\n opacity: 1;\n }\n\n to {\n bottom: 0;\n opacity: 0;\n }\n}\n","import {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Listen,\n Method,\n Prop,\n State,\n} from \"@stencil/core\";\nimport closeIcon from \"../../assets/close-icon.svg\";\nimport { VARIANT_ICONS } from \"../../utils/constants\";\nimport {\n getSlot,\n isPropDefined,\n isSlotUsed,\n onComponentRequiredPropUndefined,\n} from \"../../utils/helpers\";\nimport {\n IcActivationTypes,\n IcStatusVariants,\n IcThemeForegroundEnum,\n} from \"../../utils/types\";\nimport { ActionAreaElementTypes } from \"./ic-toast.types\";\n\nconst AUTO_DISMISS_TIMER_REFRESH_RATE_MS = 1000;\nconst TOAST_HEADING_CHAR_LIMIT = 70;\nconst TOAST_MESSAGE_CHAR_LIMIT = 140;\n\n/**\n * @slot action - IcButton or IcLink is placed below header and message. If used will default toast to manual `dismiss` type.\n * @slot neutral-icon - A custom neutral icon is placed on the left side of the component. If used will default toast to `neutral` variant.\n */\n@Component({\n tag: \"ic-toast\",\n styleUrl: \"ic-toast.css\",\n shadow: true,\n})\nexport class Toast {\n private dismissTimeout: number;\n private interactiveElements: ActionAreaElementTypes[] = [];\n private isManual: boolean;\n private neutralVariantLabel: string;\n private timerRefreshInterval: number;\n\n @Element() el: HTMLIcToastElement;\n\n @State() timerProgress = 100;\n @State() visible = false;\n\n /**\n * If toast dismissMode is set to `automatic`, use this prop to define the time before the toast dismisses (in MILLISECONDS)\n * (NOTE: Has a minimum value of `5000ms`)\n */\n @Prop({ mutable: true }) autoDismissTimeout? = 5000;\n\n /**\n * If toast can be manually dismissed, this prop sets a custom aria-label for the ic-button component\n */\n @Prop() dismissButtonAriaLabel? = \"dismiss\";\n\n /**\n * How the toast will be dismissed. If manual will display a dismiss button.\n */\n @Prop({ mutable: true }) dismissMode?: IcActivationTypes = \"manual\";\n\n /**\n * The title to display at the start of the toast. (NOTE: Should be no more than `70` characters)\n */\n @Prop() heading!: string;\n\n /**\n * The main body message of the toast. (NOTE: Should be no more than `140` characters)\n */\n @Prop() message?: string;\n\n /**\n * Provides a custom alt-text to be announced to screen readers, if slotting a custom neutral icon\n */\n @Prop() neutralIconAriaLabel?: string;\n\n /**\n * The variant of the toast being rendered\n */\n @Prop({ mutable: true }) variant?: IcStatusVariants;\n\n /**\n * Is emitted when the user dismisses the toast\n */\n @Event() icDismiss: EventEmitter<void>;\n\n disconnectedCallback(): void {\n window.clearTimeout(this.dismissTimeout);\n window.clearInterval(this.timerRefreshInterval);\n }\n\n componentWillLoad(): void {\n this.handleLongText(\n this.heading.length > TOAST_HEADING_CHAR_LIMIT,\n this.message?.length > TOAST_MESSAGE_CHAR_LIMIT\n );\n\n if (this.autoDismissTimeout < 5000) this.autoDismissTimeout = 5000;\n\n if (isSlotUsed(this.el, \"action\")) this.dismissMode = \"manual\";\n this.isManual = this.dismissMode === \"manual\";\n\n if (isSlotUsed(this.el, \"neutral-icon\")) this.variant = \"neutral\";\n if (this.variant === \"neutral\") {\n this.neutralVariantLabel =\n this.neutralIconAriaLabel ?? VARIANT_ICONS[this.variant].ariaLabel;\n }\n\n if (this.isManual) {\n const toastMessage: string = isPropDefined(this.message)\n ? `. ${this.message}`\n : \"\";\n this.el.setAttribute(\n \"aria-label\",\n this.variant\n ? this.neutralVariantLabel || VARIANT_ICONS[this.variant].ariaLabel\n : this.heading\n );\n (this.variant || this.message) &&\n this.el.setAttribute(\n \"aria-description\",\n this.variant ? `${this.heading}${toastMessage}` : this.message\n );\n }\n }\n\n componentDidLoad(): void {\n onComponentRequiredPropUndefined(\n [{ prop: this.heading, propName: \"heading\" }],\n \"Toast\"\n );\n const actionContent = getSlot(this.el, \"action\") as ActionAreaElementTypes;\n const dismissButton = this.el.shadowRoot.querySelector(\"ic-button\");\n if (actionContent) this.interactiveElements.push(actionContent);\n if (dismissButton) this.interactiveElements.push(dismissButton);\n }\n\n @Listen(\"icDismiss\", { capture: true })\n handleDismiss(): void {\n this.visible = false;\n clearInterval(this.timerRefreshInterval);\n this.timerProgress = 100;\n }\n\n @Listen(\"keydown\", { target: \"document\" })\n handleKeyboard(ev: KeyboardEvent): void {\n if (this.isManual && this.visible) {\n switch (ev.key) {\n case \"Tab\":\n ev.preventDefault();\n this.findNextInteractiveElement(ev.shiftKey).setFocus();\n break;\n case \"Escape\":\n !ev.repeat && this.dismissAction();\n ev.stopImmediatePropagation();\n break;\n }\n }\n }\n\n @Listen(\"mouseenter\")\n @Listen(\"mouseleave\")\n handleTimer(ev: MouseEvent): void {\n if (!this.isManual) {\n switch (ev.type) {\n case \"mouseenter\":\n window.clearTimeout(this.dismissTimeout);\n window.clearInterval(this.timerRefreshInterval);\n this.timerProgress = 100;\n break;\n case \"mouseleave\":\n this.dismissTimeout = window.setTimeout(\n this.dismissAction,\n this.autoDismissTimeout\n );\n this.timerRefreshInterval = window.setInterval(\n this.handleProgressChange,\n AUTO_DISMISS_TIMER_REFRESH_RATE_MS\n );\n break;\n }\n }\n }\n\n /**\n * @internal Used to display the individual toast.\n * @returns The element that previously had focus before the toast appeared\n */\n @Method()\n async setVisible(): Promise<HTMLElement> {\n if (!this.visible) this.visible = true;\n if (!this.isManual) {\n this.dismissTimeout = window.setTimeout(\n this.dismissAction,\n this.autoDismissTimeout\n );\n this.timerRefreshInterval = window.setInterval(\n this.handleProgressChange,\n AUTO_DISMISS_TIMER_REFRESH_RATE_MS\n );\n return null;\n } else {\n window.setTimeout(() => this.interactiveElements[0].setFocus(), 200);\n return document.activeElement as HTMLElement;\n }\n }\n\n private dismissAction = (): void => {\n this.icDismiss.emit();\n };\n\n private handleProgressChange = () => {\n this.timerProgress -=\n (AUTO_DISMISS_TIMER_REFRESH_RATE_MS / this.autoDismissTimeout) * 100;\n };\n\n private handleLongText(\n headingTooLong: boolean,\n messageTooLong?: boolean\n ): void {\n if (messageTooLong || headingTooLong) {\n console.error(\n `Too many characters in toast ${headingTooLong ? \"heading\" : \"\"}${\n headingTooLong && messageTooLong ? \" and \" : \"\"\n }${\n messageTooLong ? \"message\" : \"\"\n }. Refer to character limits specified in the prop description`\n );\n }\n }\n\n private findNextInteractiveElement(\n isBackwards: boolean\n ): ActionAreaElementTypes {\n const first = this.interactiveElements[0];\n const last = this.interactiveElements[this.interactiveElements.length - 1];\n\n const source = isBackwards ? first : last;\n const target = isBackwards ? last : first;\n if (this.isActive(source)) return target;\n\n let currentIndex: number;\n const found = this.interactiveElements.some((el, index) => {\n if (!this.isActive(el)) return false;\n currentIndex = index;\n return true;\n });\n\n if (!found) return first;\n return this.interactiveElements[currentIndex + (isBackwards ? -1 : 1)];\n }\n\n private isActive(targetEl: HTMLElement): boolean {\n if (targetEl === this.el) return !!this.el.shadowRoot.activeElement;\n return document.activeElement === targetEl;\n }\n\n render() {\n const {\n variant,\n heading,\n message,\n visible,\n isManual,\n dismissButtonAriaLabel,\n } = this;\n return (\n <Host\n class={{ [\"hidden\"]: !visible }}\n role={isManual ? \"dialog\" : \"status\"}\n >\n <div class=\"container\">\n {variant && visible && (\n <div class=\"toast-icon-container\">\n <div\n class={{\n [\"divider\"]: true,\n [`divider-${variant}`]: true,\n }}\n ></div>\n {variant === \"neutral\" ? (\n <slot name=\"neutral-icon\" />\n ) : (\n <span\n class=\"toast-icon\"\n innerHTML={VARIANT_ICONS[variant].icon}\n ></span>\n )}\n </div>\n )}\n <div\n class={{\n [\"toast-content\"]: true,\n [\"no-icon\"]:\n variant === \"neutral\" && !isSlotUsed(this.el, \"neutral-icon\"),\n }}\n >\n <div class=\"toast-message\">\n <ic-typography variant=\"subtitle-large\">\n {visible && <h5>{heading}</h5>}\n </ic-typography>\n {message && (\n <ic-typography variant=\"body\">\n {visible && <p>{message}</p>}\n </ic-typography>\n )}\n </div>\n {isSlotUsed(this.el, \"action\") && (\n <div class=\"toast-action-container\">\n <slot name=\"action\" />\n </div>\n )}\n </div>\n {!isManual ? (\n <ic-loading-indicator\n class=\"toast-dismiss-timer\"\n appearance=\"light\"\n size=\"icon\"\n progress={this.timerProgress}\n ></ic-loading-indicator>\n ) : (\n <ic-button\n id=\"dismiss-button\"\n innerHTML={closeIcon}\n onClick={this.dismissAction}\n variant=\"icon\"\n appearance={IcThemeForegroundEnum.Light}\n aria-label={dismissButtonAriaLabel}\n ></ic-button>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"mappings":"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"}