@ukic/web-components 3.11.0 → 3.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (357) hide show
  1. package/dist/cjs/{constants-8354f6e6.js → constants-3a9ba64a.js} +3 -1
  2. package/dist/cjs/constants-3a9ba64a.js.map +1 -0
  3. package/dist/cjs/core.cjs.js +1 -1
  4. package/dist/cjs/{helpers-ffe1c2d9.js → helpers-478d1107.js} +2 -2
  5. package/dist/cjs/helpers-478d1107.js.map +1 -0
  6. package/dist/cjs/ic-accordion-group.cjs.entry.js +2 -2
  7. package/dist/cjs/ic-accordion.cjs.entry.js +2 -2
  8. package/dist/cjs/ic-action-chip.cjs.entry.js +2 -2
  9. package/dist/cjs/ic-alert.cjs.entry.js +2 -2
  10. package/dist/cjs/ic-back-to-top.cjs.entry.js +2 -2
  11. package/dist/cjs/ic-badge.cjs.entry.js +2 -2
  12. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +2 -2
  13. package/dist/cjs/ic-breadcrumb.cjs.entry.js +2 -2
  14. package/dist/cjs/ic-button_3.cjs.entry.js +2 -2
  15. package/dist/cjs/ic-card-vertical.cjs.entry.js +2 -2
  16. package/dist/cjs/ic-checkbox-group.cjs.entry.js +8 -5
  17. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  18. package/dist/cjs/ic-checkbox.cjs.entry.js +2 -2
  19. package/dist/cjs/ic-chip.cjs.entry.js +7 -6
  20. package/dist/cjs/ic-chip.cjs.entry.js.map +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 +1381 -6
  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 +8 -7
  33. package/dist/cjs/ic-input-label_2.cjs.entry.js.map +1 -1
  34. package/dist/cjs/ic-link.cjs.entry.js +2 -2
  35. package/dist/cjs/ic-menu-group.cjs.entry.js +2 -2
  36. package/dist/cjs/ic-menu-item.cjs.entry.js +2 -2
  37. package/dist/cjs/ic-navigation-button.cjs.entry.js +2 -2
  38. package/dist/cjs/ic-navigation-group.cjs.entry.js +2 -2
  39. package/dist/cjs/ic-navigation-item.cjs.entry.js +2 -2
  40. package/dist/cjs/ic-navigation-menu.cjs.entry.js +2 -2
  41. package/dist/cjs/ic-page-header.cjs.entry.js +2 -2
  42. package/dist/cjs/ic-pagination-item.cjs.entry.js +2 -2
  43. package/dist/cjs/ic-pagination.cjs.entry.js +2 -2
  44. package/dist/cjs/ic-popover-menu.cjs.entry.js +2 -2
  45. package/dist/cjs/ic-radio-group.cjs.entry.js +15 -8
  46. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -1
  47. package/dist/cjs/ic-radio-option.cjs.entry.js +3 -3
  48. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  49. package/dist/cjs/ic-search-bar.cjs.entry.js +2 -2
  50. package/dist/cjs/ic-select.cjs.entry.js +17 -10
  51. package/dist/cjs/ic-select.cjs.entry.js.map +1 -1
  52. package/dist/cjs/ic-side-navigation.cjs.entry.js +2 -2
  53. package/dist/cjs/ic-status-tag.cjs.entry.js +2 -2
  54. package/dist/cjs/ic-step.cjs.entry.js +67 -55
  55. package/dist/cjs/ic-step.cjs.entry.js.map +1 -1
  56. package/dist/cjs/ic-stepper.cjs.entry.js +21 -4
  57. package/dist/cjs/ic-stepper.cjs.entry.js.map +1 -1
  58. package/dist/cjs/ic-switch.cjs.entry.js +2 -2
  59. package/dist/cjs/ic-tab-group.cjs.entry.js +2 -2
  60. package/dist/cjs/ic-tab.cjs.entry.js +2 -2
  61. package/dist/cjs/ic-text-field.cjs.entry.js +9 -9
  62. package/dist/cjs/ic-text-field.cjs.entry.js.map +1 -1
  63. package/dist/cjs/ic-theme.cjs.entry.js +2 -2
  64. package/dist/cjs/ic-toast.cjs.entry.js +2 -2
  65. package/dist/cjs/ic-toggle-button-group.cjs.entry.js +2 -2
  66. package/dist/cjs/ic-toggle-button.cjs.entry.js +2 -2
  67. package/dist/cjs/ic-top-navigation.cjs.entry.js +2 -2
  68. package/dist/cjs/ic-typography.cjs.entry.js +2 -2
  69. package/dist/cjs/index.cjs.js +2 -1
  70. package/dist/cjs/index.cjs.js.map +1 -1
  71. package/dist/cjs/loader.cjs.js +1 -1
  72. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.css +3 -3
  73. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js +5 -2
  74. package/dist/collection/components/ic-checkbox-group/ic-checkbox-group.js.map +1 -1
  75. package/dist/collection/components/ic-chip/ic-chip.css +4 -0
  76. package/dist/collection/components/ic-chip/ic-chip.js +4 -3
  77. package/dist/collection/components/ic-chip/ic-chip.js.map +1 -1
  78. package/dist/collection/components/ic-input-validation/ic-input-validation.css +4 -1
  79. package/dist/collection/components/ic-input-validation/ic-input-validation.js +9 -8
  80. package/dist/collection/components/ic-input-validation/ic-input-validation.js.map +1 -1
  81. package/dist/collection/components/ic-menu/ic-menu.js +5 -4
  82. package/dist/collection/components/ic-menu/ic-menu.js.map +1 -1
  83. package/dist/collection/components/ic-radio-group/ic-radio-group.css +2 -2
  84. package/dist/collection/components/ic-radio-group/ic-radio-group.js +40 -7
  85. package/dist/collection/components/ic-radio-group/ic-radio-group.js.map +1 -1
  86. package/dist/collection/components/ic-radio-group/ic-radio-group.stories.js +164 -0
  87. package/dist/collection/components/ic-radio-option/ic-radio-option.css +37 -1
  88. package/dist/collection/components/ic-select/ic-select.js +41 -8
  89. package/dist/collection/components/ic-select/ic-select.js.map +1 -1
  90. package/dist/collection/components/ic-select/ic-select_(multi).stories.js +14 -2
  91. package/dist/collection/components/ic-select/ic-select_(searchable).stories.js +10 -0
  92. package/dist/collection/components/ic-select/ic-select_(single).stories.js +111 -4
  93. package/dist/collection/components/ic-step/ic-step.js +89 -53
  94. package/dist/collection/components/ic-step/ic-step.js.map +1 -1
  95. package/dist/collection/components/ic-step/ic-step.types.js.map +1 -1
  96. package/dist/collection/components/ic-stepper/ic-stepper.js +43 -2
  97. package/dist/collection/components/ic-stepper/ic-stepper.js.map +1 -1
  98. package/dist/collection/components/ic-stepper/ic-stepper.stories.js +75 -0
  99. package/dist/collection/components/ic-text-field/ic-text-field.css +2 -2
  100. package/dist/collection/components/ic-text-field/ic-text-field.js +32 -32
  101. package/dist/collection/components/ic-text-field/ic-text-field.js.map +1 -1
  102. package/dist/collection/utils/common-helpers.js +17 -0
  103. package/dist/collection/utils/common-helpers.js.map +1 -0
  104. package/dist/collection/utils/constants.js +1 -0
  105. package/dist/collection/utils/constants.js.map +1 -1
  106. package/dist/collection/utils/types.js.map +1 -1
  107. package/dist/components/constants.js +2 -1
  108. package/dist/components/constants.js.map +1 -1
  109. package/dist/components/helpers.js.map +1 -1
  110. package/dist/components/ic-checkbox-group.js +6 -3
  111. package/dist/components/ic-checkbox-group.js.map +1 -1
  112. package/dist/components/ic-chip.js +5 -4
  113. package/dist/components/ic-chip.js.map +1 -1
  114. package/dist/components/ic-input-validation2.js +7 -6
  115. package/dist/components/ic-input-validation2.js.map +1 -1
  116. package/dist/components/ic-menu2.js +1380 -4
  117. package/dist/components/ic-menu2.js.map +1 -1
  118. package/dist/components/ic-radio-group.js +14 -6
  119. package/dist/components/ic-radio-group.js.map +1 -1
  120. package/dist/components/ic-radio-option.js +1 -1
  121. package/dist/components/ic-radio-option.js.map +1 -1
  122. package/dist/components/ic-select.js +17 -9
  123. package/dist/components/ic-select.js.map +1 -1
  124. package/dist/components/ic-side-navigation.js.map +1 -1
  125. package/dist/components/ic-step.js +66 -53
  126. package/dist/components/ic-step.js.map +1 -1
  127. package/dist/components/ic-stepper.js +20 -2
  128. package/dist/components/ic-stepper.js.map +1 -1
  129. package/dist/components/ic-text-field.js +8 -8
  130. package/dist/components/ic-text-field.js.map +1 -1
  131. package/dist/components/index.js +1 -1
  132. package/dist/core/core.esm.js +1 -1
  133. package/dist/core/core.esm.js.map +1 -1
  134. package/dist/core/index.esm.js +1 -1
  135. package/dist/core/{p-52a2f800.entry.js → p-0123dde7.entry.js} +2 -2
  136. package/dist/core/{p-23b223bf.entry.js → p-01e018cb.entry.js} +2 -2
  137. package/dist/core/{p-1ab63899.entry.js → p-02af2b59.entry.js} +2 -2
  138. package/dist/core/p-05036675.entry.js +2 -0
  139. package/dist/core/p-05036675.entry.js.map +1 -0
  140. package/dist/core/{p-1d4dfef1.entry.js → p-0c36ce84.entry.js} +2 -2
  141. package/dist/core/{p-f78f34ce.entry.js → p-0ec76cff.entry.js} +2 -2
  142. package/dist/core/{p-35ee7c53.entry.js → p-13e093d0.entry.js} +2 -2
  143. package/dist/core/{p-a48b581a.entry.js → p-1423bd4a.entry.js} +2 -2
  144. package/dist/core/{p-3f55bb5b.entry.js → p-2126d37b.entry.js} +2 -2
  145. package/dist/core/{p-515ded3f.entry.js → p-228bc12d.entry.js} +2 -2
  146. package/dist/core/{p-d27e46ac.entry.js → p-25bef09d.entry.js} +2 -2
  147. package/dist/core/{p-eddc5517.entry.js → p-27e67d45.entry.js} +2 -2
  148. package/dist/core/{p-4dd8add9.entry.js → p-2800fc30.entry.js} +2 -2
  149. package/dist/core/{p-f045f59d.entry.js → p-33582352.entry.js} +2 -2
  150. package/dist/core/p-33789b23.entry.js +3 -0
  151. package/dist/core/p-33789b23.entry.js.map +1 -0
  152. package/dist/core/{p-4a2c02b2.entry.js → p-3e36f281.entry.js} +2 -2
  153. package/dist/core/{p-58b8d154.entry.js → p-45097448.entry.js} +2 -2
  154. package/dist/core/p-514daffe.entry.js +2 -0
  155. package/dist/core/p-514daffe.entry.js.map +1 -0
  156. package/dist/core/{p-3a78bf6e.entry.js → p-54803e3b.entry.js} +2 -2
  157. package/dist/core/{p-0201abbf.entry.js → p-6058d4c9.entry.js} +2 -2
  158. package/dist/core/{p-8d29c0fa.entry.js → p-675bb3e4.entry.js} +2 -2
  159. package/dist/core/{p-75e0278a.entry.js → p-6dbe70f1.entry.js} +2 -2
  160. package/dist/core/{p-b9018261.entry.js → p-6e139e6e.entry.js} +2 -2
  161. package/dist/core/{p-aab838e5.entry.js → p-80317cd1.entry.js} +2 -2
  162. package/dist/core/{p-d35f8bd4.entry.js → p-80e0f66e.entry.js} +2 -2
  163. package/dist/core/{p-02c2c31f.entry.js → p-813ad03c.entry.js} +2 -2
  164. package/dist/core/{p-69412f61.entry.js → p-8558b9b7.entry.js} +2 -2
  165. package/dist/core/{p-a468df37.entry.js → p-8684efeb.entry.js} +2 -2
  166. package/dist/core/{p-ffc608a1.entry.js → p-8b99a806.entry.js} +2 -2
  167. package/dist/core/{p-19366be6.entry.js → p-93479c36.entry.js} +2 -2
  168. package/dist/core/{p-69cc0f7d.entry.js → p-95d3d1a7.entry.js} +2 -2
  169. package/dist/core/p-99793b64.entry.js +2 -0
  170. package/dist/core/p-99793b64.entry.js.map +1 -0
  171. package/dist/core/{p-57803949.entry.js → p-a06c1e4e.entry.js} +2 -2
  172. package/dist/core/p-a1857d24.entry.js +2 -0
  173. package/dist/core/p-a1857d24.entry.js.map +1 -0
  174. package/dist/core/{p-f17e1525.entry.js → p-a1e2e029.entry.js} +2 -2
  175. package/dist/core/{p-abb9dccb.entry.js → p-abd88929.entry.js} +2 -2
  176. package/dist/core/{p-cdd04ec2.entry.js → p-b0376079.entry.js} +2 -2
  177. package/dist/core/{p-fd488ed7.entry.js → p-b1838ad8.entry.js} +2 -2
  178. package/dist/core/p-b1838ad8.entry.js.map +1 -0
  179. package/dist/core/{p-6ceedfa8.js → p-b57e59b7.js} +2 -2
  180. package/dist/core/p-b57e59b7.js.map +1 -0
  181. package/dist/core/p-b9bdd9a9.entry.js +2 -0
  182. package/dist/core/p-b9bdd9a9.entry.js.map +1 -0
  183. package/dist/core/{p-641c26c4.js → p-bddf799a.js} +2 -2
  184. package/dist/core/p-bddf799a.js.map +1 -0
  185. package/dist/core/{p-0809aff4.entry.js → p-c04e1fab.entry.js} +2 -2
  186. package/dist/core/p-c2d5e301.entry.js +2 -0
  187. package/dist/core/p-c2d5e301.entry.js.map +1 -0
  188. package/dist/core/{p-65a3c216.entry.js → p-c975cced.entry.js} +2 -2
  189. package/dist/core/p-cc00cbce.entry.js +2 -0
  190. package/dist/core/p-cc00cbce.entry.js.map +1 -0
  191. package/dist/core/{p-a4e67ab8.entry.js → p-cf868a24.entry.js} +2 -2
  192. package/dist/core/p-cf868a24.entry.js.map +1 -0
  193. package/dist/core/{p-01aeffca.entry.js → p-d58ad080.entry.js} +2 -2
  194. package/dist/core/{p-f086d6df.entry.js → p-de32a223.entry.js} +2 -2
  195. package/dist/core/{p-46423f42.entry.js → p-e6dacbe2.entry.js} +2 -2
  196. package/dist/core/{p-8af9413c.entry.js → p-e9d28e02.entry.js} +2 -2
  197. package/dist/core/{p-1dab47b1.entry.js → p-ea06792a.entry.js} +2 -2
  198. package/dist/core/{p-5c6efed3.entry.js → p-eb0e7153.entry.js} +2 -2
  199. package/dist/core/{p-402813c9.entry.js → p-f609ca37.entry.js} +2 -2
  200. package/dist/core/{p-8d1fbbeb.entry.js → p-fb69fbc0.entry.js} +2 -2
  201. package/dist/core/{p-cd63bcf2.entry.js → p-fb734a59.entry.js} +2 -2
  202. package/dist/esm/{constants-48759bda.js → constants-7960cba4.js} +3 -2
  203. package/dist/esm/constants-7960cba4.js.map +1 -0
  204. package/dist/esm/core.js +1 -1
  205. package/dist/esm/{helpers-d8189e9d.js → helpers-4ddac6ed.js} +2 -2
  206. package/dist/esm/helpers-4ddac6ed.js.map +1 -0
  207. package/dist/esm/ic-accordion-group.entry.js +2 -2
  208. package/dist/esm/ic-accordion.entry.js +2 -2
  209. package/dist/esm/ic-action-chip.entry.js +2 -2
  210. package/dist/esm/ic-alert.entry.js +2 -2
  211. package/dist/esm/ic-back-to-top.entry.js +2 -2
  212. package/dist/esm/ic-badge.entry.js +2 -2
  213. package/dist/esm/ic-breadcrumb-group.entry.js +2 -2
  214. package/dist/esm/ic-breadcrumb.entry.js +2 -2
  215. package/dist/esm/ic-button_3.entry.js +2 -2
  216. package/dist/esm/ic-card-vertical.entry.js +2 -2
  217. package/dist/esm/ic-checkbox-group.entry.js +8 -5
  218. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  219. package/dist/esm/ic-checkbox.entry.js +2 -2
  220. package/dist/esm/ic-chip.entry.js +7 -6
  221. package/dist/esm/ic-chip.entry.js.map +1 -1
  222. package/dist/esm/ic-data-row.entry.js +2 -2
  223. package/dist/esm/ic-dialog.entry.js +2 -2
  224. package/dist/esm/ic-divider.entry.js +2 -2
  225. package/dist/esm/ic-empty-state.entry.js +2 -2
  226. package/dist/esm/ic-footer-link-group.entry.js +2 -2
  227. package/dist/esm/ic-footer-link.entry.js +2 -2
  228. package/dist/esm/ic-footer.entry.js +2 -2
  229. package/dist/esm/ic-hero.entry.js +2 -2
  230. package/dist/esm/ic-horizontal-scroll.entry.js +2 -2
  231. package/dist/esm/ic-input-component-container_3.entry.js +1381 -6
  232. package/dist/esm/ic-input-component-container_3.entry.js.map +1 -1
  233. package/dist/esm/ic-input-label_2.entry.js +8 -7
  234. package/dist/esm/ic-input-label_2.entry.js.map +1 -1
  235. package/dist/esm/ic-link.entry.js +2 -2
  236. package/dist/esm/ic-menu-group.entry.js +2 -2
  237. package/dist/esm/ic-menu-item.entry.js +2 -2
  238. package/dist/esm/ic-navigation-button.entry.js +2 -2
  239. package/dist/esm/ic-navigation-group.entry.js +2 -2
  240. package/dist/esm/ic-navigation-item.entry.js +2 -2
  241. package/dist/esm/ic-navigation-menu.entry.js +2 -2
  242. package/dist/esm/ic-page-header.entry.js +2 -2
  243. package/dist/esm/ic-pagination-item.entry.js +2 -2
  244. package/dist/esm/ic-pagination.entry.js +2 -2
  245. package/dist/esm/ic-popover-menu.entry.js +2 -2
  246. package/dist/esm/ic-radio-group.entry.js +15 -8
  247. package/dist/esm/ic-radio-group.entry.js.map +1 -1
  248. package/dist/esm/ic-radio-option.entry.js +3 -3
  249. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  250. package/dist/esm/ic-search-bar.entry.js +2 -2
  251. package/dist/esm/ic-select.entry.js +17 -10
  252. package/dist/esm/ic-select.entry.js.map +1 -1
  253. package/dist/esm/ic-side-navigation.entry.js +2 -2
  254. package/dist/esm/ic-status-tag.entry.js +2 -2
  255. package/dist/esm/ic-step.entry.js +67 -55
  256. package/dist/esm/ic-step.entry.js.map +1 -1
  257. package/dist/esm/ic-stepper.entry.js +21 -4
  258. package/dist/esm/ic-stepper.entry.js.map +1 -1
  259. package/dist/esm/ic-switch.entry.js +2 -2
  260. package/dist/esm/ic-tab-group.entry.js +2 -2
  261. package/dist/esm/ic-tab.entry.js +2 -2
  262. package/dist/esm/ic-text-field.entry.js +9 -9
  263. package/dist/esm/ic-text-field.entry.js.map +1 -1
  264. package/dist/esm/ic-theme.entry.js +2 -2
  265. package/dist/esm/ic-toast.entry.js +2 -2
  266. package/dist/esm/ic-toggle-button-group.entry.js +2 -2
  267. package/dist/esm/ic-toggle-button.entry.js +2 -2
  268. package/dist/esm/ic-top-navigation.entry.js +2 -2
  269. package/dist/esm/ic-typography.entry.js +2 -2
  270. package/dist/esm/index.js +1 -1
  271. package/dist/esm/loader.js +1 -1
  272. package/dist/types/components/ic-input-validation/ic-input-validation.d.ts +2 -3
  273. package/dist/types/components/ic-radio-group/ic-radio-group.d.ts +6 -2
  274. package/dist/types/components/ic-select/ic-select.d.ts +5 -1
  275. package/dist/types/components/ic-step/ic-step.d.ts +5 -1
  276. package/dist/types/components/ic-step/ic-step.types.d.ts +10 -0
  277. package/dist/types/components/ic-stepper/ic-stepper.d.ts +5 -1
  278. package/dist/types/components/ic-text-field/ic-text-field.d.ts +4 -4
  279. package/dist/types/components.d.ts +39 -9
  280. package/dist/types/interface.d.ts +0 -1
  281. package/dist/types/utils/common-helpers.d.ts +2 -0
  282. package/dist/types/utils/constants.d.ts +1 -0
  283. package/dist/types/utils/types.d.ts +1 -0
  284. package/hydrate/index.js +1522 -94
  285. package/hydrate/index.mjs +1522 -94
  286. package/package.json +4 -3
  287. package/vscode-data.json +30 -0
  288. package/dist/cjs/constants-8354f6e6.js.map +0 -1
  289. package/dist/cjs/helpers-ffe1c2d9.js.map +0 -1
  290. package/dist/collection/components/ic-input-validation/ic-input-validation.types.js +0 -2
  291. package/dist/collection/components/ic-input-validation/ic-input-validation.types.js.map +0 -1
  292. package/dist/core/p-402c2455.entry.js +0 -2
  293. package/dist/core/p-402c2455.entry.js.map +0 -1
  294. package/dist/core/p-641c26c4.js.map +0 -1
  295. package/dist/core/p-6ceedfa8.js.map +0 -1
  296. package/dist/core/p-75a9b2e4.entry.js +0 -2
  297. package/dist/core/p-75a9b2e4.entry.js.map +0 -1
  298. package/dist/core/p-8326db29.entry.js +0 -2
  299. package/dist/core/p-8326db29.entry.js.map +0 -1
  300. package/dist/core/p-a4e67ab8.entry.js.map +0 -1
  301. package/dist/core/p-b80d408f.entry.js +0 -2
  302. package/dist/core/p-b80d408f.entry.js.map +0 -1
  303. package/dist/core/p-c81ffadd.entry.js +0 -2
  304. package/dist/core/p-c81ffadd.entry.js.map +0 -1
  305. package/dist/core/p-d6b3e02f.entry.js +0 -2
  306. package/dist/core/p-d6b3e02f.entry.js.map +0 -1
  307. package/dist/core/p-d7bd5aa0.entry.js +0 -2
  308. package/dist/core/p-d7bd5aa0.entry.js.map +0 -1
  309. package/dist/core/p-ed69f110.entry.js +0 -2
  310. package/dist/core/p-ed69f110.entry.js.map +0 -1
  311. package/dist/core/p-fd488ed7.entry.js.map +0 -1
  312. package/dist/esm/constants-48759bda.js.map +0 -1
  313. package/dist/esm/helpers-d8189e9d.js.map +0 -1
  314. package/dist/types/components/ic-input-validation/ic-input-validation.types.d.ts +0 -1
  315. /package/dist/core/{p-52a2f800.entry.js.map → p-0123dde7.entry.js.map} +0 -0
  316. /package/dist/core/{p-23b223bf.entry.js.map → p-01e018cb.entry.js.map} +0 -0
  317. /package/dist/core/{p-1ab63899.entry.js.map → p-02af2b59.entry.js.map} +0 -0
  318. /package/dist/core/{p-1d4dfef1.entry.js.map → p-0c36ce84.entry.js.map} +0 -0
  319. /package/dist/core/{p-f78f34ce.entry.js.map → p-0ec76cff.entry.js.map} +0 -0
  320. /package/dist/core/{p-35ee7c53.entry.js.map → p-13e093d0.entry.js.map} +0 -0
  321. /package/dist/core/{p-a48b581a.entry.js.map → p-1423bd4a.entry.js.map} +0 -0
  322. /package/dist/core/{p-3f55bb5b.entry.js.map → p-2126d37b.entry.js.map} +0 -0
  323. /package/dist/core/{p-515ded3f.entry.js.map → p-228bc12d.entry.js.map} +0 -0
  324. /package/dist/core/{p-d27e46ac.entry.js.map → p-25bef09d.entry.js.map} +0 -0
  325. /package/dist/core/{p-eddc5517.entry.js.map → p-27e67d45.entry.js.map} +0 -0
  326. /package/dist/core/{p-4dd8add9.entry.js.map → p-2800fc30.entry.js.map} +0 -0
  327. /package/dist/core/{p-f045f59d.entry.js.map → p-33582352.entry.js.map} +0 -0
  328. /package/dist/core/{p-4a2c02b2.entry.js.map → p-3e36f281.entry.js.map} +0 -0
  329. /package/dist/core/{p-58b8d154.entry.js.map → p-45097448.entry.js.map} +0 -0
  330. /package/dist/core/{p-3a78bf6e.entry.js.map → p-54803e3b.entry.js.map} +0 -0
  331. /package/dist/core/{p-0201abbf.entry.js.map → p-6058d4c9.entry.js.map} +0 -0
  332. /package/dist/core/{p-8d29c0fa.entry.js.map → p-675bb3e4.entry.js.map} +0 -0
  333. /package/dist/core/{p-75e0278a.entry.js.map → p-6dbe70f1.entry.js.map} +0 -0
  334. /package/dist/core/{p-b9018261.entry.js.map → p-6e139e6e.entry.js.map} +0 -0
  335. /package/dist/core/{p-aab838e5.entry.js.map → p-80317cd1.entry.js.map} +0 -0
  336. /package/dist/core/{p-d35f8bd4.entry.js.map → p-80e0f66e.entry.js.map} +0 -0
  337. /package/dist/core/{p-02c2c31f.entry.js.map → p-813ad03c.entry.js.map} +0 -0
  338. /package/dist/core/{p-69412f61.entry.js.map → p-8558b9b7.entry.js.map} +0 -0
  339. /package/dist/core/{p-a468df37.entry.js.map → p-8684efeb.entry.js.map} +0 -0
  340. /package/dist/core/{p-ffc608a1.entry.js.map → p-8b99a806.entry.js.map} +0 -0
  341. /package/dist/core/{p-19366be6.entry.js.map → p-93479c36.entry.js.map} +0 -0
  342. /package/dist/core/{p-69cc0f7d.entry.js.map → p-95d3d1a7.entry.js.map} +0 -0
  343. /package/dist/core/{p-57803949.entry.js.map → p-a06c1e4e.entry.js.map} +0 -0
  344. /package/dist/core/{p-f17e1525.entry.js.map → p-a1e2e029.entry.js.map} +0 -0
  345. /package/dist/core/{p-abb9dccb.entry.js.map → p-abd88929.entry.js.map} +0 -0
  346. /package/dist/core/{p-cdd04ec2.entry.js.map → p-b0376079.entry.js.map} +0 -0
  347. /package/dist/core/{p-0809aff4.entry.js.map → p-c04e1fab.entry.js.map} +0 -0
  348. /package/dist/core/{p-65a3c216.entry.js.map → p-c975cced.entry.js.map} +0 -0
  349. /package/dist/core/{p-01aeffca.entry.js.map → p-d58ad080.entry.js.map} +0 -0
  350. /package/dist/core/{p-f086d6df.entry.js.map → p-de32a223.entry.js.map} +0 -0
  351. /package/dist/core/{p-46423f42.entry.js.map → p-e6dacbe2.entry.js.map} +0 -0
  352. /package/dist/core/{p-8af9413c.entry.js.map → p-e9d28e02.entry.js.map} +0 -0
  353. /package/dist/core/{p-1dab47b1.entry.js.map → p-ea06792a.entry.js.map} +0 -0
  354. /package/dist/core/{p-5c6efed3.entry.js.map → p-eb0e7153.entry.js.map} +0 -0
  355. /package/dist/core/{p-402813c9.entry.js.map → p-f609ca37.entry.js.map} +0 -0
  356. /package/dist/core/{p-8d1fbbeb.entry.js.map → p-fb69fbc0.entry.js.map} +0 -0
  357. /package/dist/core/{p-cd63bcf2.entry.js.map → p-fb734a59.entry.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"ic-radio-group.js","sourceRoot":"","sources":["../../../src/components/ic-radio-group/ic-radio-group.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Component,\n Host,\n h,\n Prop,\n State,\n Listen,\n Element,\n Event,\n EventEmitter,\n Watch,\n} from \"@stencil/core\";\nimport {\n hasValidationStatus,\n slotHasContent,\n onComponentRequiredPropUndefined,\n removeDisabledFalse,\n checkResizeObserver,\n} from \"../../utils/helpers\";\nimport {\n IcInformationStatusOrEmpty,\n IcOrientation,\n IcSizesNoLarge,\n IcThemeMode,\n IcValueEventDetail,\n} from \"../../utils/types\";\nimport { IcChangeEventDetail } from \"./ic-radio-group.types\";\n\n/**\n * @slot helper-text - Content is set as the helper text for the radio group.\n */\n@Component({\n tag: \"ic-radio-group\",\n styleUrl: \"ic-radio-group.css\",\n shadow: true,\n})\nexport class RadioGroup {\n private radioContainer?: HTMLDivElement;\n private radioOptions: HTMLIcRadioOptionElement[];\n private resizeObserver: ResizeObserver | null = null;\n private ADDITIONAL_FIELD = \"additional-field\";\n private RADIO_HORIZONTAL: IcOrientation = \"horizontal\";\n private RADIO_VERTICAL: IcOrientation = \"vertical\";\n\n @Element() el: HTMLIcRadioGroupElement;\n\n @State() checkedValue: string = \"\";\n @State() currentOrientation: IcOrientation;\n @State() initialOrientation: IcOrientation;\n @State() selectedChild: number = -1;\n\n /**\n * If `true`, the disabled state will be set.\n */\n @Prop() disabled?: boolean = false;\n\n @Watch(\"disabled\")\n watchDisabledHandler(newValue: boolean): void {\n this.radioOptions.forEach(\n (radioOption) => (radioOption.disabled = newValue)\n );\n removeDisabledFalse(this.disabled, this.el);\n }\n\n /**\n * The helper text that will be displayed for additional field guidance.\n */\n @Prop() helperText?: string;\n\n /**\n * If `true`, the label will be hidden and the required label value will be applied as an aria-label.\n */\n @Prop() hideLabel?: boolean = false;\n\n /**\n * The label for the radio group to be displayed.\n */\n @Prop() label!: string;\n\n /**\n * The name for the radio group to differentiate from other groups.\n */\n @Prop() name!: string;\n\n /**\n * The orientation of the radio buttons in the radio group. If there are more than two radio buttons in a radio group or either of the radio buttons use the `additional-field` slot, then the orientation will always be vertical.\n */\n @Prop() orientation?: IcOrientation = \"vertical\";\n\n /**\n * If `true`, the radio group will require a value.\n */\n @Prop() required?: boolean = false;\n\n /**\n * The size of the radio group component.\n */\n @Prop() size?: IcSizesNoLarge = \"medium\";\n\n /**\n * The validation status - e.g. 'error' | 'warning' | 'success'.\n */\n @Prop() validationStatus?: IcInformationStatusOrEmpty = \"\";\n\n /**\n * The text to display as the validation message.\n */\n @Prop() validationText?: string = \"\";\n\n @Watch(\"orientation\")\n orientationChangeHandler(): void {\n this.initialOrientation = this.orientation!;\n this.checkOrientation();\n }\n\n /**\n * Sets the theme color to the dark or light theme color. \"inherit\" will set the color based on the system settings or ic-theme component.\n */\n @Prop() theme?: IcThemeMode = \"inherit\";\n @Watch(\"theme\")\n watchThemeHandler(newValue: IcThemeMode): void {\n this.radioOptions.forEach((radioOption) => (radioOption.theme = newValue));\n }\n\n /**\n * Emitted when a user selects a radio.\n */\n @Event() icChange: EventEmitter<IcChangeEventDetail>;\n\n disconnectedCallback(): void {\n this.resizeObserver?.disconnect();\n this.radioContainer?.removeEventListener(\n \"slotchange\",\n this.setRadioOptions\n );\n }\n\n componentWillLoad(): void {\n removeDisabledFalse(this.disabled, this.el);\n\n this.orientationChangeHandler();\n this.currentOrientation = this.initialOrientation;\n }\n\n componentDidLoad(): void {\n this.setRadioOptions();\n checkResizeObserver(this.runResizeObserver);\n this.addSlotChangeListener();\n\n onComponentRequiredPropUndefined(\n [\n { prop: this.label, propName: \"label\" },\n { prop: this.name, propName: \"name\" },\n ],\n \"Radio Group\"\n );\n\n this.watchThemeHandler(this.theme!);\n }\n\n @Listen(\"icCheck\")\n selectHandler({ detail, target }: CustomEvent<IcValueEventDetail>): void {\n const selectedOption = target as HTMLIcRadioOptionElement;\n if (selectedOption.parentElement === this.el) {\n this.checkedValue = detail.value as string;\n this.icChange.emit({\n value: this.checkedValue,\n selectedOption: {\n radio: selectedOption,\n textFieldValue: selectedOption?.querySelector(\"ic-text-field\")?.value,\n },\n });\n\n if (this.radioOptions !== undefined) {\n this.radioOptions.forEach((radioOption, index) => {\n radioOption.selected = selectedOption === radioOption;\n if (radioOption.selected) {\n this.selectedChild = index;\n }\n });\n this.setFirstRadioOptionTabIndex(this.selectedChild > 0 ? -1 : 0);\n }\n }\n }\n\n @Listen(\"icSelectedChange\")\n changeHandler(): void {\n const selectedOption = this.radioOptions?.findIndex(\n (radioOption) => radioOption.selected\n );\n if (selectedOption < 0) {\n this.setFirstRadioOptionTabIndex(0);\n this.selectedChild = selectedOption;\n }\n }\n\n private runResizeObserver = () => {\n this.resizeObserver = new ResizeObserver(() => {\n this.checkOrientation();\n });\n\n this.resizeObserver.observe(this.el);\n };\n\n private checkOrientation() {\n if (this.initialOrientation === this.RADIO_HORIZONTAL) {\n let totalWidth = 0;\n if (Array.isArray(this.radioOptions) && this.radioOptions.length > 0) {\n this.radioOptions.forEach(({ clientWidth }, i, arr) => {\n totalWidth += clientWidth;\n if (i < arr.length - 1) totalWidth += 40;\n });\n } else {\n totalWidth = 0;\n }\n\n if (this.initialOrientation == this.RADIO_HORIZONTAL) {\n if (\n this.radioOptions !== undefined &&\n (this.radioOptions.length > 2 ||\n (this.radioOptions.length === 2 &&\n (slotHasContent(this.radioOptions[0], this.ADDITIONAL_FIELD) ||\n slotHasContent(this.radioOptions[1], this.ADDITIONAL_FIELD))))\n ) {\n this.currentOrientation = this.RADIO_VERTICAL;\n } else {\n if (this.radioContainer) {\n if (totalWidth >= this.radioContainer.clientWidth) {\n this.currentOrientation = this.RADIO_VERTICAL;\n } else if (totalWidth < this.radioContainer.clientWidth) {\n this.currentOrientation = this.RADIO_HORIZONTAL;\n }\n }\n }\n }\n }\n }\n\n private handleKeyDown = (event: KeyboardEvent): void => {\n const additionalFields = Array.from(\n this.el.querySelectorAll<HTMLElement>(\n 'ic-text-field[slot=\"additional-field\"]'\n )\n );\n const activeEl = document.activeElement;\n if (\n additionalFields.length > 0 &&\n this.radioOptions.map((el) =>\n slotHasContent(el, this.ADDITIONAL_FIELD)\n ) &&\n additionalFields.map((el) => el == activeEl)\n ) {\n return;\n }\n\n event.stopPropagation();\n switch (event.key) {\n case \"ArrowDown\":\n case \"ArrowRight\":\n this.radioOptions[\n this.getNextItemToSelect(this.selectedChild, true)\n ].click();\n event.preventDefault();\n break;\n case \"ArrowUp\":\n case \"ArrowLeft\":\n this.radioOptions[\n this.getNextItemToSelect(this.selectedChild, false)\n ].click();\n event.preventDefault();\n }\n };\n\n private getNextItemToSelect = (\n currentItem: number,\n movingDown: boolean\n ): number => {\n const numRadios = this.radioOptions.length - 1;\n\n if (currentItem < 1) {\n currentItem = 0;\n }\n\n let nextItem = movingDown ? currentItem + 1 : currentItem - 1;\n\n //check if wrap around necessary\n if (nextItem < 0) {\n nextItem = numRadios;\n } else if (nextItem > numRadios) {\n nextItem = 0;\n }\n\n //if next item is disabled then find next\n if (this.radioOptions[nextItem].disabled) {\n nextItem = this.getNextItemToSelect(nextItem, movingDown);\n }\n\n return nextItem;\n };\n\n private addSlotChangeListener = () => {\n this.radioContainer?.addEventListener(\"slotchange\", this.setRadioOptions);\n };\n\n private setFirstRadioOptionTabIndex = (value: number) => {\n this.radioOptions[0].setTabIndex(value);\n };\n\n private setRadioOptions = () => {\n this.selectedChild = -1;\n this.checkedValue = \"\";\n this.radioOptions = Array.from(this.el.children).filter(\n (el) => el.tagName === \"IC-RADIO-OPTION\"\n ) as HTMLIcRadioOptionElement[];\n if (this.radioOptions.length > 0) {\n this.radioOptions.forEach((radioOption, index) => {\n if (!radioOption.selected) {\n radioOption.selected = this.checkedValue === radioOption.value;\n }\n radioOption.name = this.name;\n radioOption.groupLabel = this.label;\n if (radioOption.selected) {\n this.selectedChild = index;\n this.checkedValue = radioOption.value;\n }\n if (this.disabled) {\n radioOption.disabled = true;\n }\n });\n this.setFirstRadioOptionTabIndex(this.selectedChild > 0 ? -1 : 0);\n\n if (\n this.initialOrientation === this.RADIO_HORIZONTAL &&\n this.radioOptions !== undefined &&\n (this.radioOptions.length > 2 ||\n (this.radioOptions.length === 2 &&\n (slotHasContent(this.radioOptions[0], this.ADDITIONAL_FIELD) ||\n slotHasContent(this.radioOptions[1], this.ADDITIONAL_FIELD))))\n ) {\n this.currentOrientation = this.RADIO_VERTICAL;\n }\n }\n };\n\n render() {\n const {\n currentOrientation,\n disabled,\n handleKeyDown,\n helperText,\n hideLabel,\n label,\n required,\n size,\n validationStatus,\n validationText,\n theme,\n } = this;\n\n return (\n <Host\n onKeyDown={handleKeyDown}\n class={{\n \"ic-radio-group-small\": size === \"small\",\n [`ic-theme-${theme}`]: theme !== \"inherit\",\n }}\n >\n <fieldset\n role=\"radiogroup\"\n id={this.name}\n aria-required={`${required}`}\n >\n {!hideLabel && (\n <legend>\n <ic-input-label\n class={{\n [`${validationStatus}`]: true,\n [\"disabled\"]: !!disabled,\n }}\n label={label}\n helperText={helperText}\n required={required}\n disabled={disabled}\n >\n <slot name=\"helper-text\" slot=\"helper-text\"></slot>\n </ic-input-label>\n </legend>\n )}\n <div\n class={{\n \"radio-buttons-container\": true,\n horizontal: currentOrientation === this.RADIO_HORIZONTAL,\n }}\n ref={(el) => (this.radioContainer = el)}\n >\n <slot></slot>\n </div>\n </fieldset>\n {hasValidationStatus(validationStatus, disabled) && (\n <ic-input-validation\n ariaLiveMode=\"polite\"\n status={validationStatus}\n message={validationText!}\n ></ic-input-validation>\n )}\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"ic-radio-group.js","sourceRoot":"","sources":["../../../src/components/ic-radio-group/ic-radio-group.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Component,\n Host,\n h,\n Prop,\n State,\n Listen,\n Element,\n Event,\n EventEmitter,\n Watch,\n} from \"@stencil/core\";\nimport {\n hasValidationStatus,\n slotHasContent,\n onComponentRequiredPropUndefined,\n removeDisabledFalse,\n checkResizeObserver,\n} from \"../../utils/helpers\";\nimport {\n IcAriaLive,\n IcInformationStatusOrEmpty,\n IcOrientation,\n IcSizesNoLarge,\n IcThemeMode,\n IcValueEventDetail,\n} from \"../../utils/types\";\nimport { IcChangeEventDetail } from \"./ic-radio-group.types\";\n\n/**\n * @slot helper-text - Content is set as the helper text for the radio group.\n */\n@Component({\n tag: \"ic-radio-group\",\n styleUrl: \"ic-radio-group.css\",\n shadow: true,\n})\nexport class RadioGroup {\n private radioContainer?: HTMLDivElement;\n private radioOptions: HTMLIcRadioOptionElement[];\n private resizeObserver: ResizeObserver | null = null;\n private ADDITIONAL_FIELD = \"additional-field\";\n private RADIO_HORIZONTAL: IcOrientation = \"horizontal\";\n private RADIO_VERTICAL: IcOrientation = \"vertical\";\n\n @Element() el: HTMLIcRadioGroupElement;\n\n @State() checkedValue: string = \"\";\n @State() currentOrientation: IcOrientation;\n @State() initialOrientation: IcOrientation;\n @State() selectedChild: number = -1;\n\n /**\n * If `true`, the disabled state will be set.\n */\n @Prop() disabled?: boolean = false;\n\n @Watch(\"disabled\")\n watchDisabledHandler(newValue: boolean): void {\n this.radioOptions.forEach(\n (radioOption) => (radioOption.disabled = newValue)\n );\n removeDisabledFalse(this.disabled, this.el);\n }\n\n /**\n * The helper text that will be displayed for additional field guidance.\n */\n @Prop() helperText?: string;\n\n /**\n * If `true`, the label will be hidden and the required label value will be applied as an aria-label.\n */\n @Prop() hideLabel?: boolean = false;\n\n /**\n * The label for the radio group to be displayed.\n */\n @Prop() label!: string;\n\n /**\n * The name for the radio group to differentiate from other groups.\n */\n @Prop() name!: string;\n\n /**\n * The orientation of the radio buttons in the radio group. If there are more than two radio buttons in a radio group or either of the radio buttons use the `additional-field` slot, then the orientation will always be vertical.\n */\n @Prop() orientation?: IcOrientation = \"vertical\";\n\n /**\n * If `true`, the radio group will require a value.\n */\n @Prop() required?: boolean = false;\n\n /**\n * The size of the radio group component.\n */\n @Prop() size?: IcSizesNoLarge = \"medium\";\n\n /**\n * The value of the `aria-live` attribute on the validation message.\n */\n @Prop() validationAriaLive: IcAriaLive = \"polite\";\n\n /**\n * The validation status - e.g. 'error' | 'warning' | 'success'.\n */\n @Prop() validationStatus?: IcInformationStatusOrEmpty = \"\";\n\n /**\n * The text to display as the validation message.\n */\n @Prop() validationText: string = \"\";\n\n @Watch(\"orientation\")\n orientationChangeHandler(): void {\n this.initialOrientation = this.orientation!;\n this.checkOrientation();\n }\n\n /**\n * Sets the theme color to the dark or light theme color. \"inherit\" will set the color based on the system settings or ic-theme component.\n */\n @Prop() theme?: IcThemeMode = \"inherit\";\n @Watch(\"theme\")\n watchThemeHandler(newValue: IcThemeMode): void {\n this.radioOptions.forEach((radioOption) => (radioOption.theme = newValue));\n }\n\n /**\n * Emitted when a user selects a radio.\n */\n @Event() icChange: EventEmitter<IcChangeEventDetail>;\n\n disconnectedCallback(): void {\n this.resizeObserver?.disconnect();\n this.radioContainer?.removeEventListener(\n \"slotchange\",\n this.setRadioOptions\n );\n }\n\n componentWillLoad(): void {\n removeDisabledFalse(this.disabled, this.el);\n\n this.orientationChangeHandler();\n this.currentOrientation = this.initialOrientation;\n }\n\n componentDidLoad(): void {\n this.setRadioOptions();\n checkResizeObserver(this.runResizeObserver);\n this.addSlotChangeListener();\n\n onComponentRequiredPropUndefined(\n [\n { prop: this.label, propName: \"label\" },\n { prop: this.name, propName: \"name\" },\n ],\n \"Radio Group\"\n );\n\n this.watchThemeHandler(this.theme!);\n }\n\n @Listen(\"icCheck\")\n selectHandler({ detail, target }: CustomEvent<IcValueEventDetail>): void {\n const selectedOption = target as HTMLIcRadioOptionElement;\n if (selectedOption.parentElement === this.el) {\n this.checkedValue = detail.value as string;\n this.icChange.emit({\n value: this.checkedValue,\n selectedOption: {\n radio: selectedOption,\n textFieldValue: selectedOption?.querySelector(\"ic-text-field\")?.value,\n },\n });\n\n if (this.radioOptions !== undefined) {\n this.radioOptions.forEach((radioOption, index) => {\n radioOption.selected = selectedOption === radioOption;\n if (radioOption.selected) {\n this.selectedChild = index;\n }\n });\n this.setFirstRadioOptionTabIndex(this.selectedChild > 0 ? -1 : 0);\n }\n }\n }\n\n @Listen(\"icSelectedChange\")\n changeHandler(): void {\n const selectedOption = this.radioOptions?.findIndex(\n (radioOption) => radioOption.selected\n );\n if (selectedOption < 0) {\n this.setFirstRadioOptionTabIndex(0);\n this.selectedChild = selectedOption;\n }\n }\n\n private runResizeObserver = () => {\n this.resizeObserver = new ResizeObserver(() => {\n this.checkOrientation();\n });\n\n this.resizeObserver.observe(this.el);\n };\n\n private checkOrientation() {\n if (this.initialOrientation === this.RADIO_HORIZONTAL) {\n let totalWidth = 0;\n if (Array.isArray(this.radioOptions) && this.radioOptions.length > 0) {\n this.radioOptions.forEach(({ clientWidth }, i, arr) => {\n totalWidth += clientWidth;\n if (i < arr.length - 1) totalWidth += 40;\n });\n } else {\n totalWidth = 0;\n }\n\n if (this.initialOrientation == this.RADIO_HORIZONTAL) {\n if (\n this.radioOptions !== undefined &&\n (this.radioOptions.length > 2 ||\n (this.radioOptions.length === 2 &&\n (slotHasContent(this.radioOptions[0], this.ADDITIONAL_FIELD) ||\n slotHasContent(this.radioOptions[1], this.ADDITIONAL_FIELD))))\n ) {\n this.currentOrientation = this.RADIO_VERTICAL;\n } else {\n if (this.radioContainer) {\n if (totalWidth >= this.radioContainer.clientWidth) {\n this.currentOrientation = this.RADIO_VERTICAL;\n } else if (totalWidth < this.radioContainer.clientWidth) {\n this.currentOrientation = this.RADIO_HORIZONTAL;\n }\n }\n }\n }\n }\n }\n\n private handleKeyDown = (event: KeyboardEvent): void => {\n const additionalFields = Array.from(\n this.el.querySelectorAll<HTMLElement>(\n 'ic-text-field[slot=\"additional-field\"]'\n )\n );\n const activeEl = document.activeElement;\n if (\n additionalFields.length > 0 &&\n this.radioOptions.map((el) =>\n slotHasContent(el, this.ADDITIONAL_FIELD)\n ) &&\n additionalFields.map((el) => el == activeEl)\n ) {\n return;\n }\n\n event.stopPropagation();\n switch (event.key) {\n case \"ArrowDown\":\n case \"ArrowRight\":\n this.radioOptions[\n this.getNextItemToSelect(this.selectedChild, true)\n ].click();\n event.preventDefault();\n break;\n case \"ArrowUp\":\n case \"ArrowLeft\":\n this.radioOptions[\n this.getNextItemToSelect(this.selectedChild, false)\n ].click();\n event.preventDefault();\n }\n };\n\n private getNextItemToSelect = (\n currentItem: number,\n movingDown: boolean\n ): number => {\n const numRadios = this.radioOptions.length - 1;\n\n if (currentItem < 1) {\n currentItem = 0;\n }\n\n let nextItem = movingDown ? currentItem + 1 : currentItem - 1;\n\n //check if wrap around necessary\n if (nextItem < 0) {\n nextItem = numRadios;\n } else if (nextItem > numRadios) {\n nextItem = 0;\n }\n\n //if next item is disabled then find next\n if (this.radioOptions[nextItem].disabled) {\n nextItem = this.getNextItemToSelect(nextItem, movingDown);\n }\n\n return nextItem;\n };\n\n private addSlotChangeListener = () => {\n this.radioContainer?.addEventListener(\"slotchange\", this.setRadioOptions);\n };\n\n private setFirstRadioOptionTabIndex = (value: number) => {\n this.radioOptions[0].setTabIndex(value);\n };\n\n private setRadioOptions = () => {\n this.selectedChild = -1;\n this.checkedValue = \"\";\n this.radioOptions = Array.from(this.el.children).filter(\n (el) => el.tagName === \"IC-RADIO-OPTION\"\n ) as HTMLIcRadioOptionElement[];\n if (this.radioOptions.length > 0) {\n this.radioOptions.forEach((radioOption, index) => {\n if (!radioOption.selected) {\n radioOption.selected = this.checkedValue === radioOption.value;\n }\n radioOption.name = this.name;\n radioOption.groupLabel = this.label;\n if (radioOption.selected) {\n this.selectedChild = index;\n this.checkedValue = radioOption.value;\n }\n if (this.disabled) {\n radioOption.disabled = true;\n }\n });\n this.setFirstRadioOptionTabIndex(this.selectedChild > 0 ? -1 : 0);\n\n if (\n this.initialOrientation === this.RADIO_HORIZONTAL &&\n this.radioOptions !== undefined &&\n (this.radioOptions.length > 2 ||\n (this.radioOptions.length === 2 &&\n (slotHasContent(this.radioOptions[0], this.ADDITIONAL_FIELD) ||\n slotHasContent(this.radioOptions[1], this.ADDITIONAL_FIELD))))\n ) {\n this.currentOrientation = this.RADIO_VERTICAL;\n }\n }\n };\n\n render() {\n const {\n currentOrientation,\n disabled,\n handleKeyDown,\n helperText,\n hideLabel,\n label,\n required,\n size,\n validationAriaLive,\n validationStatus,\n validationText,\n theme,\n } = this;\n\n const showValidation = hasValidationStatus(validationStatus, disabled);\n\n return (\n <Host\n onKeyDown={handleKeyDown}\n class={{\n \"ic-radio-group-small\": size === \"small\",\n [`ic-theme-${theme}`]: theme !== \"inherit\",\n }}\n >\n <fieldset\n role=\"radiogroup\"\n id={this.name}\n aria-required={`${required}`}\n >\n {!hideLabel && (\n <legend>\n <ic-input-label\n class={{\n [`${validationStatus}`]: true,\n [\"disabled\"]: !!disabled,\n }}\n label={label}\n helperText={helperText}\n required={required}\n disabled={disabled}\n >\n <slot name=\"helper-text\" slot=\"helper-text\"></slot>\n </ic-input-label>\n </legend>\n )}\n <div\n class={{\n \"radio-buttons-container\": true,\n horizontal: currentOrientation === this.RADIO_HORIZONTAL,\n }}\n ref={(el) => (this.radioContainer = el)}\n >\n <slot></slot>\n </div>\n </fieldset>\n <ic-input-validation\n class={{\n \"show-validation\": showValidation,\n }}\n ariaLiveMode={validationAriaLive}\n status={showValidation ? validationStatus : \"\"}\n message={showValidation ? validationText : \"\"}\n ></ic-input-validation>\n </Host>\n );\n }\n}\n"]}
