@beeq/core 1.11.0 → 1.11.2

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 (691) hide show
  1. package/dist/beeq/beeq.esm.js +1 -1
  2. package/dist/beeq/beeq.esm.js.map +1 -1
  3. package/dist/beeq/bq-accordion.entry.esm.js.map +1 -1
  4. package/dist/beeq/bq-alert.entry.esm.js.map +1 -1
  5. package/dist/beeq/bq-avatar.entry.esm.js.map +1 -1
  6. package/dist/beeq/bq-badge.entry.esm.js.map +1 -1
  7. package/dist/beeq/bq-breadcrumb-item.entry.esm.js.map +1 -1
  8. package/dist/beeq/bq-breadcrumb.entry.esm.js.map +1 -1
  9. package/dist/beeq/bq-button.bq-icon.entry.esm.js.map +1 -1
  10. package/dist/beeq/bq-card.entry.esm.js.map +1 -1
  11. package/dist/beeq/bq-checkbox.entry.esm.js.map +1 -1
  12. package/dist/beeq/bq-date-picker.entry.esm.js.map +1 -1
  13. package/dist/beeq/bq-dialog.entry.esm.js.map +1 -1
  14. package/dist/beeq/bq-divider.entry.esm.js.map +1 -1
  15. package/dist/beeq/bq-drawer.entry.esm.js.map +1 -1
  16. package/dist/beeq/bq-dropdown.bq-panel.entry.esm.js.map +1 -1
  17. package/dist/beeq/bq-empty-state.entry.esm.js.map +1 -1
  18. package/dist/beeq/bq-input.entry.esm.js.map +1 -1
  19. package/dist/beeq/bq-notification.entry.esm.js.map +1 -1
  20. package/dist/beeq/bq-option-group.entry.esm.js.map +1 -1
  21. package/dist/beeq/bq-option-list.bq-tag.entry.esm.js.map +1 -1
  22. package/dist/beeq/bq-option.entry.esm.js.map +1 -1
  23. package/dist/beeq/bq-page-title.entry.esm.js.map +1 -1
  24. package/dist/beeq/bq-progress.entry.esm.js.map +1 -1
  25. package/dist/beeq/bq-radio-group.entry.esm.js.map +1 -1
  26. package/dist/beeq/bq-radio.entry.esm.js.map +1 -1
  27. package/dist/beeq/bq-select.entry.esm.js.map +1 -1
  28. package/dist/beeq/bq-side-menu-item.entry.esm.js.map +1 -1
  29. package/dist/beeq/bq-side-menu.entry.esm.js.map +1 -1
  30. package/dist/beeq/bq-slider.entry.esm.js.map +1 -1
  31. package/dist/beeq/bq-spinner.entry.esm.js.map +1 -1
  32. package/dist/beeq/bq-status.entry.esm.js.map +1 -1
  33. package/dist/beeq/bq-step-item.entry.esm.js.map +1 -1
  34. package/dist/beeq/bq-steps.entry.esm.js.map +1 -1
  35. package/dist/beeq/bq-switch.entry.esm.js.map +1 -1
  36. package/dist/beeq/bq-tab-group.entry.esm.js.map +1 -1
  37. package/dist/beeq/bq-tab.entry.esm.js.map +1 -1
  38. package/dist/beeq/bq-textarea.entry.esm.js.map +1 -1
  39. package/dist/beeq/bq-toast.entry.esm.js.map +1 -1
  40. package/dist/beeq/bq-tooltip.entry.esm.js.map +1 -1
  41. package/dist/beeq/index.esm.js +1 -1
  42. package/dist/beeq/index.esm.js.map +1 -1
  43. package/dist/beeq/{p-a9643899.entry.js → p-0bf5e367.entry.js} +2 -2
  44. package/dist/beeq/p-0bf5e367.entry.js.map +1 -0
  45. package/dist/beeq/{p-dd896cd8.entry.js → p-16defa87.entry.js} +2 -2
  46. package/dist/beeq/p-16defa87.entry.js.map +1 -0
  47. package/dist/beeq/{p-5ce77af6.entry.js → p-17de1ba4.entry.js} +2 -2
  48. package/dist/beeq/p-17de1ba4.entry.js.map +1 -0
  49. package/dist/beeq/p-1df8fe61.entry.js +6 -0
  50. package/dist/beeq/p-1df8fe61.entry.js.map +1 -0
  51. package/dist/beeq/{p-b520bdb8.entry.js → p-24749f67.entry.js} +2 -2
  52. package/dist/beeq/p-24749f67.entry.js.map +1 -0
  53. package/dist/beeq/{p-8eb8612b.entry.js → p-38add122.entry.js} +2 -2
  54. package/dist/beeq/p-38add122.entry.js.map +1 -0
  55. package/dist/beeq/{p-d1dd36ca.entry.js → p-454fa535.entry.js} +2 -2
  56. package/dist/beeq/p-454fa535.entry.js.map +1 -0
  57. package/dist/beeq/{p-ba12d135.entry.js → p-4647a0fb.entry.js} +2 -2
  58. package/dist/beeq/p-4647a0fb.entry.js.map +1 -0
  59. package/dist/beeq/{p-87430ad8.entry.js → p-4725a142.entry.js} +2 -2
  60. package/dist/beeq/p-4725a142.entry.js.map +1 -0
  61. package/dist/beeq/{p-6852a0b0.entry.js → p-51351eed.entry.js} +2 -2
  62. package/dist/beeq/p-51351eed.entry.js.map +1 -0
  63. package/dist/beeq/{p-96f6c9ae.entry.js → p-5b0a56e7.entry.js} +2 -2
  64. package/dist/beeq/p-5b0a56e7.entry.js.map +1 -0
  65. package/dist/beeq/{p-3dca7a14.entry.js → p-5c23324d.entry.js} +2 -2
  66. package/dist/beeq/p-5c23324d.entry.js.map +1 -0
  67. package/dist/beeq/{p-eb2cfa90.entry.js → p-5df7df5d.entry.js} +2 -2
  68. package/dist/beeq/p-5df7df5d.entry.js.map +1 -0
  69. package/dist/beeq/{p-c023718e.entry.js → p-5e8c8e90.entry.js} +2 -2
  70. package/dist/beeq/p-5e8c8e90.entry.js.map +1 -0
  71. package/dist/beeq/{p-1c6ef374.entry.js → p-662578a2.entry.js} +2 -2
  72. package/dist/beeq/p-662578a2.entry.js.map +1 -0
  73. package/dist/beeq/{p-3c7397cf.entry.js → p-6ae2ca4b.entry.js} +2 -2
  74. package/dist/beeq/p-6ae2ca4b.entry.js.map +1 -0
  75. package/dist/beeq/{p-0deed5d1.entry.js → p-7ca73c06.entry.js} +2 -2
  76. package/dist/beeq/p-7ca73c06.entry.js.map +1 -0
  77. package/dist/beeq/{p-7063e5c2.entry.js → p-84e62655.entry.js} +2 -2
  78. package/dist/beeq/p-84e62655.entry.js.map +1 -0
  79. package/dist/beeq/{p-dc4d2d77.entry.js → p-93d6f4f0.entry.js} +2 -2
  80. package/dist/beeq/p-93d6f4f0.entry.js.map +1 -0
  81. package/dist/beeq/{p-2f008ed1.entry.js → p-9585221e.entry.js} +2 -2
  82. package/dist/beeq/p-9585221e.entry.js.map +1 -0
  83. package/dist/beeq/{p-60db3689.entry.js → p-9c9a83f8.entry.js} +2 -2
  84. package/dist/beeq/p-9c9a83f8.entry.js.map +1 -0
  85. package/dist/beeq/{p-477f032f.entry.js → p-9e9baa82.entry.js} +2 -2
  86. package/dist/beeq/p-9e9baa82.entry.js.map +1 -0
  87. package/dist/beeq/{p-DMf9D39m.js → p-BNvWMggA.js} +2 -2
  88. package/dist/beeq/{p-DMf9D39m.js.map → p-BNvWMggA.js.map} +1 -1
  89. package/dist/beeq/p-BOf9EC3C.js +7 -0
  90. package/dist/beeq/p-BOf9EC3C.js.map +1 -0
  91. package/dist/beeq/{p-Ci39rxuU.js → p-BRbYDZoo.js} +2 -2
  92. package/dist/beeq/{p-Ci39rxuU.js.map → p-BRbYDZoo.js.map} +1 -1
  93. package/dist/beeq/{p-D9ofIraD.js → p-CVw85-WU.js} +1 -1
  94. package/dist/beeq/p-CVw85-WU.js.map +1 -0
  95. package/dist/beeq/p-CgIw4Syg.js +6 -0
  96. package/dist/beeq/{p-y49NXy_H.js.map → p-CgIw4Syg.js.map} +1 -1
  97. package/dist/beeq/p-DdvbF5yL.js.map +1 -1
  98. package/dist/beeq/{p-48811a09.entry.js → p-b1d2e472.entry.js} +2 -2
  99. package/dist/beeq/p-b1d2e472.entry.js.map +1 -0
  100. package/dist/beeq/p-b7efb629.entry.js +6 -0
  101. package/dist/beeq/p-b7efb629.entry.js.map +1 -0
  102. package/dist/beeq/{p-9305e1a2.entry.js → p-b88b2573.entry.js} +2 -2
  103. package/dist/beeq/p-b88b2573.entry.js.map +1 -0
  104. package/dist/beeq/p-bfca08f5.entry.js +6 -0
  105. package/dist/beeq/p-bfca08f5.entry.js.map +1 -0
  106. package/dist/beeq/{p-6a10175b.entry.js → p-c63b89d2.entry.js} +2 -2
  107. package/dist/beeq/p-c63b89d2.entry.js.map +1 -0
  108. package/dist/beeq/{p-3e8980ff.entry.js → p-ca93325b.entry.js} +2 -2
  109. package/dist/beeq/p-ca93325b.entry.js.map +1 -0
  110. package/dist/beeq/{p-04745600.entry.js → p-cb0639d5.entry.js} +2 -2
  111. package/dist/beeq/p-cb0639d5.entry.js.map +1 -0
  112. package/dist/beeq/{p-78be94d2.entry.js → p-cd53041f.entry.js} +2 -2
  113. package/dist/beeq/p-cd53041f.entry.js.map +1 -0
  114. package/dist/beeq/{p-6d429afd.entry.js → p-d31e8b6a.entry.js} +2 -2
  115. package/dist/beeq/p-d31e8b6a.entry.js.map +1 -0
  116. package/dist/beeq/{p-f12a127c.entry.js → p-d8118f0b.entry.js} +2 -2
  117. package/dist/beeq/p-d8118f0b.entry.js.map +1 -0
  118. package/dist/beeq/p-d9c5ab1d.entry.js +6 -0
  119. package/dist/beeq/p-d9c5ab1d.entry.js.map +1 -0
  120. package/dist/beeq/{p-1421f4a3.entry.js → p-dc5aa386.entry.js} +2 -2
  121. package/dist/beeq/p-dc5aa386.entry.js.map +1 -0
  122. package/dist/beeq/{p-fbc38c77.entry.js → p-dcda1181.entry.js} +2 -2
  123. package/dist/beeq/p-dcda1181.entry.js.map +1 -0
  124. package/dist/beeq/p-eaa8c123.entry.js +6 -0
  125. package/dist/beeq/p-eaa8c123.entry.js.map +1 -0
  126. package/dist/beeq/{p-8280145e.entry.js → p-eb47c1ae.entry.js} +2 -2
  127. package/dist/beeq/p-eb47c1ae.entry.js.map +1 -0
  128. package/dist/beeq/{p-f8d5c1ab.entry.js → p-eb6eac82.entry.js} +2 -2
  129. package/dist/beeq/p-eb6eac82.entry.js.map +1 -0
  130. package/dist/beeq/{p-37a2fb82.entry.js → p-f691f00c.entry.js} +2 -2
  131. package/dist/beeq/p-f691f00c.entry.js.map +1 -0
  132. package/dist/beeq/p-igOoibr-.js +6 -0
  133. package/dist/beeq/p-igOoibr-.js.map +1 -0
  134. package/dist/beeq/{p-CVMdKx0v.js → p-lysmVw2n.js} +2 -2
  135. package/dist/beeq/{p-CVMdKx0v.js.map → p-lysmVw2n.js.map} +1 -1
  136. package/dist/beeq.html-custom-data.json +40 -49
  137. package/dist/cjs/beeq.cjs.js +3 -5
  138. package/dist/cjs/beeq.cjs.js.map +1 -1
  139. package/dist/cjs/bq-accordion-group.cjs.entry.js +1 -3
  140. package/dist/cjs/bq-accordion.cjs.entry.js +18 -10
  141. package/dist/cjs/bq-accordion.entry.cjs.js.map +1 -1
  142. package/dist/cjs/bq-alert.cjs.entry.js +12 -11
  143. package/dist/cjs/bq-alert.entry.cjs.js.map +1 -1
  144. package/dist/cjs/bq-avatar.cjs.entry.js +5 -7
  145. package/dist/cjs/bq-avatar.entry.cjs.js.map +1 -1
  146. package/dist/cjs/bq-badge.cjs.entry.js +4 -4
  147. package/dist/cjs/bq-badge.entry.cjs.js.map +1 -1
  148. package/dist/cjs/bq-breadcrumb-item.cjs.entry.js +4 -6
  149. package/dist/cjs/bq-breadcrumb-item.entry.cjs.js.map +1 -1
  150. package/dist/cjs/bq-breadcrumb.cjs.entry.js +6 -4
  151. package/dist/cjs/bq-breadcrumb.entry.cjs.js.map +1 -1
  152. package/dist/cjs/bq-button.bq-icon.entry.cjs.js.map +1 -1
  153. package/dist/cjs/bq-button_2.cjs.entry.js +14 -12
  154. package/dist/cjs/bq-card.cjs.entry.js +2 -4
  155. package/dist/cjs/bq-card.entry.cjs.js.map +1 -1
  156. package/dist/cjs/bq-checkbox.cjs.entry.js +5 -5
  157. package/dist/cjs/bq-checkbox.entry.cjs.js.map +1 -1
  158. package/dist/cjs/bq-date-picker.cjs.entry.js +69 -26
  159. package/dist/cjs/bq-date-picker.entry.cjs.js.map +1 -1
  160. package/dist/cjs/bq-dialog.cjs.entry.js +12 -8
  161. package/dist/cjs/bq-dialog.entry.cjs.js.map +1 -1
  162. package/dist/cjs/bq-divider.cjs.entry.js +7 -7
  163. package/dist/cjs/bq-divider.entry.cjs.js.map +1 -1
  164. package/dist/cjs/bq-drawer.cjs.entry.js +8 -6
  165. package/dist/cjs/bq-drawer.entry.cjs.js.map +1 -1
  166. package/dist/cjs/bq-dropdown.bq-panel.entry.cjs.js.map +1 -1
  167. package/dist/cjs/bq-dropdown_2.cjs.entry.js +12 -8
  168. package/dist/cjs/bq-empty-state.cjs.entry.js +9 -7
  169. package/dist/cjs/bq-empty-state.entry.cjs.js.map +1 -1
  170. package/dist/cjs/bq-input.cjs.entry.js +29 -23
  171. package/dist/cjs/bq-input.entry.cjs.js.map +1 -1
  172. package/dist/cjs/bq-notification.cjs.entry.js +10 -6
  173. package/dist/cjs/bq-notification.entry.cjs.js.map +1 -1
  174. package/dist/cjs/bq-option-group.cjs.entry.js +2 -4
  175. package/dist/cjs/bq-option-group.entry.cjs.js.map +1 -1
  176. package/dist/cjs/bq-option-list.bq-tag.entry.cjs.js.map +1 -1
  177. package/dist/cjs/bq-option-list_2.cjs.entry.js +45 -26
  178. package/dist/cjs/bq-option.cjs.entry.js +17 -12
  179. package/dist/cjs/bq-option.entry.cjs.js.map +1 -1
  180. package/dist/cjs/bq-page-title.cjs.entry.js +10 -6
  181. package/dist/cjs/bq-page-title.entry.cjs.js.map +1 -1
  182. package/dist/cjs/bq-progress.cjs.entry.js +6 -8
  183. package/dist/cjs/bq-progress.entry.cjs.js.map +1 -1
  184. package/dist/cjs/bq-radio-group.cjs.entry.js +15 -11
  185. package/dist/cjs/bq-radio-group.entry.cjs.js.map +1 -1
  186. package/dist/cjs/bq-radio.cjs.entry.js +4 -4
  187. package/dist/cjs/bq-radio.entry.cjs.js.map +1 -1
  188. package/dist/cjs/bq-select.cjs.entry.js +75 -30
  189. package/dist/cjs/bq-select.entry.cjs.js.map +1 -1
  190. package/dist/cjs/bq-side-menu-item.cjs.entry.js +6 -6
  191. package/dist/cjs/bq-side-menu-item.entry.cjs.js.map +1 -1
  192. package/dist/cjs/bq-side-menu.cjs.entry.js +11 -9
  193. package/dist/cjs/bq-side-menu.entry.cjs.js.map +1 -1
  194. package/dist/cjs/bq-slider.cjs.entry.js +25 -14
  195. package/dist/cjs/bq-slider.entry.cjs.js.map +1 -1
  196. package/dist/cjs/bq-spinner.cjs.entry.js +12 -14
  197. package/dist/cjs/bq-spinner.entry.cjs.js.map +1 -1
  198. package/dist/cjs/bq-status.cjs.entry.js +2 -4
  199. package/dist/cjs/bq-status.entry.cjs.js.map +1 -1
  200. package/dist/cjs/bq-step-item.cjs.entry.js +7 -9
  201. package/dist/cjs/bq-step-item.entry.cjs.js.map +1 -1
  202. package/dist/cjs/bq-steps.cjs.entry.js +5 -5
  203. package/dist/cjs/bq-steps.entry.cjs.js.map +1 -1
  204. package/dist/cjs/bq-switch.cjs.entry.js +8 -6
  205. package/dist/cjs/bq-switch.entry.cjs.js.map +1 -1
  206. package/dist/cjs/bq-tab-group.cjs.entry.js +9 -9
  207. package/dist/cjs/bq-tab-group.entry.cjs.js.map +1 -1
  208. package/dist/cjs/bq-tab.cjs.entry.js +8 -6
  209. package/dist/cjs/bq-tab.entry.cjs.js.map +1 -1
  210. package/dist/cjs/bq-textarea.cjs.entry.js +16 -15
  211. package/dist/cjs/bq-textarea.entry.cjs.js.map +1 -1
  212. package/dist/cjs/bq-toast.cjs.entry.js +4 -7
  213. package/dist/cjs/bq-toast.entry.cjs.js.map +1 -1
  214. package/dist/cjs/bq-tooltip.cjs.entry.js +9 -5
  215. package/dist/cjs/bq-tooltip.entry.cjs.js.map +1 -1
  216. package/dist/cjs/date-C-h2CBps.js +170 -0
  217. package/dist/cjs/date-C-h2CBps.js.map +1 -0
  218. package/dist/cjs/{debounce-DFaAa1Cu.js → debounce-D0tIpUuS.js} +4 -4
  219. package/dist/cjs/debounce-D0tIpUuS.js.map +1 -0
  220. package/dist/cjs/{index-tFN0ax76.js → index-D7RDSS0K.js} +73 -47
  221. package/dist/cjs/{index-tFN0ax76.js.map → index-D7RDSS0K.js.map} +1 -1
  222. package/dist/cjs/{index-CLoLF-_B.js → index-g8MkV15i.js} +78 -65
  223. package/dist/cjs/index-g8MkV15i.js.map +1 -0
  224. package/dist/cjs/index.cjs.js +7 -6
  225. package/dist/cjs/index.cjs.js.map +1 -1
  226. package/dist/cjs/{isDefined-K4EcmGLZ.js → isDefined-D24L82z9.js} +3 -3
  227. package/dist/cjs/{isDefined-K4EcmGLZ.js.map → isDefined-D24L82z9.js.map} +1 -1
  228. package/dist/cjs/{isString-CHgmxASW.js → isString-CA9m1aBg.js} +3 -3
  229. package/dist/cjs/{isString-CHgmxASW.js.map → isString-CA9m1aBg.js.map} +1 -1
  230. package/dist/cjs/loader.cjs.js +2 -4
  231. package/dist/cjs/{stringToArray-DTx7uqZ4.js → stringToArray-B747BpEA.js} +4 -4
  232. package/dist/cjs/{stringToArray-DTx7uqZ4.js.map → stringToArray-B747BpEA.js.map} +1 -1
  233. package/dist/cjs/transition-C0S-pYqN.js.map +1 -1
  234. package/dist/collection/collection-manifest.json +2 -2
  235. package/dist/collection/components/accordion/bq-accordion.js +17 -11
  236. package/dist/collection/components/accordion/bq-accordion.js.map +1 -1
  237. package/dist/collection/components/accordion/helper/index.js +6 -2
  238. package/dist/collection/components/accordion/helper/index.js.map +1 -1
  239. package/dist/collection/components/accordion/scss/bq-accordion.css +1 -1
  240. package/dist/collection/components/accordion-group/bq-accordion-group.js +6 -6
  241. package/dist/collection/components/alert/bq-alert.js +25 -22
  242. package/dist/collection/components/alert/bq-alert.js.map +1 -1
  243. package/dist/collection/components/avatar/bq-avatar.js +16 -16
  244. package/dist/collection/components/avatar/bq-avatar.js.map +1 -1
  245. package/dist/collection/components/badge/bq-badge.js +10 -8
  246. package/dist/collection/components/badge/bq-badge.js.map +1 -1
  247. package/dist/collection/components/breadcrumb/bq-breadcrumb.js +7 -3
  248. package/dist/collection/components/breadcrumb/bq-breadcrumb.js.map +1 -1
  249. package/dist/collection/components/breadcrumb-item/bq-breadcrumb-item.js +6 -6
  250. package/dist/collection/components/breadcrumb-item/bq-breadcrumb-item.js.map +1 -1
  251. package/dist/collection/components/button/bq-button.js +23 -19
  252. package/dist/collection/components/button/bq-button.js.map +1 -1
  253. package/dist/collection/components/button/scss/bq-button.css +1 -1
  254. package/dist/collection/components/card/bq-card.js +5 -5
  255. package/dist/collection/components/card/bq-card.js.map +1 -1
  256. package/dist/collection/components/checkbox/bq-checkbox.js +19 -17
  257. package/dist/collection/components/checkbox/bq-checkbox.js.map +1 -1
  258. package/dist/collection/components/date-picker/bq-date-picker.js +103 -61
  259. package/dist/collection/components/date-picker/bq-date-picker.js.map +1 -1
  260. package/dist/collection/components/dialog/bq-dialog.js +20 -14
  261. package/dist/collection/components/dialog/bq-dialog.js.map +1 -1
  262. package/dist/collection/components/divider/bq-divider.js +17 -15
  263. package/dist/collection/components/divider/bq-divider.js.map +1 -1
  264. package/dist/collection/components/drawer/bq-drawer.js +16 -12
  265. package/dist/collection/components/drawer/bq-drawer.js.map +1 -1
  266. package/dist/collection/components/dropdown/bq-dropdown.js +18 -14
  267. package/dist/collection/components/dropdown/bq-dropdown.js.map +1 -1
  268. package/dist/collection/components/empty-state/bq-empty-state.js +10 -6
  269. package/dist/collection/components/empty-state/bq-empty-state.js.map +1 -1
  270. package/dist/collection/components/icon/bq-icon.js +17 -17
  271. package/dist/collection/components/icon/bq-icon.js.map +1 -1
  272. package/dist/collection/components/input/bq-input.js +89 -86
  273. package/dist/collection/components/input/bq-input.js.map +1 -1
  274. package/dist/collection/components/notification/bq-notification.js +21 -15
  275. package/dist/collection/components/notification/bq-notification.js.map +1 -1
  276. package/dist/collection/components/option/bq-option.js +42 -16
  277. package/dist/collection/components/option/bq-option.js.map +1 -1
  278. package/dist/collection/components/option/scss/bq-option.css +1 -1
  279. package/dist/collection/components/option-group/bq-option-group.js +1 -1
  280. package/dist/collection/components/option-group/bq-option-group.js.map +1 -1
  281. package/dist/collection/components/option-list/bq-option-list.js +1 -1
  282. package/dist/collection/components/option-list/bq-option-list.js.map +1 -1
  283. package/dist/collection/components/page-title/bq-page-title.js +9 -3
  284. package/dist/collection/components/page-title/bq-page-title.js.map +1 -1
  285. package/dist/collection/components/panel/bq-panel.js +10 -8
  286. package/dist/collection/components/panel/bq-panel.js.map +1 -1
  287. package/dist/collection/components/progress/bq-progress.js +14 -14
  288. package/dist/collection/components/progress/bq-progress.js.map +1 -1
  289. package/dist/collection/components/radio/bq-radio.js +16 -14
  290. package/dist/collection/components/radio/bq-radio.js.map +1 -1
  291. package/dist/collection/components/radio-group/bq-radio-group.js +25 -19
  292. package/dist/collection/components/radio-group/bq-radio-group.js.map +1 -1
  293. package/dist/collection/components/select/bq-select.js +101 -54
  294. package/dist/collection/components/select/bq-select.js.map +1 -1
  295. package/dist/collection/components/side-menu/bq-side-menu.js +12 -8
  296. package/dist/collection/components/side-menu/bq-side-menu.js.map +1 -1
  297. package/dist/collection/components/side-menu/scss/bq-side-menu.css +1 -1
  298. package/dist/collection/components/side-menu-item/bq-side-menu-item.js +8 -6
  299. package/dist/collection/components/side-menu-item/bq-side-menu-item.js.map +1 -1
  300. package/dist/collection/components/slider/bq-slider.js +36 -23
  301. package/dist/collection/components/slider/bq-slider.js.map +1 -1
  302. package/dist/collection/components/spinner/bq-spinner.js +14 -14
  303. package/dist/collection/components/spinner/bq-spinner.js.map +1 -1
  304. package/dist/collection/components/spinner/bq-spinner.types.js +1 -1
  305. package/dist/collection/components/spinner/bq-spinner.types.js.map +1 -1
  306. package/dist/collection/components/spinner/scss/bq-spinner.css +1 -1
  307. package/dist/collection/components/status/bq-status.js +3 -3
  308. package/dist/collection/components/status/bq-status.js.map +1 -1
  309. package/dist/collection/components/step-item/bq-step-item.js +11 -11
  310. package/dist/collection/components/step-item/bq-step-item.js.map +1 -1
  311. package/dist/collection/components/steps/bq-steps.js +8 -6
  312. package/dist/collection/components/steps/bq-steps.js.map +1 -1
  313. package/dist/collection/components/switch/bq-switch.js +22 -18
  314. package/dist/collection/components/switch/bq-switch.js.map +1 -1
  315. package/dist/collection/components/tab/bq-tab.js +17 -13
  316. package/dist/collection/components/tab/bq-tab.js.map +1 -1
  317. package/dist/collection/components/tab-group/bq-tab-group.js +15 -13
  318. package/dist/collection/components/tab-group/bq-tab-group.js.map +1 -1
  319. package/dist/collection/components/tag/bq-tag.js +59 -38
  320. package/dist/collection/components/tag/bq-tag.js.map +1 -1
  321. package/dist/collection/components/tag/helper/index.js.map +1 -1
  322. package/dist/collection/components/tag/scss/bq-tag.css +1 -1
  323. package/dist/collection/components/textarea/bq-textarea.js +51 -62
  324. package/dist/collection/components/textarea/bq-textarea.js.map +1 -1
  325. package/dist/collection/components/toast/bq-toast.js +11 -12
  326. package/dist/collection/components/toast/bq-toast.js.map +1 -1
  327. package/dist/collection/components/tooltip/bq-tooltip.js +14 -8
  328. package/dist/collection/components/tooltip/bq-tooltip.js.map +1 -1
  329. package/dist/collection/services/interfaces/floating-ui.js.map +1 -1
  330. package/dist/collection/services/libraries/floating-ui/index.js +34 -25
  331. package/dist/collection/services/libraries/floating-ui/index.js.map +1 -1
  332. package/dist/collection/shared/test-utils/sleep.js +1 -1
  333. package/dist/collection/shared/test-utils/sleep.js.map +1 -1
  334. package/dist/collection/shared/utils/date.js +163 -0
  335. package/dist/collection/shared/utils/date.js.map +1 -0
  336. package/dist/collection/shared/utils/debounce.js +2 -1
  337. package/dist/collection/shared/utils/debounce.js.map +1 -1
  338. package/dist/collection/shared/utils/index.js +1 -0
  339. package/dist/collection/shared/utils/index.js.map +1 -1
  340. package/dist/collection/shared/utils/isString.js +1 -1
  341. package/dist/collection/shared/utils/isString.js.map +1 -1
  342. package/dist/collection/shared/utils/setRafTimeout.js +0 -1
  343. package/dist/collection/shared/utils/setRafTimeout.js.map +1 -1
  344. package/dist/collection/tools/angular-value-accessor-config.js.map +1 -1
  345. package/dist/collection/tools/generate-custom-elements-json.js +2 -2
  346. package/dist/collection/tools/generate-custom-elements-json.js.map +1 -1
  347. package/dist/collection/tools/vue-model-config.js.map +1 -1
  348. package/dist/components/bq-accordion-group.js +1 -1
  349. package/dist/components/bq-accordion-group.js.map +1 -1
  350. package/dist/components/bq-accordion.js +1 -1
  351. package/dist/components/bq-accordion.js.map +1 -1
  352. package/dist/components/bq-alert.js +1 -1
  353. package/dist/components/bq-alert.js.map +1 -1
  354. package/dist/components/bq-avatar.js +1 -1
  355. package/dist/components/bq-avatar.js.map +1 -1
  356. package/dist/components/bq-badge.js +1 -1
  357. package/dist/components/bq-breadcrumb-item.js +1 -1
  358. package/dist/components/bq-breadcrumb-item.js.map +1 -1
  359. package/dist/components/bq-breadcrumb.js +1 -1
  360. package/dist/components/bq-breadcrumb.js.map +1 -1
  361. package/dist/components/bq-button.js +1 -1
  362. package/dist/components/bq-card.js +1 -1
  363. package/dist/components/bq-card.js.map +1 -1
  364. package/dist/components/bq-checkbox.js +1 -1
  365. package/dist/components/bq-checkbox.js.map +1 -1
  366. package/dist/components/bq-date-picker.js +1 -1
  367. package/dist/components/bq-date-picker.js.map +1 -1
  368. package/dist/components/bq-dialog.js +1 -1
  369. package/dist/components/bq-dialog.js.map +1 -1
  370. package/dist/components/bq-divider.js +1 -1
  371. package/dist/components/bq-drawer.js +1 -1
  372. package/dist/components/bq-drawer.js.map +1 -1
  373. package/dist/components/bq-dropdown.js +1 -1
  374. package/dist/components/bq-empty-state.js +1 -1
  375. package/dist/components/bq-empty-state.js.map +1 -1
  376. package/dist/components/bq-icon.js +1 -1
  377. package/dist/components/bq-input.js +1 -1
  378. package/dist/components/bq-input.js.map +1 -1
  379. package/dist/components/bq-notification.js +1 -1
  380. package/dist/components/bq-notification.js.map +1 -1
  381. package/dist/components/bq-option-group.js +1 -1
  382. package/dist/components/bq-option-group.js.map +1 -1
  383. package/dist/components/bq-option-list.js +1 -1
  384. package/dist/components/bq-option.js +1 -1
  385. package/dist/components/bq-option.js.map +1 -1
  386. package/dist/components/bq-page-title.js +1 -1
  387. package/dist/components/bq-page-title.js.map +1 -1
  388. package/dist/components/bq-panel.js +1 -1
  389. package/dist/components/bq-progress.js +1 -1
  390. package/dist/components/bq-progress.js.map +1 -1
  391. package/dist/components/bq-radio-group.js +1 -1
  392. package/dist/components/bq-radio-group.js.map +1 -1
  393. package/dist/components/bq-radio.js +1 -1
  394. package/dist/components/bq-radio.js.map +1 -1
  395. package/dist/components/bq-select.js +1 -1
  396. package/dist/components/bq-select.js.map +1 -1
  397. package/dist/components/bq-side-menu-item.js +1 -1
  398. package/dist/components/bq-side-menu-item.js.map +1 -1
  399. package/dist/components/bq-side-menu.js +1 -1
  400. package/dist/components/bq-side-menu.js.map +1 -1
  401. package/dist/components/bq-slider.js +1 -1
  402. package/dist/components/bq-slider.js.map +1 -1
  403. package/dist/components/bq-spinner.js +1 -1
  404. package/dist/components/bq-spinner.js.map +1 -1
  405. package/dist/components/bq-status.js +1 -1
  406. package/dist/components/bq-status.js.map +1 -1
  407. package/dist/components/bq-step-item.js +1 -1
  408. package/dist/components/bq-step-item.js.map +1 -1
  409. package/dist/components/bq-steps.js +1 -1
  410. package/dist/components/bq-steps.js.map +1 -1
  411. package/dist/components/bq-switch.js +1 -1
  412. package/dist/components/bq-switch.js.map +1 -1
  413. package/dist/components/bq-tab-group.js +1 -1
  414. package/dist/components/bq-tab-group.js.map +1 -1
  415. package/dist/components/bq-tab.js +1 -1
  416. package/dist/components/bq-tab.js.map +1 -1
  417. package/dist/components/bq-tag.js +1 -1
  418. package/dist/components/bq-textarea.js +1 -1
  419. package/dist/components/bq-textarea.js.map +1 -1
  420. package/dist/components/bq-toast.js +1 -1
  421. package/dist/components/bq-toast.js.map +1 -1
  422. package/dist/components/bq-tooltip.js +1 -1
  423. package/dist/components/index.js +1 -1
  424. package/dist/components/index.js.map +1 -1
  425. package/dist/components/{p-C4Jb3i-D.js → p-16lKXCDk.js} +2 -2
  426. package/dist/components/p-16lKXCDk.js.map +1 -0
  427. package/dist/components/{p-CjS2vgik.js → p-A6e1tN-B.js} +2 -2
  428. package/dist/components/p-A6e1tN-B.js.map +1 -0
  429. package/dist/components/{p-5er2o4Mn.js → p-B5XEhmuc.js} +2 -2
  430. package/dist/components/{p-5er2o4Mn.js.map → p-B5XEhmuc.js.map} +1 -1
  431. package/dist/components/{p-Ci39rxuU.js → p-BRbYDZoo.js} +2 -2
  432. package/dist/components/{p-Bs3hKCXS.js → p-CIV0haMJ.js} +2 -2
  433. package/dist/components/p-CIV0haMJ.js.map +1 -0
  434. package/dist/components/{p-D9ofIraD.js → p-CVw85-WU.js} +1 -1
  435. package/dist/components/p-CVw85-WU.js.map +1 -0
  436. package/dist/components/p-CXUO6Zub.js +6 -0
  437. package/dist/components/p-CXUO6Zub.js.map +1 -0
  438. package/dist/components/p-CgIw4Syg.js +6 -0
  439. package/dist/components/p-CgIw4Syg.js.map +1 -0
  440. package/dist/components/{p-k2047NJf.js → p-D14_9VoZ.js} +2 -2
  441. package/dist/components/{p-k2047NJf.js.map → p-D14_9VoZ.js.map} +1 -1
  442. package/dist/components/{p-fQPjV9jm.js → p-DGysEMss.js} +2 -2
  443. package/dist/components/p-DGysEMss.js.map +1 -0
  444. package/dist/components/p-DHdYy1q5.js +6 -0
  445. package/dist/components/p-DHdYy1q5.js.map +1 -0
  446. package/dist/components/p-DdvbF5yL.js.map +1 -1
  447. package/dist/components/{p-BIl7Vq5P.js → p-DokL_HVP.js} +2 -2
  448. package/dist/components/p-DokL_HVP.js.map +1 -0
  449. package/dist/components/{p-BPVTwD6U.js → p-eRUe5rRq.js} +2 -2
  450. package/dist/components/p-eRUe5rRq.js.map +1 -0
  451. package/dist/components/{p-CVMdKx0v.js → p-lysmVw2n.js} +2 -2
  452. package/dist/components/{p-CVMdKx0v.js.map → p-lysmVw2n.js.map} +1 -1
  453. package/dist/custom-elements.json +804 -799
  454. package/dist/esm/beeq.js +4 -6
  455. package/dist/esm/beeq.js.map +1 -1
  456. package/dist/esm/bq-accordion-group.entry.js +1 -3
  457. package/dist/esm/bq-accordion.entry.js +18 -10
  458. package/dist/esm/bq-accordion.entry.js.map +1 -1
  459. package/dist/esm/bq-alert.entry.js +12 -11
  460. package/dist/esm/bq-alert.entry.js.map +1 -1
  461. package/dist/esm/bq-avatar.entry.js +5 -7
  462. package/dist/esm/bq-avatar.entry.js.map +1 -1
  463. package/dist/esm/bq-badge.entry.js +4 -4
  464. package/dist/esm/bq-badge.entry.js.map +1 -1
  465. package/dist/esm/bq-breadcrumb-item.entry.js +4 -6
  466. package/dist/esm/bq-breadcrumb-item.entry.js.map +1 -1
  467. package/dist/esm/bq-breadcrumb.entry.js +6 -4
  468. package/dist/esm/bq-breadcrumb.entry.js.map +1 -1
  469. package/dist/esm/bq-button.bq-icon.entry.js.map +1 -1
  470. package/dist/esm/bq-button_2.entry.js +14 -12
  471. package/dist/esm/bq-card.entry.js +2 -4
  472. package/dist/esm/bq-card.entry.js.map +1 -1
  473. package/dist/esm/bq-checkbox.entry.js +5 -5
  474. package/dist/esm/bq-checkbox.entry.js.map +1 -1
  475. package/dist/esm/bq-date-picker.entry.js +69 -26
  476. package/dist/esm/bq-date-picker.entry.js.map +1 -1
  477. package/dist/esm/bq-dialog.entry.js +12 -8
  478. package/dist/esm/bq-dialog.entry.js.map +1 -1
  479. package/dist/esm/bq-divider.entry.js +7 -7
  480. package/dist/esm/bq-divider.entry.js.map +1 -1
  481. package/dist/esm/bq-drawer.entry.js +8 -6
  482. package/dist/esm/bq-drawer.entry.js.map +1 -1
  483. package/dist/esm/bq-dropdown.bq-panel.entry.js.map +1 -1
  484. package/dist/esm/bq-dropdown_2.entry.js +12 -8
  485. package/dist/esm/bq-empty-state.entry.js +9 -7
  486. package/dist/esm/bq-empty-state.entry.js.map +1 -1
  487. package/dist/esm/bq-input.entry.js +29 -23
  488. package/dist/esm/bq-input.entry.js.map +1 -1
  489. package/dist/esm/bq-notification.entry.js +10 -6
  490. package/dist/esm/bq-notification.entry.js.map +1 -1
  491. package/dist/esm/bq-option-group.entry.js +2 -4
  492. package/dist/esm/bq-option-group.entry.js.map +1 -1
  493. package/dist/esm/bq-option-list.bq-tag.entry.js.map +1 -1
  494. package/dist/esm/bq-option-list_2.entry.js +45 -26
  495. package/dist/esm/bq-option.entry.js +17 -12
  496. package/dist/esm/bq-option.entry.js.map +1 -1
  497. package/dist/esm/bq-page-title.entry.js +10 -6
  498. package/dist/esm/bq-page-title.entry.js.map +1 -1
  499. package/dist/esm/bq-progress.entry.js +6 -8
  500. package/dist/esm/bq-progress.entry.js.map +1 -1
  501. package/dist/esm/bq-radio-group.entry.js +15 -11
  502. package/dist/esm/bq-radio-group.entry.js.map +1 -1
  503. package/dist/esm/bq-radio.entry.js +4 -4
  504. package/dist/esm/bq-radio.entry.js.map +1 -1
  505. package/dist/esm/bq-select.entry.js +75 -30
  506. package/dist/esm/bq-select.entry.js.map +1 -1
  507. package/dist/esm/bq-side-menu-item.entry.js +6 -6
  508. package/dist/esm/bq-side-menu-item.entry.js.map +1 -1
  509. package/dist/esm/bq-side-menu.entry.js +11 -9
  510. package/dist/esm/bq-side-menu.entry.js.map +1 -1
  511. package/dist/esm/bq-slider.entry.js +25 -14
  512. package/dist/esm/bq-slider.entry.js.map +1 -1
  513. package/dist/esm/bq-spinner.entry.js +12 -14
  514. package/dist/esm/bq-spinner.entry.js.map +1 -1
  515. package/dist/esm/bq-status.entry.js +2 -4
  516. package/dist/esm/bq-status.entry.js.map +1 -1
  517. package/dist/esm/bq-step-item.entry.js +7 -9
  518. package/dist/esm/bq-step-item.entry.js.map +1 -1
  519. package/dist/esm/bq-steps.entry.js +5 -5
  520. package/dist/esm/bq-steps.entry.js.map +1 -1
  521. package/dist/esm/bq-switch.entry.js +8 -6
  522. package/dist/esm/bq-switch.entry.js.map +1 -1
  523. package/dist/esm/bq-tab-group.entry.js +9 -9
  524. package/dist/esm/bq-tab-group.entry.js.map +1 -1
  525. package/dist/esm/bq-tab.entry.js +8 -6
  526. package/dist/esm/bq-tab.entry.js.map +1 -1
  527. package/dist/esm/bq-textarea.entry.js +16 -15
  528. package/dist/esm/bq-textarea.entry.js.map +1 -1
  529. package/dist/esm/bq-toast.entry.js +4 -7
  530. package/dist/esm/bq-toast.entry.js.map +1 -1
  531. package/dist/esm/bq-tooltip.entry.js +9 -5
  532. package/dist/esm/bq-tooltip.entry.js.map +1 -1
  533. package/dist/esm/date-igOoibr-.js +167 -0
  534. package/dist/esm/date-igOoibr-.js.map +1 -0
  535. package/dist/esm/{debounce-cjfQylgg.js → debounce-gVeuteEJ.js} +4 -4
  536. package/dist/esm/debounce-gVeuteEJ.js.map +1 -0
  537. package/dist/esm/{index-DDw-pDpy.js → index-BOf9EC3C.js} +78 -65
  538. package/dist/esm/index-BOf9EC3C.js.map +1 -0
  539. package/dist/esm/{index-y49NXy_H.js → index-CgIw4Syg.js} +73 -47
  540. package/dist/esm/{index-y49NXy_H.js.map → index-CgIw4Syg.js.map} +1 -1
  541. package/dist/esm/index.js +5 -6
  542. package/dist/esm/index.js.map +1 -1
  543. package/dist/esm/{isDefined-DjmcVyb_.js → isDefined-DvmFa_bD.js} +3 -3
  544. package/dist/esm/{isDefined-DjmcVyb_.js.map → isDefined-DvmFa_bD.js.map} +1 -1
  545. package/dist/esm/{isString-CVMdKx0v.js → isString-lysmVw2n.js} +3 -3
  546. package/dist/esm/{isString-CVMdKx0v.js.map → isString-lysmVw2n.js.map} +1 -1
  547. package/dist/esm/loader.js +3 -5
  548. package/dist/esm/{stringToArray-DD7NecAG.js → stringToArray-CIJArUww.js} +4 -4
  549. package/dist/esm/{stringToArray-DD7NecAG.js.map → stringToArray-CIJArUww.js.map} +1 -1
  550. package/dist/esm/transition-DdvbF5yL.js.map +1 -1
  551. package/dist/hydrate/index.d.ts +2 -0
  552. package/dist/hydrate/index.js +994 -564
  553. package/dist/hydrate/index.mjs +994 -564
  554. package/dist/jest.config.js +3 -0
  555. package/dist/jest.config.js.map +1 -1
  556. package/dist/stencil.config.js +3 -2
  557. package/dist/stencil.config.js.map +1 -1
  558. package/dist/types/components/date-picker/bq-date-picker.d.ts +5 -2
  559. package/dist/types/components/dropdown/bq-dropdown.d.ts +1 -0
  560. package/dist/types/components/icon/bq-icon.d.ts +1 -1
  561. package/dist/types/components/input/bq-input.d.ts +10 -11
  562. package/dist/types/components/option/bq-option.d.ts +4 -2
  563. package/dist/types/components/select/bq-select.d.ts +1 -0
  564. package/dist/types/components/spinner/bq-spinner.types.d.ts +1 -1
  565. package/dist/types/components/step-item/bq-step-item.d.ts +1 -1
  566. package/dist/types/components/tag/bq-tag.d.ts +6 -4
  567. package/dist/types/components/tag/helper/index.d.ts +1 -1
  568. package/dist/types/components/textarea/bq-textarea.d.ts +5 -9
  569. package/dist/types/components.d.ts +46 -48
  570. package/dist/types/global.d.ts +1 -4
  571. package/dist/types/home/runner/work/BEEQ/BEEQ/.stencil/packages/beeq/jest.config.d.ts +3 -0
  572. package/dist/types/services/interfaces/floating-ui.d.ts +1 -1
  573. package/dist/types/services/libraries/floating-ui/index.d.ts +5 -2
  574. package/dist/types/shared/test-utils/setProperties.d.ts +1 -1
  575. package/dist/types/shared/test-utils/sleep.d.ts +1 -1
  576. package/dist/types/shared/utils/date.d.ts +18 -0
  577. package/dist/types/shared/utils/debounce.d.ts +1 -1
  578. package/dist/types/shared/utils/index.d.ts +1 -0
  579. package/dist/types/shared/utils/setRafTimeout.d.ts +1 -1
  580. package/dist/types/stencil-public-runtime.d.ts +49 -2
  581. package/dist/types/tools/angular-value-accessor-config.d.ts +1 -1
  582. package/dist/types/tools/vue-model-config.d.ts +1 -1
  583. package/package.json +1 -1
  584. package/dist/beeq/p-04745600.entry.js.map +0 -1
  585. package/dist/beeq/p-0deed5d1.entry.js.map +0 -1
  586. package/dist/beeq/p-1421f4a3.entry.js.map +0 -1
  587. package/dist/beeq/p-1c6ef374.entry.js.map +0 -1
  588. package/dist/beeq/p-1cd1ae48.entry.js +0 -6
  589. package/dist/beeq/p-1cd1ae48.entry.js.map +0 -1
  590. package/dist/beeq/p-2f008ed1.entry.js.map +0 -1
  591. package/dist/beeq/p-37a2fb82.entry.js.map +0 -1
  592. package/dist/beeq/p-3c7397cf.entry.js.map +0 -1
  593. package/dist/beeq/p-3dca7a14.entry.js.map +0 -1
  594. package/dist/beeq/p-3e8980ff.entry.js.map +0 -1
  595. package/dist/beeq/p-477f032f.entry.js.map +0 -1
  596. package/dist/beeq/p-48811a09.entry.js.map +0 -1
  597. package/dist/beeq/p-540d625a.entry.js +0 -6
  598. package/dist/beeq/p-540d625a.entry.js.map +0 -1
  599. package/dist/beeq/p-5ce77af6.entry.js.map +0 -1
  600. package/dist/beeq/p-60db3689.entry.js.map +0 -1
  601. package/dist/beeq/p-6852a0b0.entry.js.map +0 -1
  602. package/dist/beeq/p-6a10175b.entry.js.map +0 -1
  603. package/dist/beeq/p-6d429afd.entry.js.map +0 -1
  604. package/dist/beeq/p-7063e5c2.entry.js.map +0 -1
  605. package/dist/beeq/p-78be94d2.entry.js.map +0 -1
  606. package/dist/beeq/p-8280145e.entry.js.map +0 -1
  607. package/dist/beeq/p-87430ad8.entry.js.map +0 -1
  608. package/dist/beeq/p-8eb8612b.entry.js.map +0 -1
  609. package/dist/beeq/p-9305e1a2.entry.js.map +0 -1
  610. package/dist/beeq/p-96f6c9ae.entry.js.map +0 -1
  611. package/dist/beeq/p-D9ofIraD.js.map +0 -1
  612. package/dist/beeq/p-DDw-pDpy.js +0 -7
  613. package/dist/beeq/p-DDw-pDpy.js.map +0 -1
  614. package/dist/beeq/p-a9643899.entry.js.map +0 -1
  615. package/dist/beeq/p-b268b017.entry.js +0 -6
  616. package/dist/beeq/p-b268b017.entry.js.map +0 -1
  617. package/dist/beeq/p-b520bdb8.entry.js.map +0 -1
  618. package/dist/beeq/p-ba12d135.entry.js.map +0 -1
  619. package/dist/beeq/p-c023718e.entry.js.map +0 -1
  620. package/dist/beeq/p-d1dd36ca.entry.js.map +0 -1
  621. package/dist/beeq/p-dc4d2d77.entry.js.map +0 -1
  622. package/dist/beeq/p-dd896cd8.entry.js.map +0 -1
  623. package/dist/beeq/p-e7bd48a0.entry.js +0 -6
  624. package/dist/beeq/p-e7bd48a0.entry.js.map +0 -1
  625. package/dist/beeq/p-eb2cfa90.entry.js.map +0 -1
  626. package/dist/beeq/p-f12a127c.entry.js.map +0 -1
  627. package/dist/beeq/p-f189b65d.entry.js +0 -6
  628. package/dist/beeq/p-f189b65d.entry.js.map +0 -1
  629. package/dist/beeq/p-f8d5c1ab.entry.js.map +0 -1
  630. package/dist/beeq/p-fbc38c77.entry.js.map +0 -1
  631. package/dist/beeq/p-y49NXy_H.js +0 -6
  632. package/dist/cjs/bq-accordion-group.cjs.entry.js.map +0 -1
  633. package/dist/cjs/bq-accordion.cjs.entry.js.map +0 -1
  634. package/dist/cjs/bq-alert.cjs.entry.js.map +0 -1
  635. package/dist/cjs/bq-avatar.cjs.entry.js.map +0 -1
  636. package/dist/cjs/bq-badge.cjs.entry.js.map +0 -1
  637. package/dist/cjs/bq-breadcrumb-item.cjs.entry.js.map +0 -1
  638. package/dist/cjs/bq-breadcrumb.cjs.entry.js.map +0 -1
  639. package/dist/cjs/bq-button_2.cjs.entry.js.map +0 -1
  640. package/dist/cjs/bq-card.cjs.entry.js.map +0 -1
  641. package/dist/cjs/bq-checkbox.cjs.entry.js.map +0 -1
  642. package/dist/cjs/bq-date-picker.cjs.entry.js.map +0 -1
  643. package/dist/cjs/bq-dialog.cjs.entry.js.map +0 -1
  644. package/dist/cjs/bq-divider.cjs.entry.js.map +0 -1
  645. package/dist/cjs/bq-drawer.cjs.entry.js.map +0 -1
  646. package/dist/cjs/bq-dropdown_2.cjs.entry.js.map +0 -1
  647. package/dist/cjs/bq-empty-state.cjs.entry.js.map +0 -1
  648. package/dist/cjs/bq-input.cjs.entry.js.map +0 -1
  649. package/dist/cjs/bq-notification.cjs.entry.js.map +0 -1
  650. package/dist/cjs/bq-option-group.cjs.entry.js.map +0 -1
  651. package/dist/cjs/bq-option-list_2.cjs.entry.js.map +0 -1
  652. package/dist/cjs/bq-option.cjs.entry.js.map +0 -1
  653. package/dist/cjs/bq-page-title.cjs.entry.js.map +0 -1
  654. package/dist/cjs/bq-progress.cjs.entry.js.map +0 -1
  655. package/dist/cjs/bq-radio-group.cjs.entry.js.map +0 -1
  656. package/dist/cjs/bq-radio.cjs.entry.js.map +0 -1
  657. package/dist/cjs/bq-select.cjs.entry.js.map +0 -1
  658. package/dist/cjs/bq-side-menu-item.cjs.entry.js.map +0 -1
  659. package/dist/cjs/bq-side-menu.cjs.entry.js.map +0 -1
  660. package/dist/cjs/bq-slider.cjs.entry.js.map +0 -1
  661. package/dist/cjs/bq-spinner.cjs.entry.js.map +0 -1
  662. package/dist/cjs/bq-status.cjs.entry.js.map +0 -1
  663. package/dist/cjs/bq-step-item.cjs.entry.js.map +0 -1
  664. package/dist/cjs/bq-steps.cjs.entry.js.map +0 -1
  665. package/dist/cjs/bq-switch.cjs.entry.js.map +0 -1
  666. package/dist/cjs/bq-tab-group.cjs.entry.js.map +0 -1
  667. package/dist/cjs/bq-tab.cjs.entry.js.map +0 -1
  668. package/dist/cjs/bq-textarea.cjs.entry.js.map +0 -1
  669. package/dist/cjs/bq-toast.cjs.entry.js.map +0 -1
  670. package/dist/cjs/bq-tooltip.cjs.entry.js.map +0 -1
  671. package/dist/cjs/debounce-DFaAa1Cu.js.map +0 -1
  672. package/dist/cjs/index-CLoLF-_B.js.map +0 -1
  673. package/dist/components/p-BIl7Vq5P.js.map +0 -1
  674. package/dist/components/p-BPVTwD6U.js.map +0 -1
  675. package/dist/components/p-Bkf_oCvP.js +0 -6
  676. package/dist/components/p-Bkf_oCvP.js.map +0 -1
  677. package/dist/components/p-Bs3hKCXS.js.map +0 -1
  678. package/dist/components/p-C4Jb3i-D.js.map +0 -1
  679. package/dist/components/p-CjS2vgik.js.map +0 -1
  680. package/dist/components/p-D9ofIraD.js.map +0 -1
  681. package/dist/components/p-DE7kLeHf.js +0 -6
  682. package/dist/components/p-DE7kLeHf.js.map +0 -1
  683. package/dist/components/p-fQPjV9jm.js.map +0 -1
  684. package/dist/components/p-y49NXy_H.js +0 -6
  685. package/dist/components/p-y49NXy_H.js.map +0 -1
  686. package/dist/esm/bq-button_2.entry.js.map +0 -1
  687. package/dist/esm/bq-dropdown_2.entry.js.map +0 -1
  688. package/dist/esm/bq-option-list_2.entry.js.map +0 -1
  689. package/dist/esm/debounce-cjfQylgg.js.map +0 -1
  690. package/dist/esm/index-DDw-pDpy.js.map +0 -1
  691. /package/dist/components/{p-Ci39rxuU.js.map → p-BRbYDZoo.js.map} +0 -0