@@ -9,6 +9,7 @@ const defaultArgs = {
9
9
  orientation: "vertical",
10
10
  required: false,
11
11
  size: "medium",
12
+ validationAriaLive: "polite",
12
13
  validationStatus: "no status",
13
14
  validationText: "",
14
15
  additionalFieldDisplay: "static",
@@ -341,6 +342,159 @@ export const Validation = {
341
342
  name: "Validation",
342
343
  };
343
344
 
345
+ export const AriaLiveBehaviour = {
346
+ render: (args) =>
347
+ html`<ic-radio-group
348
+ id="field-1"
349
+ label="This is a label"
350
+ name="1"
351
+ helper-text="Error already set on page load and aria-live overridden as 'assertive'"
352
+ validation-status="error"
353
+ validation-text="First error message"
354
+ validation-aria-live="assertive"
355
+ >
356
+ <ic-radio-option
357
+ value="valueName1"
358
+ label="Unselected / Default 1"
359
+ ></ic-radio-option>
360
+ <ic-radio-option
361
+ value="valueName2"
362
+ label="Selected / Default 1"
363
+ selected
364
+ ></ic-radio-option>
365
+ <ic-radio-option
366
+ value="valueName3"
367
+ label="Unselected / Disabled 1"
368
+ disabled
369
+ ></ic-radio-option>
370
+ </ic-radio-group>
371
+ <br />
372
+ <ic-radio-group
373
+ id="field-2"
374
+ label="This is a label"
375
+ name="2"
376
+ helper-text="Error set after page load and aria-live overridden as 'assertive'"
377
+ validation-aria-live="assertive"
378
+ >
379
+ <ic-radio-option
380
+ value="valueName1"
381
+ label="Unselected / Default 2"
382
+ ></ic-radio-option>
383
+ <ic-radio-option
384
+ value="valueName2"
385
+ label="Selected / Default 2"
386
+ selected
387
+ ></ic-radio-option>
388
+ <ic-radio-option
389
+ value="valueName3"
390
+ label="Unselected / Disabled 2"
391
+ disabled
392
+ ></ic-radio-option>
393
+ </ic-radio-group>
394
+ <br />
395
+ <ic-button id="toggle-btn-1">Toggle errors</ic-button>
396
+ <script>
397
+ let showErrors1 = false;
398
+ const btn1 = document.getElementById("toggle-btn-1");
399
+ const field1 = document.getElementById("field-1");
400
+ const field2 = document.getElementById("field-2");
401
+
402
+ btn1.addEventListener("click", () => {
403
+ showErrors1 = !showErrors1;
404
+
405
+ field1.setAttribute("validation-status", showErrors1 ? "" : "error");
406
+ field1.setAttribute(
407
+ "validation-text",
408
+ showErrors1 ? "" : "First error message"
409
+ );
410
+
411
+ field2.setAttribute("validation-status", showErrors1 ? "error" : "");
412
+ field2.setAttribute(
413
+ "validation-text",
414
+ showErrors1 ? "Second error message" : ""
415
+ );
416
+ });
417
+ </script>
418
+ <br />
419
+ <br />
420
+ <br />
421
+ <br />
422
+ <ic-radio-group
423
+ id="field-3"
424
+ label="This is a label"
425
+ name="3"
426
+ helper-text="Default aria-live behaviour (i.e. 'polite')"
427
+ >
428
+ <ic-radio-option
429
+ value="valueName1"
430
+ label="Unselected / Default 3"
431
+ ></ic-radio-option>
432
+ <ic-radio-option
433
+ value="valueName2"
434
+ label="Selected / Default 3"
435
+ selected
436
+ ></ic-radio-option>
437
+ <ic-radio-option
438
+ value="valueName3"
439
+ label="Unselected / Disabled 3"
440
+ disabled
441
+ ></ic-radio-option>
442
+ </ic-radio-group>
443
+ <br />
444
+ <ic-radio-group
445
+ id="field-4"
446
+ label="This is a label"
447
+ name="4"
448
+ helper-text="Default aria-live behaviour (i.e. 'polite')"
449
+ >
450
+ <ic-radio-option
451
+ value="valueName1"
452
+ label="Unselected / Default 4"
453
+ ></ic-radio-option>
454
+ <ic-radio-option
455
+ value="valueName2"
456
+ label="Selected / Default 4"
457
+ selected
458
+ ></ic-radio-option>
459
+ <ic-radio-option
460
+ value="valueName3"
461
+ label="Unselected / Disabled 4"
462
+ disabled
463
+ ></ic-radio-option>
464
+ </ic-radio-group>
465
+ <br />
466
+ <ic-button id="toggle-btn-2">Toggle errors</ic-button>
467
+ <br />
468
+ <br />
469
+ <br />
470
+ <br />
471
+ <br />
472
+ <script>
473
+ let showErrors2 = false;
474
+ const btn2 = document.getElementById("toggle-btn-2");
475
+ const field3 = document.getElementById("field-3");
476
+ const field4 = document.getElementById("field-4");
477
+
478
+ btn2.addEventListener("click", () => {
479
+ showErrors2 = !showErrors2;
480
+
481
+ field3.setAttribute("validation-status", showErrors2 ? "error" : "");
482
+ field3.setAttribute(
483
+ "validation-text",
484
+ showErrors2 ? "Third error message" : ""
485
+ );
486
+
487
+ field4.setAttribute("validation-status", showErrors2 ? "error" : "");
488
+ field4.setAttribute(
489
+ "validation-text",
490
+ showErrors2 ? "Fourth error message" : ""
491
+ );
492
+ });
493
+ </script>`,
494
+
495
+ name: "Aria-live behaviour",
496
+ };
497
+
344
498
  export const Form = {
345
499
  render: (args) => html`
346
500
  <form>
@@ -414,6 +568,7 @@ export const Playground = {
414
568
  orientation=${args.orientation}
415
569
  required=${args.required}
416
570
  size=${args.size}
571
+ validation-aria-live=${args.validationAriaLive}
417
572
  validation-status=${args.validationStatus === "no status"
418
573
  ? ""
419
574
  : args.validationStatus}
@@ -436,6 +591,7 @@ export const Playground = {
436
591
  slot=${args.additionalFieldSlot}
437
592
  placeholder="Placeholder"
438
593
  label="What's your favourite type of coffee?"
594
+ size=${args.size}
439
595
  ></ic-text-field>
440
596
  </ic-radio-option>
441
597
  <ic-radio-option value="valueName2" label="Radio 2"></ic-radio-option>
@@ -461,6 +617,14 @@ export const Playground = {
461
617
  },
462
618
  },
463
619
 
620
+ validationAriaLive: {
621
+ options: ["polite", "assertive", "off"],
622
+
623
+ control: {
624
+ type: inlineRadioSelector,
625
+ },
626
+ },
627
+
464
628
  validationStatus: {
465
629
  options: ["no status", "error", "warning", "success"],
466
630
 
@@ -478,6 +478,10 @@ ic-radio-option.ic-radio-option-disabled .radio-label {
478
478
  margin: var(--ic-space-xxs) 0 var(--ic-space-xxs) var(--ic-space-xxs);
479
479
  }
480
480
 
481
+ .ic-radio-group-small .container {
482
+ margin: 0 0 0 var(--ic-space-xxs);
483
+ }
484
+
481
485
  .container.disabled,
482
486
  .container.disabled input:disabled {
483
487
  cursor: default;
@@ -497,6 +501,11 @@ ic-radio-option.ic-radio-option-disabled .radio-label {
497
501
  border: none;
498
502
  }
499
503
 
504
+ .ic-radio-group-small .container input {
505
+ height: var(--ic-space-md);
506
+ width: var(--ic-space-md);
507
+ }
508
+
500
509
  /* Create a custom radio button */
501
510
  .checkmark {
502
511
  display: block;
@@ -512,6 +521,11 @@ ic-radio-option.ic-radio-option-disabled .radio-label {
512
521
  box-sizing: border-box;
513
522
  }
514
523
 
524
+ .ic-radio-group-small .checkmark {
525
+ height: var(--ic-space-md);
526
+ width: var(--ic-space-md);
527
+ }
528
+
515
529
  /* Show the indicator (dot/circle) when checked */
516
530
  .container input:checked ~ .checkmark::after {
517
531
  display: inline-block;
@@ -544,6 +558,10 @@ ic-radio-option.ic-radio-option-disabled .radio-label {
544
558
  box-shadow: 0 0 0 0.25rem var(--ic-radio-button-active-pressed);
545
559
  }
546
560
 
561
+ .ic-radio-group-small .container input:checked ~ .checkmark {
562
+ border-width: var(--ic-space-1px);
563
+ }
564
+
547
565
  /* When pressed and selected, adds the active colours */
548
566
  .container:active input:checked ~ .checkmark::after {
549
567
  background-color: var(--ic-radio-button-default-pressed);
@@ -592,12 +610,26 @@ ic-radio-option.ic-radio-option-disabled .radio-label {
592
610
  background: var(--ic-radio-button-default-active);
593
611
  }
594
612
 
613
+ .ic-radio-group-small .container .checkmark::after {
614
+ top: 50%;
615
+ left: 50%;
616
+ width: 0.625rem;
617
+ height: 0.625rem;
618
+ border-radius: 50%;
619
+ background: var(--ic-radio-button-default-active);
620
+ transform: translate(-50%, -50%);
621
+ }
622
+
595
623
  .radio-label {
596
624
  margin-left: var(--ic-space-md);
597
625
 
598
626
  --ic-typography-color: var(--ic-radio-button-text-option);
599
627
  }
600
628
 
629
+ .ic-radio-group-small .radio-label {
630
+ margin-left: var(--ic-space-xs);
631
+ }
632
+
601
633
  .additional-field-wrapper {
602
634
  margin-left: var(--ic-space-xs);
603
635
  }
@@ -617,10 +649,14 @@ ic-radio-option.ic-radio-option-disabled .radio-label {
617
649
  .dynamic-container {
618
650
  display: flex;
619
651
  position: relative;
620
- margin: var(--ic-space-xxxs) 0 var(--ic-space-xxs) var(--ic-space-md);
652
+ margin: var(--ic-space-xxs) 0 var(--ic-space-xxs) var(--ic-space-md);
621
653
  gap: var(--ic-space-xs);
622
654
  }
623
655
 
656
+ .ic-radio-group-small .dynamic-container {
657
+ margin-left: 12px;
658
+ }
659
+
624
660
  .dynamic-container.hidden {
625
661
  display: none;
626
662
  }
@@ -112,6 +112,10 @@ export class Select {
112
112
  * Sets the theme color to the dark or light theme color. "inherit" will set the color based on the system settings or ic-theme component.
113
113
  */
114
114
  this.theme = "inherit";
115
+ /**
116
+ * The value of the `aria-live` attribute on the validation message.
117
+ */
118
+ this.validationAriaLive = "polite";
115
119
  /**
116
120
  * The validation status - e.g. 'error' | 'warning' | 'success'.
117
121
  */
@@ -771,12 +775,13 @@ export class Select {
771
775
  }
772
776
  render() {
773
777
  var _a;
774
- const { size, disabled, fullWidth, helperText, hideLabel, label, menuId, multiple, name, options, placeholder, readonly, required, searchable, showClearButton, validationStatus, validationText, currValue, theme, hiddenInputValue, open, inputId, searchableSelectInputValue, loading, value, emptyOptionListText, uniqueOptions, selectOnEnter, form, inheritedAttributes, ariaActiveDescendant, hasTimedOut, noOptions, filteredOptions, clearButtonFocused, } = this;
778
+ const { size, disabled, fullWidth, helperText, hideLabel, label, menuId, multiple, name, options, placeholder, readonly, required, searchable, showClearButton, validationAriaLive, validationStatus, validationText, currValue, theme, hiddenInputValue, open, inputId, searchableSelectInputValue, loading, value, emptyOptionListText, uniqueOptions, selectOnEnter, form, inheritedAttributes, ariaActiveDescendant, hasTimedOut, noOptions, filteredOptions, clearButtonFocused, } = this;
775
779
  // HTML inputs only accept 'string' for their value
776
780
  // Does not cause errors when it is a multi-select - sets value correctly, to a comma-separated string
777
781
  renderHiddenInput(this.el, searchable ? hiddenInputValue : currValue, name || inputId, disabled);
778
782
  const invalid = `${validationStatus === IcInformationStatus.Error}`;
779
- const describedBy = getInputDescribedByText(this.el, inputId, helperText !== "", hasValidationStatus(validationStatus, !!disabled)).trim();
783
+ const showValidation = hasValidationStatus(validationStatus, !!disabled);
784
+ const describedBy = getInputDescribedByText(this.el, inputId, helperText !== "", showValidation).trim();
780
785
  const valueLabelString = multiple
781
786
  ? this.getMultipleOptionsString(currValue)
782
787
  : this.getLabelFromValue(currValue);
@@ -784,18 +789,18 @@ export class Select {
784
789
  (searchable
785
790
  ? !!searchableSelectInputValue
786
791
  : !!currValue && !loading && showClearButton);
787
- return (h(Host, { key: 'f5904ffbfd98939566138b0b3cbc02541dbc9e23', class: {
792
+ return (h(Host, { key: 'd4771b458b86fdf5e8fd7242b0faa34c641dc1fd', class: {
788
793
  "ic-select-disabled": disabled,
789
794
  "ic-select-searchable": searchable,
790
795
  [`ic-select-${size}`]: size !== "medium",
791
796
  "ic-select-full-width": fullWidth,
792
797
  [`ic-theme-${theme}`]: theme !== "inherit",
793
- }, onBlur: this.onBlur }, h("ic-input-container", { key: '27f49919e3c64328952cf089eac456d71e555ab1', readonly: readonly }, !hideLabel && (h("ic-input-label", { key: 'fe561a5ebe6dc81cca4a88c5be92aed4ca962883', for: inputId, label: label, helperText: helperText, required: required, disabled: disabled, readonly: readonly }, h("slot", { key: 'b1abb9c01278c2767df3f684448eb0efb7de58e9', name: "helper-text", slot: "helper-text" }))), h("ic-input-component-container", { key: 'bbe206ebe78a9d93b3fb64a63e9fe3d14b1a9536', ref: (el) => (this.anchorEl = el), class: { "menu-open": open }, size: size, fullWidth: fullWidth, disabled: disabled, readonly: readonly, validationStatus: validationStatus }, isSlotUsed(this.el, "icon") &&
798
+ }, onBlur: this.onBlur }, h("ic-input-container", { key: '085e9b190479932161c56015ed340dda3e94bd20', readonly: readonly }, !hideLabel && (h("ic-input-label", { key: '7ed1f56a30c8ba83b5c5f21291221d8910310fbd', for: inputId, label: label, helperText: helperText, required: required, disabled: disabled, readonly: readonly }, h("slot", { key: '1d3aac656b887c2a553f425e310d3be2fcc0a570', name: "helper-text", slot: "helper-text" }))), h("ic-input-component-container", { key: '7f6973e971e7b892717e72d8420346d8951751ca', ref: (el) => (this.anchorEl = el), class: { "menu-open": open }, size: size, fullWidth: fullWidth, disabled: disabled, readonly: readonly, validationStatus: validationStatus }, isSlotUsed(this.el, "icon") &&
794
799
  !disabled &&
795
- (!readonly || !!value) && (h("span", { key: 'fa16f00a341024e3714b4702f74a0e15e2152105', slot: "left-icon", class: {
800
+ (!readonly || !!value) && (h("span", { key: '208359e9a4b4c92823fa924ce0e7b0e5419c0cef', slot: "left-icon", class: {
796
801
  readonly,
797
802
  "has-value": !!value,
798
- } }, h("slot", { key: '200b59949e9f50eaa0e42e6125c507179f6a5646', name: "icon" }))), readonly ? (h("ic-typography", null, h("p", null, valueLabelString))) : isMobileOrTablet() && !multiple ? (h("select", Object.assign({ ref: (el) => (this.nativeSelectElement = el), disabled: disabled, onChange: this.handleNativeSelectChange, required: required, id: inputId, "aria-label": label, "aria-describedby": describedBy, "aria-invalid": invalid, onBlur: this.onBlur, onFocus: this.onFocus, onKeyDown: this.handleNativeSelectKeyDown, form: form }, inheritedAttributes), h("option", { value: "", selected: true, disabled: !showClearButton }, placeholder), options.map((option) => option.children ? (h("optgroup", { label: option.label }, option.children.map((child) => this.renderNativeOption(child)))) : (this.renderNativeOption(option))))) : searchable ? (h("div", { class: "searchable-select-container" }, h("input", { class: {
803
+ } }, h("slot", { key: '462c17f5f746f3d54eaff493c990e6527ed7c381', name: "icon" }))), readonly ? (h("ic-typography", null, h("p", null, valueLabelString))) : isMobileOrTablet() && !multiple ? (h("select", Object.assign({ ref: (el) => (this.nativeSelectElement = el), disabled: disabled, onChange: this.handleNativeSelectChange, required: required, id: inputId, "aria-label": label, "aria-describedby": describedBy, "aria-invalid": invalid, onBlur: this.onBlur, onFocus: this.onFocus, onKeyDown: this.handleNativeSelectKeyDown, form: form }, inheritedAttributes), h("option", { value: "", selected: true, disabled: !showClearButton }, placeholder), options.map((option) => option.children ? (h("optgroup", { label: option.label }, option.children.map((child) => this.renderNativeOption(child)))) : (this.renderNativeOption(option))))) : searchable ? (h("div", { class: "searchable-select-container" }, h("input", { class: {
799
804
  "value-text": true,
800
805
  "select-input": true,
801
806
  "with-clear-button": !!searchableSelectInputValue,
@@ -816,13 +821,15 @@ export class Select {
816
821
  } }, valueLabelString || placeholder), h("div", { class: "select-input-end" }, isClearable && h("div", { class: "divider" }), h("span", { class: {
817
822
  "expand-icon": true,
818
823
  "expand-icon-open": open,
819
- }, innerHTML: Expand, "aria-hidden": "true" }))), isClearable && (h("ic-button", { id: "clear-button", "aria-label": "Clear selection", class: "clear-button", innerHTML: Clear, onClick: this.handleClear, onFocus: this.handleClearButtonFocus, onBlur: this.handleClearButtonBlur, size: size, variant: "icon-tertiary", theme: clearButtonFocused ? "light" : "dark" }))))), (!isMobileOrTablet() || multiple) && (h("ic-menu", { key: '7da68ec2635584a01e03cd7c1a4a549677dc5ca4', class: {
824
+ }, innerHTML: Expand, "aria-hidden": "true" }))), isClearable && (h("ic-button", { id: "clear-button", "aria-label": "Clear selection", class: "clear-button", innerHTML: Clear, onClick: this.handleClear, onFocus: this.handleClearButtonFocus, onBlur: this.handleClearButtonBlur, size: size, variant: "icon-tertiary", theme: clearButtonFocused ? "light" : "dark" }))))), (!isMobileOrTablet() || multiple) && (h("ic-menu", { key: '4daeee28961203c0b190687229c0f9f2b4a1d66e', class: {
820
825
  "no-results": loading ||
821
826
  hasTimedOut ||
822
827
  ((_a = noOptions === null || noOptions === void 0 ? void 0 : noOptions[0]) === null || _a === void 0 ? void 0 : _a.label) === emptyOptionListText,
823
828
  }, ref: (el) => (this.menu = el), inputEl: searchable
824
829
  ? this.searchableSelectElement
825
- : this.customSelectElement, inputLabel: label, anchorEl: this.anchorEl, size: size, menuId: menuId, open: open, options: searchable ? filteredOptions : uniqueOptions, value: multiple ? currValue : currValue, fullWidth: fullWidth, selectOnEnter: selectOnEnter, onMenuStateChange: this.handleMenuChange, onMenuOptionSelect: this.handleCustomSelectChange, onMenuOptionSelectAll: this.handleSelectAllChange, onMenuKeyPress: this.handleMenuKeyPress, onUngroupedOptionsSet: this.setUngroupedOptions, onRetryButtonClicked: this.handleRetry, parentEl: this.el, onTimeoutBlur: this.onTimeoutBlur, activationType: searchable || multiple || selectOnEnter ? "manual" : "automatic", closeOnSelect: !multiple, multiSelect: multiple ? true : false, searchableSelect: searchable ? true : false })), multiple && (h("div", { key: '70e9f25c6d4c937a7cdf1afeeb30c125371c0ddb', "aria-live": "polite", role: "status", class: "multi-select-selected-count" })), hasValidationStatus(validationStatus, disabled) && (h("ic-input-validation", { key: '5bc6df7d14d1db099a6047b24b27f068f918711f', class: { "menu-open": open }, ariaLiveMode: "polite", status: validationStatus, message: validationText, for: inputId })))));
830
+ : this.customSelectElement, inputLabel: label, anchorEl: this.anchorEl, size: size, menuId: menuId, open: open, options: searchable ? filteredOptions : uniqueOptions, value: multiple ? currValue : currValue, fullWidth: fullWidth, selectOnEnter: selectOnEnter, onMenuStateChange: this.handleMenuChange, onMenuOptionSelect: this.handleCustomSelectChange, onMenuOptionSelectAll: this.handleSelectAllChange, onMenuKeyPress: this.handleMenuKeyPress, onUngroupedOptionsSet: this.setUngroupedOptions, onRetryButtonClicked: this.handleRetry, parentEl: this.el, onTimeoutBlur: this.onTimeoutBlur, activationType: searchable || multiple || selectOnEnter ? "manual" : "automatic", closeOnSelect: !multiple, multiSelect: multiple ? true : false, searchableSelect: searchable ? true : false })), multiple && (h("div", { key: '87993e273df521157bb8101f5f96639b0cb3503b', "aria-live": "polite", role: "status", class: "multi-select-selected-count" })), h("ic-input-validation", { key: 'c0248fb27e0d97f885c8227ffda4534ab65561ec', class: {
831
+ "menu-open": open,
832
+ }, ariaLiveMode: validationAriaLive, status: showValidation ? validationStatus : "", message: showValidation ? validationText : "", for: inputId }))));
826
833
  }
827
834
  static get is() { return "ic-select"; }
828
835
  static get encapsulation() { return "shadow"; }
@@ -1334,6 +1341,32 @@ export class Select {
1334
1341
  "reflect": false,
1335
1342
  "defaultValue": "\"inherit\""
1336
1343
  },
1344
+ "validationAriaLive": {
1345
+ "type": "string",
1346
+ "mutable": false,
1347
+ "complexType": {
1348
+ "original": "IcAriaLive",
1349
+ "resolved": "\"assertive\" | \"off\" | \"polite\"",
1350
+ "references": {
1351
+ "IcAriaLive": {
1352
+ "location": "import",
1353
+ "path": "../../utils/types",
1354
+ "id": "src/utils/types.ts::IcAriaLive"
1355
+ }
1356
+ }
1357
+ },
1358
+ "required": false,
1359
+ "optional": false,
1360
+ "docs": {
1361
+ "tags": [],
1362
+ "text": "The value of the `aria-live` attribute on the validation message."
1363
+ },
1364
+ "getter": false,
1365
+ "setter": false,
1366
+ "attribute": "validation-aria-live",
1367
+ "reflect": false,
1368
+ "defaultValue": "\"polite\""
1369
+ },
1337
1370
  "validationStatus": {
1338
1371
  "type": "string",
1339
1372
  "mutable": false,