@@ -2,7 +2,7 @@
2
2
  * Built by Endavans
3
3
  * © https://beeq.design - Apache 2 License.
4
4
  */
5
- import { h, Host } from "@stencil/core";
5
+ import { Host, h } from "@stencil/core";
6
6
  /**
7
7
  * The radio button is a user interface element that allows users to select a single option.
8
8
  *
@@ -158,7 +158,9 @@ export class BqRadio {
158
158
  'is-disabled': this.isDisabled,
159
159
  'is-checked': this.checked,
160
160
  'has-background': this.backgroundOnHover,
161
- }, part: "base" }, h("div", { key: '438b1daf66ba3fab98ed6e5afaac925e4086c050', class: "bq-radio__control" }, h("input", { key: '01457f18d246d946c380628847bdae9d6cc49dad', class: "bq-radio__input", ref: (element) => (this.inputElement = element), type: "radio", form: this.formId, name: this.name, value: this.value, required: this.required, disabled: this.isDisabled, checked: this.checked, onBlur: this.handleOnBlur, onClick: this.handleClick, onFocus: this.handleOnFocus, onKeyDown: this.handleOnKeyDown, "aria-checked": this.checked ? 'true' : 'false', "aria-disabled": this.isDisabled ? 'true' : 'false', "aria-labelledby": "bq-radio__label", part: "input" }), h("div", { key: '4ee55909614558994fa4f396a34788da163c2641', class: "bq-radio__circle", part: "radio" }, h("div", { key: '6cf2c2de2ee41af48d9906d52a177b0eae59cab8', class: "bq-radio__checked" }))), h("span", { key: '0b494c425a4b8af9007dfc957a8530b3e3032188', class: "bq-radio__label group-hover:text-text-primary-hover group-[.is-disabled]:text-text-primary-disabled", part: "label" }, h("slot", { key: '92580957415ad7f435c9f5e5a4fd2afbbc96f044', id: "bq-radio__label" })))));
161
+ }, part: "base" }, h("div", { key: '438b1daf66ba3fab98ed6e5afaac925e4086c050', class: "bq-radio__control" }, h("input", { key: '6fe9c908da9f0dc81d368ecd9721e24e27520c95', "aria-checked": this.checked ? 'true' : 'false', "aria-disabled": this.isDisabled ? 'true' : 'false', "aria-labelledby": "bq-radio__label", checked: this.checked, class: "bq-radio__input", disabled: this.isDisabled, form: this.formId, name: this.name, onBlur: this.handleOnBlur, onClick: this.handleClick, onFocus: this.handleOnFocus, onKeyDown: this.handleOnKeyDown, part: "input", ref: (element) => {
162
+ this.inputElement = element;
163
+ }, required: this.required, type: "radio", value: this.value }), h("div", { key: 'd3f23f57a905431a31dfb4eb426176c04a4295d4', class: "bq-radio__circle", part: "radio" }, h("div", { key: '074045b752f2e1541d9fe2b51c8290b55dc23fb3', class: "bq-radio__checked" }))), h("span", { key: 'd2849008f9e81df99ddfc9fefa38aab255bf22aa', class: "bq-radio__label group-hover:text-text-primary-hover group-[.is-disabled]:text-text-primary-disabled", part: "label" }, h("slot", { key: '97c17462f377502cad6a6f2e3588df84ee762ea3', id: "bq-radio__label" })))));
162
164
  }
163
165
  static get is() { return "bq-radio"; }
164
166
  static get encapsulation() { return "shadow"; }
@@ -177,7 +179,6 @@ export class BqRadio {
177
179
  return {
178
180
  "backgroundOnHover": {
179
181
  "type": "boolean",
180
- "attribute": "background-on-hover",
181
182
  "mutable": false,
182
183
  "complexType": {
183
184
  "original": "boolean",
@@ -193,11 +194,11 @@ export class BqRadio {
193
194
  "getter": false,
194
195
  "setter": false,
195
196
  "reflect": true,
197
+ "attribute": "background-on-hover",
196
198
  "defaultValue": "false"
197
199
  },
198
200
  "checked": {
199
201
  "type": "boolean",
200
- "attribute": "checked",
201
202
  "mutable": true,
202
203
  "complexType": {
203
204
  "original": "boolean",
@@ -213,11 +214,11 @@ export class BqRadio {
213
214
  "getter": false,
214
215
  "setter": false,
215
216
  "reflect": true,
217
+ "attribute": "checked",
216
218
  "defaultValue": "false"
217
219
  },
218
220
  "disabled": {
219
221
  "type": "boolean",
220
- "attribute": "disabled",
221
222
  "mutable": false,
222
223
  "complexType": {
223
224
  "original": "boolean",
@@ -233,11 +234,11 @@ export class BqRadio {
233
234
  "getter": false,
234
235
  "setter": false,
235
236
  "reflect": true,
237
+ "attribute": "disabled",
236
238
  "defaultValue": "false"
237
239
  },
238
240
  "forceDisabled": {
239
241
  "type": "boolean",
240
- "attribute": "force-disabled",
241
242
  "mutable": false,
242
243
  "complexType": {
243
244
  "original": "boolean",
@@ -256,11 +257,11 @@ export class BqRadio {
256
257
  "getter": false,
257
258
  "setter": false,
258
259
  "reflect": true,
260
+ "attribute": "force-disabled",
259
261
  "defaultValue": "false"
260
262
  },
261
263
  "formId": {
262
264
  "type": "string",
263
- "attribute": "form-id",
264
265
  "mutable": false,
265
266
  "complexType": {
266
267
  "original": "string",
@@ -275,11 +276,11 @@ export class BqRadio {
275
276
  },
276
277
  "getter": false,
277
278
  "setter": false,
278
- "reflect": true
279
+ "reflect": true,
280
+ "attribute": "form-id"
279
281
  },
280
282
  "name": {
281
283
  "type": "string",
282
- "attribute": "name",
283
284
  "mutable": false,
284
285
  "complexType": {
285
286
  "original": "string",
@@ -294,11 +295,11 @@ export class BqRadio {
294
295
  },
295
296
  "getter": false,
296
297
  "setter": false,
297
- "reflect": true
298
+ "reflect": true,
299
+ "attribute": "name"
298
300
  },
299
301
  "required": {
300
302
  "type": "boolean",
301
- "attribute": "required",
302
303
  "mutable": false,
303
304
  "complexType": {
304
305
  "original": "boolean",
@@ -313,11 +314,11 @@ export class BqRadio {
313
314
  },
314
315
  "getter": false,
315
316
  "setter": false,
316
- "reflect": true
317
+ "reflect": true,
318
+ "attribute": "required"
317
319
  },
318
320
  "value": {
319
321
  "type": "string",
320
- "attribute": "value",
321
322
  "mutable": false,
322
323
  "complexType": {
323
324
  "original": "string",
@@ -332,7 +333,8 @@ export class BqRadio {
332
333
  },
333
334
  "getter": false,
334
335
  "setter": false,
335
- "reflect": true
336
+ "reflect": true,
337
+ "attribute": "value"
336
338
  }
337
339
  };
338
340
  }
@@ -1 +1 @@
1
- {"version":3,"file":"bq-radio.js","sourceRoot":"","sources":["../../../../../../packages/beeq/src/components/radio/bq-radio.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAGjF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsCG;AAQH,MAAM,OAAO,OAAO;IAClB,iBAAiB;IACjB,uBAAuB;IACf,YAAY,CAAmB;IAEvC,iCAAiC;IACjC,sCAAsC;IAE3B,EAAE,CAAsB;IAEnC,oBAAoB;IACpB,wCAAwC;IACxC,0CAA0C;IAE1C,sBAAsB;IACtB,2BAA2B;IAE3B,iDAAiD;IACxB,iBAAiB,GAAG,KAAK,CAAC;IAEnD,qCAAqC;IACG,OAAO,GAAG,KAAK,CAAC;IAExD,sCAAsC;IACb,QAAQ,GAAG,KAAK,CAAC;IAE1C,wGAAwG;IAC/E,aAAa,GAAG,KAAK,CAAC;IAE/C,0DAA0D;IACjC,MAAM,CAAU;IAEzC,kGAAkG;IACzE,IAAI,CAAU;IAEvC,2HAA2H;IAClG,QAAQ,CAAW;IAE5C,oDAAoD;IAC3B,KAAK,CAAU;IAExC,wBAAwB;IACxB,0BAA0B;IAE1B,iBAAiB;IACjB,+CAA+C;IAC/C,iDAAiD;IAEjD,wDAAwD;IAC/C,OAAO,CAA8D;IAE9E,qDAAqD;IAC5C,OAAO,CAAmC;IAEnD,sDAAsD;IAC7C,MAAM,CAAmC;IAElD,yDAAyD;IAChD,SAAS,CAA4D;IAE9E,6BAA6B;IAC7B,sCAAsC;IACtC,wCAAwC;IAExC,YAAY;IACZ,iBAAiB;IAEjB,qBAAqB;IACrB,iDAAiD;IACjD,wBAAwB;IACxB,gCAAgC;IAChC,gDAAgD;IAChD,kDAAkD;IAElD;;;OAGG;IAEH,KAAK,CAAC,MAAM;QACV,IAAI,CAAC,YAAY,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;IAED;;;OAGG;IAEH,KAAK,CAAC,MAAM;QACV,IAAI,CAAC,YAAY,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;IAED;;;OAGG;IAEH,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,YAAY,EAAE,IAAI,EAAE,CAAC;IAC5B,CAAC;IAED;;OAEG;IAEH,KAAK,CAAC,cAAc;QAClB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,gBAAgB;IAChB,2BAA2B;IAC3B,wDAAwD;IACxD,0DAA0D;IAElD,WAAW,GAAG,CAAC,KAAiB,EAAE,EAAE;QAC1C,kDAAkD;QAClD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAE1B,wCAAwC;QACxC,wEAAwE;QACxE,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;QAC/E,IAAI,YAAY,CAAC,gBAAgB,EAAE,CAAC;YAClC,KAAK,CAAC,wBAAwB,EAAE,CAAC;QACnC,CAAC;IACH,CAAC,CAAC;IAEM,aAAa,GAAG,GAAG,EAAE;QAC3B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC,CAAC;IAEM,YAAY,GAAG,GAAG,EAAE;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC,CAAC;IAEM,eAAe,GAAG,CAAC,KAAoB,EAAE,EAAE;QACjD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;IAC3D,CAAC,CAAC;IAEF,IAAY,UAAU;QACpB,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,aAAa,CAAC;IAC7C,CAAC;IAED,oBAAoB;IACpB,oCAAoC;IACpC,sCAAsC;IAEtC,MAAM;QACJ,OAAO,CACL,EAAC,IAAI;YACH,8DACE,KAAK,EAAE;oBACL,gBAAgB,EAAE,IAAI;oBACtB,aAAa,EAAE,IAAI,CAAC,UAAU;oBAC9B,YAAY,EAAE,IAAI,CAAC,OAAO;oBAC1B,gBAAgB,EAAE,IAAI,CAAC,iBAAiB;iBACzC,EACD,IAAI,EAAC,MAAM;gBAEX,4DAAK,KAAK,EAAC,mBAAmB;oBAC5B,8DACE,KAAK,EAAC,iBAAiB,EACvB,GAAG,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,EAC/C,IAAI,EAAC,OAAO,EACZ,IAAI,EAAE,IAAI,CAAC,MAAM,EACjB,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,QAAQ,EAAE,IAAI,CAAC,UAAU,EACzB,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,MAAM,EAAE,IAAI,CAAC,YAAY,EACzB,OAAO,EAAE,IAAI,CAAC,WAAW,EACzB,OAAO,EAAE,IAAI,CAAC,aAAa,EAC3B,SAAS,EAAE,IAAI,CAAC,eAAe,kBACjB,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,mBAC9B,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,qBACjC,iBAAiB,EACjC,IAAI,EAAC,OAAO,GACZ;oBACF,4DAAK,KAAK,EAAC,kBAAkB,EAAC,IAAI,EAAC,OAAO;wBACxC,4DAAK,KAAK,EAAC,mBAAmB,GAAG,CAC7B,CACF;gBACN,6DACE,KAAK,EAAC,qGAAqG,EAC3G,IAAI,EAAC,OAAO;oBAEZ,6DAAM,EAAE,EAAC,iBAAiB,GAAQ,CAC7B,CACD,CACH,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Element, Event, h, Host, Method, Prop } from '@stencil/core';\nimport type { EventEmitter } from '@stencil/core';\n\n/**\n * The radio button is a user interface element that allows users to select a single option.\n *\n * @example How to use it\n * ```html\n * <bq-radio value=\"option1\">Radio option 1</bq-radio>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/9718e1-radio-button/b/09d7b1\n * @status stable\n *\n * @attr {boolean} background-on-hover - If `true`, the radio displays background on hover\n * @attr {boolean} checked - If `true` radio input is checked\n * @attr {boolean} disabled - If `true` radio input is disabled\n * @attr {string} form-id - The form ID that the radio input is associated with\n * @attr {string} name - Name of the HTML input form control. Submitted with the form as part of a name/value pair\n * @attr {boolean} required - If `true`, it will indicate that the user must specify a value for the radio before the owning form can be submitted\n * @attr {boolean} value - A string representing the value of the radio\n *\n * @method vClick - Simulate a click event on the native `<input>` HTML element used under the hood\n * @method vFocus - Sets focus on the native `<input>` HTML element used under the hood\n * @method vBlur - Remove focus from the native `<input>` HTML element used under the hood\n * @method getNativeInput - Returns the native `<input>` HTML element used under the hood\n *\n * @event bqBlur - Handler to be called when the radio loses focus\n * @event bqClick - Handler to be called when the radio state changes\n * @event bqFocus - Handler to be called when the radio gets focused\n * @event bqKeyDown - The handler is to be called when the radio key is pressed\n *\n * @slot - The bq-radio item\n *\n * @part base - The component's internal wrapper of the radio component.\n * @part input - The native HTML `<input type=\"radio\">` used under the hood.\n * @part radio - The component's internal wrapper of the radio component.\n * @part label - The `<span>` element that holds the text content.\n *\n * @cssprop --bq-radio--size - Radio size\n * @cssprop --bq-radio--border-width - Radio border width\n */\n@Component({\n tag: 'bq-radio',\n styleUrl: './scss/bq-radio.scss',\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class BqRadio {\n // Own Properties\n // ====================\n private inputElement: HTMLInputElement;\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqRadioElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n // Public Property API\n // ========================\n\n /** If true radio displays background on hover */\n @Prop({ reflect: true }) backgroundOnHover = false;\n\n /** If true radio input is checked */\n @Prop({ reflect: true, mutable: true }) checked = false;\n\n /** If true radio input is disabled */\n @Prop({ reflect: true }) disabled = false;\n\n /** @internal Used by the radio-group parent component to force the disabled state of the radio input */\n @Prop({ reflect: true }) forceDisabled = false;\n\n /** The form ID that the radio input is associated with */\n @Prop({ reflect: true }) formId?: string;\n\n /** Name of the HTML input form control. Submitted with the form as part of a name/value pair. */\n @Prop({ reflect: true }) name!: string;\n\n /** If `true`, it will indicate that the user must specify a value for the radio before the owning form can be submitted */\n @Prop({ reflect: true }) required?: boolean;\n\n /** A string representing the value of the radio. */\n @Prop({ reflect: true }) value!: string;\n\n // Prop lifecycle events\n // =======================\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n /** Handler to be called when the radio state changes */\n @Event() bqClick: EventEmitter<{ value: string; target: HTMLBqRadioElement }>;\n\n /** Handler to be called when the radio gets focus */\n @Event() bqFocus: EventEmitter<HTMLBqRadioElement>;\n\n /** Handler to be called when the radio loses focus */\n @Event() bqBlur: EventEmitter<HTMLBqRadioElement>;\n\n /** Handler to be called when the radio key is pressed */\n @Event() bqKeyDown: EventEmitter<{ key: string; target: HTMLBqRadioElement }>;\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n // Listeners\n // ==============\n\n // Public methods API\n // These methods are exposed on the host element.\n // Always use two lines.\n // Public Methods must be async.\n // Requires JSDocs for public API documentation.\n // ===============================================\n\n /**\n * Simulate a click event on the native `<input>` HTML element used under the hood.\n * Use this method instead of the global `element.click()`.\n */\n @Method()\n async vClick() {\n this.inputElement?.click();\n }\n\n /**\n * Sets focus on the native `<input>` HTML element used under the hood.\n * Use this method instead of the global `element.focus()`.\n */\n @Method()\n async vFocus() {\n this.inputElement?.focus();\n }\n\n /**\n * Remove focus from the native `<input>` HTML element used under the hood.\n * Use this method instead of the global `element.blur()`.\n */\n @Method()\n async vBlur() {\n this.inputElement?.blur();\n }\n\n /**\n * Returns the native `<input>` HTML element used under the hood.\n */\n @Method()\n async getNativeInput() {\n return this.inputElement;\n }\n\n // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n private handleClick = (event: MouseEvent) => {\n // Prevent the native input click default behavior\n event.preventDefault();\n if (this.disabled) return;\n\n // Emit the event without changing state\n // Let the radio-group handle all state management and event propagation\n const bqClickEvent = this.bqClick.emit({ value: this.value, target: this.el });\n if (bqClickEvent.defaultPrevented) {\n event.stopImmediatePropagation();\n }\n };\n\n private handleOnFocus = () => {\n this.bqFocus.emit(this.el);\n };\n\n private handleOnBlur = () => {\n this.bqBlur.emit(this.el);\n };\n\n private handleOnKeyDown = (event: KeyboardEvent) => {\n this.bqKeyDown.emit({ key: event.key, target: this.el });\n };\n\n private get isDisabled() {\n return this.disabled || this.forceDisabled;\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <Host>\n <label\n class={{\n 'bq-radio group': true,\n 'is-disabled': this.isDisabled,\n 'is-checked': this.checked,\n 'has-background': this.backgroundOnHover,\n }}\n part=\"base\"\n >\n <div class=\"bq-radio__control\">\n <input\n class=\"bq-radio__input\"\n ref={(element) => (this.inputElement = element)}\n type=\"radio\"\n form={this.formId}\n name={this.name}\n value={this.value}\n required={this.required}\n disabled={this.isDisabled}\n checked={this.checked}\n onBlur={this.handleOnBlur}\n onClick={this.handleClick}\n onFocus={this.handleOnFocus}\n onKeyDown={this.handleOnKeyDown}\n aria-checked={this.checked ? 'true' : 'false'}\n aria-disabled={this.isDisabled ? 'true' : 'false'}\n aria-labelledby=\"bq-radio__label\"\n part=\"input\"\n />\n <div class=\"bq-radio__circle\" part=\"radio\">\n <div class=\"bq-radio__checked\" />\n </div>\n </div>\n <span\n class=\"bq-radio__label group-hover:text-text-primary-hover group-[.is-disabled]:text-text-primary-disabled\"\n part=\"label\"\n >\n <slot id=\"bq-radio__label\"></slot>\n </span>\n </label>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"bq-radio.js","sourceRoot":"","sources":["../../../../../../packages/beeq/src/components/radio/bq-radio.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { EventEmitter } from '@stencil/core';\nimport { Component, Element, Event, Host, h, Method, Prop } from '@stencil/core';\n\n/**\n * The radio button is a user interface element that allows users to select a single option.\n *\n * @example How to use it\n * ```html\n * <bq-radio value=\"option1\">Radio option 1</bq-radio>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/9718e1-radio-button/b/09d7b1\n * @status stable\n *\n * @attr {boolean} background-on-hover - If `true`, the radio displays background on hover\n * @attr {boolean} checked - If `true` radio input is checked\n * @attr {boolean} disabled - If `true` radio input is disabled\n * @attr {string} form-id - The form ID that the radio input is associated with\n * @attr {string} name - Name of the HTML input form control. Submitted with the form as part of a name/value pair\n * @attr {boolean} required - If `true`, it will indicate that the user must specify a value for the radio before the owning form can be submitted\n * @attr {boolean} value - A string representing the value of the radio\n *\n * @method vClick - Simulate a click event on the native `<input>` HTML element used under the hood\n * @method vFocus - Sets focus on the native `<input>` HTML element used under the hood\n * @method vBlur - Remove focus from the native `<input>` HTML element used under the hood\n * @method getNativeInput - Returns the native `<input>` HTML element used under the hood\n *\n * @event bqBlur - Handler to be called when the radio loses focus\n * @event bqClick - Handler to be called when the radio state changes\n * @event bqFocus - Handler to be called when the radio gets focused\n * @event bqKeyDown - The handler is to be called when the radio key is pressed\n *\n * @slot - The bq-radio item\n *\n * @part base - The component's internal wrapper of the radio component.\n * @part input - The native HTML `<input type=\"radio\">` used under the hood.\n * @part radio - The component's internal wrapper of the radio component.\n * @part label - The `<span>` element that holds the text content.\n *\n * @cssprop --bq-radio--size - Radio size\n * @cssprop --bq-radio--border-width - Radio border width\n */\n@Component({\n tag: 'bq-radio',\n styleUrl: './scss/bq-radio.scss',\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class BqRadio {\n // Own Properties\n // ====================\n private inputElement: HTMLInputElement;\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqRadioElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n // Public Property API\n // ========================\n\n /** If true radio displays background on hover */\n @Prop({ reflect: true }) backgroundOnHover = false;\n\n /** If true radio input is checked */\n @Prop({ reflect: true, mutable: true }) checked = false;\n\n /** If true radio input is disabled */\n @Prop({ reflect: true }) disabled = false;\n\n /** @internal Used by the radio-group parent component to force the disabled state of the radio input */\n @Prop({ reflect: true }) forceDisabled = false;\n\n /** The form ID that the radio input is associated with */\n @Prop({ reflect: true }) formId?: string;\n\n /** Name of the HTML input form control. Submitted with the form as part of a name/value pair. */\n @Prop({ reflect: true }) name!: string;\n\n /** If `true`, it will indicate that the user must specify a value for the radio before the owning form can be submitted */\n @Prop({ reflect: true }) required?: boolean;\n\n /** A string representing the value of the radio. */\n @Prop({ reflect: true }) value!: string;\n\n // Prop lifecycle events\n // =======================\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n /** Handler to be called when the radio state changes */\n @Event() bqClick: EventEmitter<{ value: string; target: HTMLBqRadioElement }>;\n\n /** Handler to be called when the radio gets focus */\n @Event() bqFocus: EventEmitter<HTMLBqRadioElement>;\n\n /** Handler to be called when the radio loses focus */\n @Event() bqBlur: EventEmitter<HTMLBqRadioElement>;\n\n /** Handler to be called when the radio key is pressed */\n @Event() bqKeyDown: EventEmitter<{ key: string; target: HTMLBqRadioElement }>;\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n // Listeners\n // ==============\n\n // Public methods API\n // These methods are exposed on the host element.\n // Always use two lines.\n // Public Methods must be async.\n // Requires JSDocs for public API documentation.\n // ===============================================\n\n /**\n * Simulate a click event on the native `<input>` HTML element used under the hood.\n * Use this method instead of the global `element.click()`.\n */\n @Method()\n async vClick() {\n this.inputElement?.click();\n }\n\n /**\n * Sets focus on the native `<input>` HTML element used under the hood.\n * Use this method instead of the global `element.focus()`.\n */\n @Method()\n async vFocus() {\n this.inputElement?.focus();\n }\n\n /**\n * Remove focus from the native `<input>` HTML element used under the hood.\n * Use this method instead of the global `element.blur()`.\n */\n @Method()\n async vBlur() {\n this.inputElement?.blur();\n }\n\n /**\n * Returns the native `<input>` HTML element used under the hood.\n */\n @Method()\n async getNativeInput() {\n return this.inputElement;\n }\n\n // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n private handleClick = (event: MouseEvent) => {\n // Prevent the native input click default behavior\n event.preventDefault();\n if (this.disabled) return;\n\n // Emit the event without changing state\n // Let the radio-group handle all state management and event propagation\n const bqClickEvent = this.bqClick.emit({ value: this.value, target: this.el });\n if (bqClickEvent.defaultPrevented) {\n event.stopImmediatePropagation();\n }\n };\n\n private handleOnFocus = () => {\n this.bqFocus.emit(this.el);\n };\n\n private handleOnBlur = () => {\n this.bqBlur.emit(this.el);\n };\n\n private handleOnKeyDown = (event: KeyboardEvent) => {\n this.bqKeyDown.emit({ key: event.key, target: this.el });\n };\n\n private get isDisabled() {\n return this.disabled || this.forceDisabled;\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <Host>\n <label\n class={{\n 'bq-radio group': true,\n 'is-disabled': this.isDisabled,\n 'is-checked': this.checked,\n 'has-background': this.backgroundOnHover,\n }}\n part=\"base\"\n >\n <div class=\"bq-radio__control\">\n <input\n aria-checked={this.checked ? 'true' : 'false'}\n aria-disabled={this.isDisabled ? 'true' : 'false'}\n aria-labelledby=\"bq-radio__label\"\n checked={this.checked}\n class=\"bq-radio__input\"\n disabled={this.isDisabled}\n form={this.formId}\n name={this.name}\n onBlur={this.handleOnBlur}\n onClick={this.handleClick}\n onFocus={this.handleOnFocus}\n onKeyDown={this.handleOnKeyDown}\n part=\"input\"\n ref={(element) => {\n this.inputElement = element;\n }}\n required={this.required}\n type=\"radio\"\n value={this.value}\n />\n <div class=\"bq-radio__circle\" part=\"radio\">\n <div class=\"bq-radio__checked\" />\n </div>\n </div>\n <span\n class=\"bq-radio__label group-hover:text-text-primary-hover group-[.is-disabled]:text-text-primary-disabled\"\n part=\"label\"\n >\n <slot id=\"bq-radio__label\"></slot>\n </span>\n </label>\n </Host>\n );\n }\n}\n"]}
@@ -2,9 +2,9 @@
2
2
  * Built by Endavans
3
3
  * © https://beeq.design - Apache 2 License.
4
4
  */
5
- import { h, Host } from "@stencil/core";
6
- import { RADIO_GROUP_ORIENTATION } from "./bq-radio-group.types";
5
+ import { Host, h } from "@stencil/core";
7
6
  import { debounce, getNextElement, isDefined, isEventTargetChildOfElement, isNil, validatePropValue, } from "../../shared/utils";
7
+ import { RADIO_GROUP_ORIENTATION } from "./bq-radio-group.types";
8
8
  const KEY_MAP = {
9
9
  ArrowDown: 'forward',
10
10
  ArrowRight: 'forward',
@@ -190,7 +190,7 @@ export class BqRadioGroup {
190
190
  onBqBlur(event) {
191
191
  if (!isEventTargetChildOfElement(event, this.el))
192
192
  return;
193
- // NOTE: if focusedBqRadio is nil that means the event occured from this component
193
+ // NOTE: if focusedBqRadio is nil that means the event occurred from this component
194
194
  if (isNil(this.focusedBqRadio))
195
195
  return;
196
196
  event.stopPropagation();
@@ -217,7 +217,9 @@ export class BqRadioGroup {
217
217
  */
218
218
  initializeRadioElements = () => {
219
219
  this.radioElementsSet.clear();
220
- this.el.querySelectorAll('bq-radio').forEach((radio) => this.radioElementsSet.add(radio));
220
+ this.el.querySelectorAll('bq-radio').forEach((radio) => {
221
+ this.radioElementsSet.add(radio);
222
+ });
221
223
  // Caching the radio elements in an array for faster access and iteration
222
224
  this.cachedRadioElements = Array.from(this.radioElementsSet);
223
225
  // Set the tabIndex of the host element to -1 if there are no radio elements or the group is disabled, otherwise set it to 0
@@ -234,7 +236,9 @@ export class BqRadioGroup {
234
236
  return;
235
237
  // If disabled, all radios get tabIndex -1
236
238
  if (this.disabled) {
237
- this.cachedRadioElements.forEach((radio) => (radio.tabIndex = -1));
239
+ this.cachedRadioElements.forEach((radio) => {
240
+ radio.tabIndex = -1;
241
+ });
238
242
  return;
239
243
  }
240
244
  // Find which radio should be focusable
@@ -337,7 +341,9 @@ export class BqRadioGroup {
337
341
  states.add(this.orientation);
338
342
  // Update states
339
343
  this.internals?.states.clear();
340
- states.forEach((state) => this.internals?.states.add(state));
344
+ states.forEach((state) => {
345
+ this.internals?.states.add(state);
346
+ });
341
347
  };
342
348
  handleSlotChange = () => {
343
349
  this.initializeRadioElements();
@@ -347,7 +353,7 @@ export class BqRadioGroup {
347
353
  // Always the last one in the class.
348
354
  // ===================================
349
355
  render() {
350
- return (h(Host, { key: '35cd47995318a2b305bbca98397e65834d886f29', tabindex: this.tabIndex }, h("fieldset", { key: '6d075a89612330cefff2fe88e73516ff35fd10e0', class: { 'bq-radio-group': true, 'has-fieldset': this.fieldset }, "aria-controls": "bq-radiogroup", "aria-labelledby": "bq-radio-group__label", "aria-disabled": this.disabled, "aria-required": this.required, disabled: this.disabled, role: "radiogroup", part: "base" }, h("legend", { key: '1a8d10c6b3aed840710baf61cffeee6756840bdb', part: "label" }, h("slot", { key: '829e6636946c4642af79eba286f04fa5415a02cb', id: "bq-radiogroup__label", name: "label" })), h("div", { key: '783e674e87b56b3682f732397b8478bc46b88716', class: `bq-radio-group--${this.orientation}`, part: "group" }, h("slot", { key: '5f1fe1d9d09e64394415fdb13afed1eaf3023cec', id: "bq-radiogroup", onSlotchange: this.handleSlotChange })))));
356
+ return (h(Host, { key: '324a831a19e6713db5b5f561d78571cb84e9b530', tabindex: this.tabIndex }, h("fieldset", { key: '41474f54b518587ecd897bbbddd8a96ba1e7ebed', "aria-controls": "bq-radiogroup", "aria-disabled": this.disabled, "aria-labelledby": "bq-radio-group__label", class: { 'bq-radio-group': true, 'has-fieldset': this.fieldset }, disabled: this.disabled, part: "base" }, h("legend", { key: 'f5c8834333aa3174418298e7240f16d9d5e85c70', part: "label" }, h("slot", { key: '8180b8c2a610af608092a5a37b3bb5b59ef32b76', id: "bq-radiogroup__label", name: "label" })), h("div", { key: 'dbad104bf6d984de4f9057e2d588dc1899705116', class: `bq-radio-group--${this.orientation}`, part: "group" }, h("slot", { key: '08ce09046a91f79a46e015bda8fc094291a66f4a', id: "bq-radiogroup", onSlotchange: this.handleSlotChange })))));
351
357
  }
352
358
  static get is() { return "bq-radio-group"; }
353
359
  static get encapsulation() { return "shadow"; }
@@ -367,7 +373,6 @@ export class BqRadioGroup {
367
373
  return {
368
374
  "backgroundOnHover": {
369
375
  "type": "boolean",
370
- "attribute": "background-on-hover",
371
376
  "mutable": false,
372
377
  "complexType": {
373
378
  "original": "boolean",
@@ -383,11 +388,11 @@ export class BqRadioGroup {
383
388
  "getter": false,
384
389
  "setter": false,
385
390
  "reflect": true,
391
+ "attribute": "background-on-hover",
386
392
  "defaultValue": "false"
387
393
  },
388
394
  "debounceTime": {
389
395
  "type": "number",
390
- "attribute": "debounce-time",
391
396
  "mutable": true,
392
397
  "complexType": {
393
398
  "original": "number",
@@ -403,11 +408,11 @@ export class BqRadioGroup {
403
408
  "getter": false,
404
409
  "setter": false,
405
410
  "reflect": true,
411
+ "attribute": "debounce-time",
406
412
  "defaultValue": "0"
407
413
  },
408
414
  "disabled": {
409
415
  "type": "boolean",
410
- "attribute": "disabled",
411
416
  "mutable": false,
412
417
  "complexType": {
413
418
  "original": "boolean",
@@ -423,11 +428,11 @@ export class BqRadioGroup {
423
428
  "getter": false,
424
429
  "setter": false,
425
430
  "reflect": true,
431
+ "attribute": "disabled",
426
432
  "defaultValue": "false"
427
433
  },
428
434
  "fieldset": {
429
435
  "type": "boolean",
430
- "attribute": "fieldset",
431
436
  "mutable": false,
432
437
  "complexType": {
433
438
  "original": "boolean",
@@ -443,11 +448,11 @@ export class BqRadioGroup {
443
448
  "getter": false,
444
449
  "setter": false,
445
450
  "reflect": true,
451
+ "attribute": "fieldset",
446
452
  "defaultValue": "false"
447
453
  },
448
454
  "name": {
449
455
  "type": "string",
450
- "attribute": "name",
451
456
  "mutable": false,
452
457
  "complexType": {
453
458
  "original": "string",
@@ -462,11 +467,11 @@ export class BqRadioGroup {
462
467
  },
463
468
  "getter": false,
464
469
  "setter": false,
465
- "reflect": true
470
+ "reflect": true,
471
+ "attribute": "name"
466
472
  },
467
473
  "orientation": {
468
474
  "type": "string",
469
- "attribute": "orientation",
470
475
  "mutable": true,
471
476
  "complexType": {
472
477
  "original": "TRadioGroupOrientation",
@@ -488,11 +493,11 @@ export class BqRadioGroup {
488
493
  "getter": false,
489
494
  "setter": false,
490
495
  "reflect": true,
496
+ "attribute": "orientation",
491
497
  "defaultValue": "'vertical'"
492
498
  },
493
499
  "required": {
494
500
  "type": "boolean",
495
- "attribute": "required",
496
501
  "mutable": false,
497
502
  "complexType": {
498
503
  "original": "boolean",
@@ -508,11 +513,11 @@ export class BqRadioGroup {
508
513
  "getter": false,
509
514
  "setter": false,
510
515
  "reflect": true,
516
+ "attribute": "required",
511
517
  "defaultValue": "false"
512
518
  },
513
519
  "requiredValidationMessage": {
514
520
  "type": "string",
515
- "attribute": "required-validation-message",
516
521
  "mutable": false,
517
522
  "complexType": {
518
523
  "original": "string",
@@ -527,11 +532,11 @@ export class BqRadioGroup {
527
532
  },
528
533
  "getter": false,
529
534
  "setter": false,
530
- "reflect": true
535
+ "reflect": true,
536
+ "attribute": "required-validation-message"
531
537
  },
532
538
  "value": {
533
539
  "type": "string",
534
- "attribute": "value",
535
540
  "mutable": true,
536
541
  "complexType": {
537
542
  "original": "string",
@@ -546,7 +551,8 @@ export class BqRadioGroup {
546
551
  },
547
552
  "getter": false,
548
553
  "setter": false,
549
- "reflect": true
554
+ "reflect": true,
555
+ "attribute": "value"
550
556
  }
551
557
  };
552
558
  }
@@ -1 +1 @@
1
- {"version":3,"file":"bq-radio-group.js","sourceRoot":"","sources":["../../../../../../packages/beeq/src/components/radio-group/bq-radio-group.tsx"],"names":[],"mappings":"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","sourcesContent":["import { AttachInternals, Component, Element, Event, h, Host, Listen, Prop, State, Watch } from '@stencil/core';\nimport type { EventEmitter } from '@stencil/core';\n\nimport { RADIO_GROUP_ORIENTATION } from './bq-radio-group.types';\nimport type { TRadioGroupOrientation } from './bq-radio-group.types';\nimport {\n debounce,\n getNextElement,\n isDefined,\n isEventTargetChildOfElement,\n isNil,\n TDebounce,\n validatePropValue,\n} from '../../shared/utils';\n\nconst KEY_MAP = {\n ArrowDown: 'forward',\n ArrowRight: 'forward',\n ArrowUp: 'backward',\n ArrowLeft: 'backward',\n} as const;\n\ntype Direction = (typeof KEY_MAP)[keyof typeof KEY_MAP];\n\n/**\n * The radio group is a user interface component that groups radio buttons to enable a single selection within the group.\n *\n * @example How to use it\n * ```html\n * <bq-radio-group fieldset value=\"option1\">\n * <span slot=\"label\">radio group</span>\n * <bq-radio value=\"option1\">Radio option 1</bq-radio>\n * <bq-radio value=\"option2\">Radio option 2</bq-radio>\n * <bq-radio value=\"option3\">Radio option 3</bq-radio>\n * </bq-radio-group>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/9718e1-radio-button/b/09d7b1\n * @status stable\n *\n * @attr {boolean} background-on-hover - If `true`, the radio displays background on hover\n * @attr {number} debounce-time - A number representing the delay time (in milliseconds) that bqChange event handler gets triggered once the value change\n * @attr {boolean} disabled - If `true` radio inputs are disabled\n * @attr {boolean} fieldset - If `true` displays fieldset\n * @attr {string} name - Name of the HTML input form control. Submitted with the form as part of a name/value pair\n * @attr {\"horizontal\" | \"vertical\"} orientation - The display orientation of the radio inputs\n * @attr {boolean} required - If `true`, the radio group is required\n * @attr {string} required-validation-message - The native form validation message when the radio group is required\n * @attr {string} value - The display orientation of the radio inputs\n *\n * @method vClick - Simulate a click event on the native `<input>` HTML element used under the hood\n * @method vFocus - Sets focus on the native `<input>` HTML element used under the hood\n * @method vBlur - Remove focus from the native `<input>` HTML element used under the hood\n *\n * @event bqChange - Handler to be called when the radio state changes\n *\n * @slot - The bq-radio items to group\n * @slot label - The label content of radio group\n *\n * @part base - The component's internal wrapper of the radio components.\n * @part label - The `<legend>` element that holds the text content.\n * @part group - The `<div>` element that holds the radio inputs.\n */\n@Component({\n tag: 'bq-radio-group',\n styleUrl: './scss/bq-radio-group.scss',\n formAssociated: true,\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class BqRadioGroup {\n // Own Properties\n // ====================\n\n private initialValue?: string;\n private debouncedBqChange: TDebounce<{ value: string; target: HTMLBqRadioElement }>;\n private focusedBqRadio: HTMLBqRadioElement | null = null;\n private readonly radioElementsSet = new Set<HTMLBqRadioElement>();\n private cachedRadioElements: HTMLBqRadioElement[] = [];\n\n // Reference to host HTML element\n // ===================================\n\n @AttachInternals() internals!: ElementInternals;\n @Element() el!: HTMLBqRadioGroupElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n @State() checkedRadio?: HTMLBqRadioElement;\n @State() tabIndex: '0' | '-1' = '0';\n\n // Public Property API\n // ========================\n\n /** If true, all radio inputs in the group will display a background on hover */\n @Prop({ reflect: true }) backgroundOnHover = false;\n\n /** A number representing the delay time (in milliseconds) that `bqChange` event handler gets triggered once the value change */\n @Prop({ reflect: true, mutable: true }) debounceTime = 0;\n\n /** If true radio inputs are disabled */\n @Prop({ reflect: true }) disabled = false;\n\n /** If true displays fieldset */\n @Prop({ reflect: true }) fieldset = false;\n\n /** Name of the HTML input form control. Submitted with the form as part of a name/value pair. */\n @Prop({ reflect: true }) name!: string;\n\n /** The display orientation of the radio inputs */\n @Prop({ reflect: true, mutable: true }) orientation: TRadioGroupOrientation = 'vertical';\n\n /** If true, the radio group is required */\n @Prop({ reflect: true }) required = false;\n\n /** The native form validation message when the radio group is required */\n @Prop({ reflect: true }) requiredValidationMessage?: string;\n\n /** A string representing the value of the radio. */\n @Prop({ reflect: true, mutable: true }) value?: string;\n\n // Prop lifecycle events\n // =======================\n\n @Watch('debounceTime')\n handleDebounceTimeChange() {\n const MIN_DEBOUNCE_TIME = 0;\n const normalizedDebounceTime = Math.max(MIN_DEBOUNCE_TIME, this.debounceTime);\n\n if (normalizedDebounceTime !== this.debounceTime) {\n this.debounceTime = normalizedDebounceTime;\n }\n\n this.debouncedBqChange?.cancel();\n this.debouncedBqChange = debounce((event: { value: string; target: HTMLBqRadioElement }): void => {\n this.bqChange?.emit(event);\n }, this.debounceTime);\n }\n\n @Watch('disabled')\n handleDisabledChange() {\n this.tabIndex = this.disabled ? '-1' : '0';\n this.updateRadioTabIndexes();\n }\n\n @Watch('backgroundOnHover')\n @Watch('disabled')\n @Watch('name')\n @Watch('required')\n handleGroupProperties() {\n this.updateRadioProperties();\n }\n\n @Watch('orientation')\n checkPropValues() {\n validatePropValue(RADIO_GROUP_ORIENTATION, 'vertical', this.el, 'orientation');\n }\n\n @Watch('required')\n handleRequiredChange() {\n this.updateFormValidity();\n }\n\n @Watch('value')\n handleValueChange() {\n this.updateRadioProperties();\n this.updateFormValidity();\n\n // Find and update the checked radio based on the new value\n const newCheckedRadio = this.cachedRadioElements.find((radio) => radio.value === this.value);\n if (newCheckedRadio) {\n this.checkedRadio = newCheckedRadio;\n this.debouncedBqChange?.({ value: this.value, target: newCheckedRadio });\n } else {\n this.checkedRadio = undefined;\n }\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n /** Handler to be called when the radio state changes */\n @Event() bqChange: EventEmitter<{ value: string; target: HTMLBqRadioElement }>;\n\n /** Handler to be called when the radio loses focus */\n @Event() bqBlur: EventEmitter<HTMLBqRadioElement>;\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n componentWillLoad() {\n this.initialValue = this.value;\n this.handleDebounceTimeChange();\n this.internals.setFormValue(this.value ?? null);\n\n this.updateCustomStates();\n this.updateFormValidity();\n }\n\n disconnectedCallback() {\n this.debouncedBqChange?.cancel();\n }\n\n formAssociatedCallback() {\n this.internals.setFormValue(this.value ?? null);\n this.updateFormValidity();\n }\n\n formResetCallback() {\n this.value = this.initialValue;\n this.internals.setFormValue(this.value ?? null);\n this.updateFormValidity();\n this.updateCustomStates();\n }\n\n // Listeners\n // ==============\n\n @Listen('bqClick', { capture: true })\n async onBqClick(event: CustomEvent<{ value: string; target: HTMLBqRadioElement }>) {\n if (!isEventTargetChildOfElement(event, this.el)) return;\n\n const { target, value } = event.detail;\n if (value === this.value) return;\n\n requestAnimationFrame(() => {\n if (event.defaultPrevented) return;\n this.updateRadioSelection(target);\n });\n }\n\n @Listen('bqKeyDown')\n onBqKeyDown(event: CustomEvent<{ key: string; target: HTMLBqRadioElement }>) {\n if (!isEventTargetChildOfElement(event, this.el)) return;\n\n const direction: Direction | undefined = KEY_MAP[event.detail.key];\n if (!direction) return;\n\n this.focusRadioInputSibling(event.detail.target, direction);\n }\n\n @Listen('bqFocus', { capture: true })\n onBqFocus(event: CustomEvent<HTMLBqRadioElement>) {\n if (!isEventTargetChildOfElement(event, this.el)) return;\n\n const shouldStopPropagation = isDefined(this.focusedBqRadio);\n this.focusedBqRadio = event.detail;\n\n if (shouldStopPropagation) {\n event.stopPropagation();\n }\n }\n\n @Listen('bqBlur', { capture: true })\n onBqBlur(event: CustomEvent<HTMLBqRadioElement>) {\n if (!isEventTargetChildOfElement(event, this.el)) return;\n\n // NOTE: if focusedBqRadio is nil that means the event occured from this component\n if (isNil(this.focusedBqRadio)) return;\n\n event.stopPropagation();\n\n requestAnimationFrame(() => {\n if (this.focusedBqRadio !== event.detail) return;\n\n this.focusedBqRadio = null;\n this.bqBlur.emit(event.detail);\n });\n }\n\n // Public methods API\n // These methods are exposed on the host element.\n // Always use two lines.\n // Public Methods must be async.\n // Requires JSDocs for public API documentation.\n // ===============================================\n\n // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n /**\n * Initializes the radio elements set by querying the host element for `ds-radio` elements.\n * This is done to avoid re-querying the host element for radio elements on every change.\n */\n private initializeRadioElements = (): void => {\n this.radioElementsSet.clear();\n this.el.querySelectorAll('bq-radio').forEach((radio) => this.radioElementsSet.add(radio));\n // Caching the radio elements in an array for faster access and iteration\n this.cachedRadioElements = Array.from(this.radioElementsSet);\n // Set the tabIndex of the host element to -1 if there are no radio elements or the group is disabled, otherwise set it to 0\n this.tabIndex = this.cachedRadioElements.length === 0 || this.disabled ? '-1' : '0';\n // Set initial tabIndex for all radios\n this.updateRadioTabIndexes();\n };\n\n /**\n * Sets tabIndex for all radio elements based on current state\n * Handles all scenarios: disabled state, checked radio, value matching, fallback to first\n */\n private updateRadioTabIndexes = (): void => {\n if (this.cachedRadioElements.length === 0) return;\n\n // If disabled, all radios get tabIndex -1\n if (this.disabled) {\n this.cachedRadioElements.forEach((radio) => (radio.tabIndex = -1));\n return;\n }\n\n // Find which radio should be focusable\n let focusableRadio: HTMLBqRadioElement | undefined;\n\n // Priority 1: Currently checked radio\n focusableRadio = this.cachedRadioElements.find((radio) => radio.checked);\n\n // Priority 2: Radio matching current value\n if (!focusableRadio && this.value) {\n focusableRadio = this.cachedRadioElements.find((radio) => radio.value === this.value);\n }\n\n // Priority 3: First enabled radio (fallback)\n if (!focusableRadio) {\n focusableRadio = this.cachedRadioElements.find((radio) => !radio.disabled);\n }\n\n // Apply tabIndex to all radios\n this.cachedRadioElements.forEach((radio) => {\n radio.tabIndex = radio === focusableRadio ? 0 : -1;\n });\n };\n\n /**\n * Updates the radio selection and focus.\n * @param target - The radio element to update.\n */\n private updateRadioSelection = (target: HTMLBqRadioElement): void => {\n // Only uncheck the previously checked radio if it's different\n if (this.checkedRadio && this.checkedRadio !== target) {\n this.checkedRadio.checked = false;\n this.checkedRadio.tabIndex = -1;\n }\n\n target.checked = true;\n target.tabIndex = 0;\n target.vFocus();\n\n this.checkedRadio = target;\n this.value = target.value;\n this.internals?.setFormValue(this.value ?? null);\n\n this.updateRadioTabIndexes();\n };\n\n /**\n * Synchronizes properties of child radio elements with the group's state.\n */\n private updateRadioProperties = (): void => {\n if (this.cachedRadioElements.length === 0) return;\n\n const { backgroundOnHover, disabled, name, required, value } = this;\n\n for (const radio of this.cachedRadioElements) {\n radio.backgroundOnHover = backgroundOnHover;\n radio.checked = value === radio.value;\n // This will allows us to force all radio elements to be disabled\n // while keeping the disabled state of the radio element if it was set individually by the user\n radio.forceDisabled = disabled;\n radio.name = name;\n radio.required = required;\n }\n };\n\n /**\n * Focuses the next/previous radio element in the group based on the current target.\n * Handles circular navigation and skips disabled elements.\n * @param currentTarget - The currently focused radio element\n * @param direction - The navigation direction ('forward' | 'backward')\n */\n private focusRadioInputSibling = (currentTarget: HTMLBqRadioElement, direction: Direction): void => {\n // If there is none or only one radio element, there will be no sibling to focus\n if (this.cachedRadioElements.length <= 1) return;\n\n const currentIndex = this.cachedRadioElements.indexOf(currentTarget);\n // If the index of the radio element target is not found, it means that it's not part of the group\n if (currentIndex === -1) return;\n\n const nextElement = getNextElement(this.cachedRadioElements, currentIndex, direction);\n this.updateRadioSelection(nextElement);\n };\n\n private updateFormValidity = async (): Promise<void> => {\n const { internals, required, requiredValidationMessage, value } = this;\n // Clear the validity state\n internals?.states.clear();\n\n if (!required || (required && !isNil(value))) {\n // If the radio group is not required or has a value, set the validity state to valid\n internals?.states.add('valid');\n internals?.setValidity({});\n return;\n }\n\n const firstRadio = this.cachedRadioElements[0];\n if (!firstRadio) return;\n // If the radio group is required and has no value, set the validity state to invalid\n internals?.states.add('invalid');\n // We need to pass the native input element to the setValidity method as anchor element\n internals?.setValidity(\n { valueMissing: true },\n requiredValidationMessage ?? 'Please select an option',\n await firstRadio.getNativeInput(),\n );\n };\n\n /**\n * Updates the custom states based on the component properties.\n * The custom states can be used to style the component based on the component properties.\n * The custom states are `disabled`, based on the component properties.\n */\n private updateCustomStates = (): void => {\n const states = new Set<string>();\n\n if (this.disabled) states.add('disabled');\n if (this.orientation) states.add(this.orientation);\n\n // Update states\n this.internals?.states.clear();\n states.forEach((state) => this.internals?.states.add(state));\n };\n\n private handleSlotChange = (): void => {\n this.initializeRadioElements();\n this.updateRadioProperties();\n };\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <Host tabindex={this.tabIndex}>\n <fieldset\n class={{ 'bq-radio-group': true, 'has-fieldset': this.fieldset }}\n aria-controls=\"bq-radiogroup\"\n aria-labelledby=\"bq-radio-group__label\"\n aria-disabled={this.disabled}\n aria-required={this.required}\n disabled={this.disabled}\n role=\"radiogroup\"\n part=\"base\"\n >\n <legend part=\"label\">\n <slot id=\"bq-radiogroup__label\" name=\"label\" />\n </legend>\n <div class={`bq-radio-group--${this.orientation}`} part=\"group\">\n <slot id=\"bq-radiogroup\" onSlotchange={this.handleSlotChange} />\n </div>\n </fieldset>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"bq-radio-group.js","sourceRoot":"","sources":["../../../../../../packages/beeq/src/components/radio-group/bq-radio-group.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { EventEmitter } from '@stencil/core';\nimport { AttachInternals, Component, Element, Event, Host, h, Listen, Prop, State, Watch } from '@stencil/core';\n\nimport {\n debounce,\n getNextElement,\n isDefined,\n isEventTargetChildOfElement,\n isNil,\n type TDebounce,\n validatePropValue,\n} from '../../shared/utils';\nimport type { TRadioGroupOrientation } from './bq-radio-group.types';\nimport { RADIO_GROUP_ORIENTATION } from './bq-radio-group.types';\n\nconst KEY_MAP = {\n ArrowDown: 'forward',\n ArrowRight: 'forward',\n ArrowUp: 'backward',\n ArrowLeft: 'backward',\n} as const;\n\ntype Direction = (typeof KEY_MAP)[keyof typeof KEY_MAP];\n\n/**\n * The radio group is a user interface component that groups radio buttons to enable a single selection within the group.\n *\n * @example How to use it\n * ```html\n * <bq-radio-group fieldset value=\"option1\">\n * <span slot=\"label\">radio group</span>\n * <bq-radio value=\"option1\">Radio option 1</bq-radio>\n * <bq-radio value=\"option2\">Radio option 2</bq-radio>\n * <bq-radio value=\"option3\">Radio option 3</bq-radio>\n * </bq-radio-group>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/9718e1-radio-button/b/09d7b1\n * @status stable\n *\n * @attr {boolean} background-on-hover - If `true`, the radio displays background on hover\n * @attr {number} debounce-time - A number representing the delay time (in milliseconds) that bqChange event handler gets triggered once the value change\n * @attr {boolean} disabled - If `true` radio inputs are disabled\n * @attr {boolean} fieldset - If `true` displays fieldset\n * @attr {string} name - Name of the HTML input form control. Submitted with the form as part of a name/value pair\n * @attr {\"horizontal\" | \"vertical\"} orientation - The display orientation of the radio inputs\n * @attr {boolean} required - If `true`, the radio group is required\n * @attr {string} required-validation-message - The native form validation message when the radio group is required\n * @attr {string} value - The display orientation of the radio inputs\n *\n * @method vClick - Simulate a click event on the native `<input>` HTML element used under the hood\n * @method vFocus - Sets focus on the native `<input>` HTML element used under the hood\n * @method vBlur - Remove focus from the native `<input>` HTML element used under the hood\n *\n * @event bqChange - Handler to be called when the radio state changes\n *\n * @slot - The bq-radio items to group\n * @slot label - The label content of radio group\n *\n * @part base - The component's internal wrapper of the radio components.\n * @part label - The `<legend>` element that holds the text content.\n * @part group - The `<div>` element that holds the radio inputs.\n */\n@Component({\n tag: 'bq-radio-group',\n styleUrl: './scss/bq-radio-group.scss',\n formAssociated: true,\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class BqRadioGroup {\n // Own Properties\n // ====================\n\n private initialValue?: string;\n private debouncedBqChange: TDebounce<{ value: string; target: HTMLBqRadioElement }>;\n private focusedBqRadio: HTMLBqRadioElement | null = null;\n private readonly radioElementsSet = new Set<HTMLBqRadioElement>();\n private cachedRadioElements: HTMLBqRadioElement[] = [];\n\n // Reference to host HTML element\n // ===================================\n\n @AttachInternals() internals!: ElementInternals;\n @Element() el!: HTMLBqRadioGroupElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n @State() checkedRadio?: HTMLBqRadioElement;\n @State() tabIndex: '0' | '-1' = '0';\n\n // Public Property API\n // ========================\n\n /** If true, all radio inputs in the group will display a background on hover */\n @Prop({ reflect: true }) backgroundOnHover = false;\n\n /** A number representing the delay time (in milliseconds) that `bqChange` event handler gets triggered once the value change */\n @Prop({ reflect: true, mutable: true }) debounceTime = 0;\n\n /** If true radio inputs are disabled */\n @Prop({ reflect: true }) disabled = false;\n\n /** If true displays fieldset */\n @Prop({ reflect: true }) fieldset = false;\n\n /** Name of the HTML input form control. Submitted with the form as part of a name/value pair. */\n @Prop({ reflect: true }) name!: string;\n\n /** The display orientation of the radio inputs */\n @Prop({ reflect: true, mutable: true }) orientation: TRadioGroupOrientation = 'vertical';\n\n /** If true, the radio group is required */\n @Prop({ reflect: true }) required = false;\n\n /** The native form validation message when the radio group is required */\n @Prop({ reflect: true }) requiredValidationMessage?: string;\n\n /** A string representing the value of the radio. */\n @Prop({ reflect: true, mutable: true }) value?: string;\n\n // Prop lifecycle events\n // =======================\n\n @Watch('debounceTime')\n handleDebounceTimeChange() {\n const MIN_DEBOUNCE_TIME = 0;\n const normalizedDebounceTime = Math.max(MIN_DEBOUNCE_TIME, this.debounceTime);\n\n if (normalizedDebounceTime !== this.debounceTime) {\n this.debounceTime = normalizedDebounceTime;\n }\n\n this.debouncedBqChange?.cancel();\n this.debouncedBqChange = debounce((event: { value: string; target: HTMLBqRadioElement }): void => {\n this.bqChange?.emit(event);\n }, this.debounceTime);\n }\n\n @Watch('disabled')\n handleDisabledChange() {\n this.tabIndex = this.disabled ? '-1' : '0';\n this.updateRadioTabIndexes();\n }\n\n @Watch('backgroundOnHover')\n @Watch('disabled')\n @Watch('name')\n @Watch('required')\n handleGroupProperties() {\n this.updateRadioProperties();\n }\n\n @Watch('orientation')\n checkPropValues() {\n validatePropValue(RADIO_GROUP_ORIENTATION, 'vertical', this.el, 'orientation');\n }\n\n @Watch('required')\n handleRequiredChange() {\n this.updateFormValidity();\n }\n\n @Watch('value')\n handleValueChange() {\n this.updateRadioProperties();\n this.updateFormValidity();\n\n // Find and update the checked radio based on the new value\n const newCheckedRadio = this.cachedRadioElements.find((radio) => radio.value === this.value);\n if (newCheckedRadio) {\n this.checkedRadio = newCheckedRadio;\n this.debouncedBqChange?.({ value: this.value, target: newCheckedRadio });\n } else {\n this.checkedRadio = undefined;\n }\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n /** Handler to be called when the radio state changes */\n @Event() bqChange: EventEmitter<{ value: string; target: HTMLBqRadioElement }>;\n\n /** Handler to be called when the radio loses focus */\n @Event() bqBlur: EventEmitter<HTMLBqRadioElement>;\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n componentWillLoad() {\n this.initialValue = this.value;\n this.handleDebounceTimeChange();\n this.internals.setFormValue(this.value ?? null);\n\n this.updateCustomStates();\n this.updateFormValidity();\n }\n\n disconnectedCallback() {\n this.debouncedBqChange?.cancel();\n }\n\n formAssociatedCallback() {\n this.internals.setFormValue(this.value ?? null);\n this.updateFormValidity();\n }\n\n formResetCallback() {\n this.value = this.initialValue;\n this.internals.setFormValue(this.value ?? null);\n this.updateFormValidity();\n this.updateCustomStates();\n }\n\n // Listeners\n // ==============\n\n @Listen('bqClick', { capture: true })\n async onBqClick(event: CustomEvent<{ value: string; target: HTMLBqRadioElement }>) {\n if (!isEventTargetChildOfElement(event, this.el)) return;\n\n const { target, value } = event.detail;\n if (value === this.value) return;\n\n requestAnimationFrame(() => {\n if (event.defaultPrevented) return;\n this.updateRadioSelection(target);\n });\n }\n\n @Listen('bqKeyDown')\n onBqKeyDown(event: CustomEvent<{ key: string; target: HTMLBqRadioElement }>) {\n if (!isEventTargetChildOfElement(event, this.el)) return;\n\n const direction: Direction | undefined = KEY_MAP[event.detail.key];\n if (!direction) return;\n\n this.focusRadioInputSibling(event.detail.target, direction);\n }\n\n @Listen('bqFocus', { capture: true })\n onBqFocus(event: CustomEvent<HTMLBqRadioElement>) {\n if (!isEventTargetChildOfElement(event, this.el)) return;\n\n const shouldStopPropagation = isDefined(this.focusedBqRadio);\n this.focusedBqRadio = event.detail;\n\n if (shouldStopPropagation) {\n event.stopPropagation();\n }\n }\n\n @Listen('bqBlur', { capture: true })\n onBqBlur(event: CustomEvent<HTMLBqRadioElement>) {\n if (!isEventTargetChildOfElement(event, this.el)) return;\n\n // NOTE: if focusedBqRadio is nil that means the event occurred from this component\n if (isNil(this.focusedBqRadio)) return;\n\n event.stopPropagation();\n\n requestAnimationFrame(() => {\n if (this.focusedBqRadio !== event.detail) return;\n\n this.focusedBqRadio = null;\n this.bqBlur.emit(event.detail);\n });\n }\n\n // Public methods API\n // These methods are exposed on the host element.\n // Always use two lines.\n // Public Methods must be async.\n // Requires JSDocs for public API documentation.\n // ===============================================\n\n // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n /**\n * Initializes the radio elements set by querying the host element for `ds-radio` elements.\n * This is done to avoid re-querying the host element for radio elements on every change.\n */\n private initializeRadioElements = (): void => {\n this.radioElementsSet.clear();\n this.el.querySelectorAll('bq-radio').forEach((radio) => {\n this.radioElementsSet.add(radio);\n });\n // Caching the radio elements in an array for faster access and iteration\n this.cachedRadioElements = Array.from(this.radioElementsSet);\n // Set the tabIndex of the host element to -1 if there are no radio elements or the group is disabled, otherwise set it to 0\n this.tabIndex = this.cachedRadioElements.length === 0 || this.disabled ? '-1' : '0';\n // Set initial tabIndex for all radios\n this.updateRadioTabIndexes();\n };\n\n /**\n * Sets tabIndex for all radio elements based on current state\n * Handles all scenarios: disabled state, checked radio, value matching, fallback to first\n */\n private updateRadioTabIndexes = (): void => {\n if (this.cachedRadioElements.length === 0) return;\n\n // If disabled, all radios get tabIndex -1\n if (this.disabled) {\n this.cachedRadioElements.forEach((radio) => {\n radio.tabIndex = -1;\n });\n return;\n }\n\n // Find which radio should be focusable\n let focusableRadio: HTMLBqRadioElement | undefined;\n\n // Priority 1: Currently checked radio\n focusableRadio = this.cachedRadioElements.find((radio) => radio.checked);\n\n // Priority 2: Radio matching current value\n if (!focusableRadio && this.value) {\n focusableRadio = this.cachedRadioElements.find((radio) => radio.value === this.value);\n }\n\n // Priority 3: First enabled radio (fallback)\n if (!focusableRadio) {\n focusableRadio = this.cachedRadioElements.find((radio) => !radio.disabled);\n }\n\n // Apply tabIndex to all radios\n this.cachedRadioElements.forEach((radio) => {\n radio.tabIndex = radio === focusableRadio ? 0 : -1;\n });\n };\n\n /**\n * Updates the radio selection and focus.\n * @param target - The radio element to update.\n */\n private updateRadioSelection = (target: HTMLBqRadioElement): void => {\n // Only uncheck the previously checked radio if it's different\n if (this.checkedRadio && this.checkedRadio !== target) {\n this.checkedRadio.checked = false;\n this.checkedRadio.tabIndex = -1;\n }\n\n target.checked = true;\n target.tabIndex = 0;\n target.vFocus();\n\n this.checkedRadio = target;\n this.value = target.value;\n this.internals?.setFormValue(this.value ?? null);\n\n this.updateRadioTabIndexes();\n };\n\n /**\n * Synchronizes properties of child radio elements with the group's state.\n */\n private updateRadioProperties = (): void => {\n if (this.cachedRadioElements.length === 0) return;\n\n const { backgroundOnHover, disabled, name, required, value } = this;\n\n for (const radio of this.cachedRadioElements) {\n radio.backgroundOnHover = backgroundOnHover;\n radio.checked = value === radio.value;\n // This will allows us to force all radio elements to be disabled\n // while keeping the disabled state of the radio element if it was set individually by the user\n radio.forceDisabled = disabled;\n radio.name = name;\n radio.required = required;\n }\n };\n\n /**\n * Focuses the next/previous radio element in the group based on the current target.\n * Handles circular navigation and skips disabled elements.\n * @param currentTarget - The currently focused radio element\n * @param direction - The navigation direction ('forward' | 'backward')\n */\n private focusRadioInputSibling = (currentTarget: HTMLBqRadioElement, direction: Direction): void => {\n // If there is none or only one radio element, there will be no sibling to focus\n if (this.cachedRadioElements.length <= 1) return;\n\n const currentIndex = this.cachedRadioElements.indexOf(currentTarget);\n // If the index of the radio element target is not found, it means that it's not part of the group\n if (currentIndex === -1) return;\n\n const nextElement = getNextElement(this.cachedRadioElements, currentIndex, direction);\n this.updateRadioSelection(nextElement);\n };\n\n private updateFormValidity = async (): Promise<void> => {\n const { internals, required, requiredValidationMessage, value } = this;\n // Clear the validity state\n internals?.states.clear();\n\n if (!required || (required && !isNil(value))) {\n // If the radio group is not required or has a value, set the validity state to valid\n internals?.states.add('valid');\n internals?.setValidity({});\n return;\n }\n\n const firstRadio = this.cachedRadioElements[0];\n if (!firstRadio) return;\n // If the radio group is required and has no value, set the validity state to invalid\n internals?.states.add('invalid');\n // We need to pass the native input element to the setValidity method as anchor element\n internals?.setValidity(\n { valueMissing: true },\n requiredValidationMessage ?? 'Please select an option',\n await firstRadio.getNativeInput(),\n );\n };\n\n /**\n * Updates the custom states based on the component properties.\n * The custom states can be used to style the component based on the component properties.\n * The custom states are `disabled`, based on the component properties.\n */\n private updateCustomStates = (): void => {\n const states = new Set<string>();\n\n if (this.disabled) states.add('disabled');\n if (this.orientation) states.add(this.orientation);\n\n // Update states\n this.internals?.states.clear();\n states.forEach((state) => {\n this.internals?.states.add(state);\n });\n };\n\n private handleSlotChange = (): void => {\n this.initializeRadioElements();\n this.updateRadioProperties();\n };\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <Host tabindex={this.tabIndex}>\n <fieldset\n aria-controls=\"bq-radiogroup\"\n aria-disabled={this.disabled}\n aria-labelledby=\"bq-radio-group__label\"\n class={{ 'bq-radio-group': true, 'has-fieldset': this.fieldset }}\n disabled={this.disabled}\n part=\"base\"\n >\n <legend part=\"label\">\n <slot id=\"bq-radiogroup__label\" name=\"label\" />\n </legend>\n <div class={`bq-radio-group--${this.orientation}`} part=\"group\">\n <slot id=\"bq-radiogroup\" onSlotchange={this.handleSlotChange} />\n </div>\n </fieldset>\n </Host>\n );\n }\n}\n"]}