@beeq/core 1.11.2 → 1.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (737) 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/index.esm.js +1 -1
  4. package/dist/beeq/p-039f7907.entry.js +6 -0
  5. package/dist/beeq/p-039f7907.entry.js.map +1 -0
  6. package/dist/beeq/{p-eb47c1ae.entry.js → p-043a472a.entry.js} +2 -2
  7. package/dist/beeq/p-043a472a.entry.js.map +1 -0
  8. package/dist/beeq/p-1b988f57.entry.js +6 -0
  9. package/dist/beeq/p-1b988f57.entry.js.map +1 -0
  10. package/dist/beeq/p-20de0359.entry.js +6 -0
  11. package/dist/beeq/p-20de0359.entry.js.map +1 -0
  12. package/dist/beeq/p-22e2de76.entry.js +6 -0
  13. package/dist/beeq/p-22e2de76.entry.js.map +1 -0
  14. package/dist/beeq/p-258e890f.entry.js +6 -0
  15. package/dist/beeq/p-258e890f.entry.js.map +1 -0
  16. package/dist/beeq/p-28c6cdbc.entry.js +6 -0
  17. package/dist/beeq/p-28c6cdbc.entry.js.map +1 -0
  18. package/dist/beeq/p-3c491238.entry.js +6 -0
  19. package/dist/beeq/p-3c491238.entry.js.map +1 -0
  20. package/dist/beeq/{p-cd53041f.entry.js → p-47404d61.entry.js} +2 -2
  21. package/dist/beeq/p-47404d61.entry.js.map +1 -0
  22. package/dist/beeq/p-50cbee50.entry.js +6 -0
  23. package/dist/beeq/p-50cbee50.entry.js.map +1 -0
  24. package/dist/beeq/{p-b88b2573.entry.js → p-52334e53.entry.js} +2 -2
  25. package/dist/{cjs/bq-tab.entry.cjs.js.map → beeq/p-52334e53.entry.js.map} +1 -1
  26. package/dist/beeq/p-552d3e73.entry.js +6 -0
  27. package/dist/beeq/p-552d3e73.entry.js.map +1 -0
  28. package/dist/{components/p-CXUO6Zub.js → beeq/p-55b686b4.entry.js} +2 -2
  29. package/dist/beeq/p-55b686b4.entry.js.map +1 -0
  30. package/dist/beeq/p-59cb331c.entry.js +6 -0
  31. package/dist/beeq/p-59cb331c.entry.js.map +1 -0
  32. package/dist/beeq/p-5e186220.entry.js +6 -0
  33. package/dist/beeq/p-5e186220.entry.js.map +1 -0
  34. package/dist/beeq/p-63f1dcd2.entry.js +6 -0
  35. package/dist/beeq/p-63f1dcd2.entry.js.map +1 -0
  36. package/dist/beeq/{p-662578a2.entry.js → p-6cac6da2.entry.js} +2 -2
  37. package/dist/beeq/p-6cac6da2.entry.js.map +1 -0
  38. package/dist/beeq/p-76d65605.entry.js +6 -0
  39. package/dist/beeq/p-76d65605.entry.js.map +1 -0
  40. package/dist/beeq/p-8379d440.entry.js +6 -0
  41. package/dist/beeq/p-8379d440.entry.js.map +1 -0
  42. package/dist/{components/p-B5XEhmuc.js → beeq/p-8a5e127b.entry.js} +2 -2
  43. package/dist/beeq/p-8a5e127b.entry.js.map +1 -0
  44. package/dist/beeq/{p-84e62655.entry.js → p-8cd20d85.entry.js} +2 -2
  45. package/dist/beeq/p-8cd20d85.entry.js.map +1 -0
  46. package/dist/beeq/{p-cb0639d5.entry.js → p-8e9d8445.entry.js} +2 -2
  47. package/dist/beeq/p-8e9d8445.entry.js.map +1 -0
  48. package/dist/{components/p-DHdYy1q5.js → beeq/p-8fd716b1.entry.js} +2 -2
  49. package/dist/beeq/p-8fd716b1.entry.js.map +1 -0
  50. package/dist/beeq/p-904e521c.entry.js +6 -0
  51. package/dist/beeq/p-904e521c.entry.js.map +1 -0
  52. package/dist/beeq/p-90b0fef1.entry.js +6 -0
  53. package/dist/beeq/p-90b0fef1.entry.js.map +1 -0
  54. package/dist/beeq/p-96a79f9b.entry.js +6 -0
  55. package/dist/beeq/p-96a79f9b.entry.js.map +1 -0
  56. package/dist/beeq/p-BIw6Ac7W.js +7 -0
  57. package/dist/beeq/p-BIw6Ac7W.js.map +1 -0
  58. package/dist/beeq/p-BRMw_HGf.js +6 -0
  59. package/dist/beeq/p-BRMw_HGf.js.map +1 -0
  60. package/dist/beeq/p-C33fRBEf.js +6 -0
  61. package/dist/beeq/p-C33fRBEf.js.map +1 -0
  62. package/dist/beeq/p-CpKQ7XUL.js +6 -0
  63. package/dist/beeq/p-CpKQ7XUL.js.map +1 -0
  64. package/dist/beeq/p-D1A0LpG_.js +6 -0
  65. package/dist/beeq/{p-BxgDLPzX.js.map → p-D1A0LpG_.js.map} +1 -1
  66. package/dist/beeq/p-a09d8901.entry.js +6 -0
  67. package/dist/beeq/p-a09d8901.entry.js.map +1 -0
  68. package/dist/beeq/p-a7a74198.entry.js +6 -0
  69. package/dist/beeq/p-a7a74198.entry.js.map +1 -0
  70. package/dist/beeq/p-a9cc76af.entry.js +6 -0
  71. package/dist/beeq/p-a9cc76af.entry.js.map +1 -0
  72. package/dist/beeq/p-b4a612db.entry.js +6 -0
  73. package/dist/beeq/p-b4a612db.entry.js.map +1 -0
  74. package/dist/beeq/{p-dc5aa386.entry.js → p-b7de07f5.entry.js} +2 -2
  75. package/dist/beeq/p-b7de07f5.entry.js.map +1 -0
  76. package/dist/beeq/p-be1b3e87.entry.js +6 -0
  77. package/dist/beeq/p-be1b3e87.entry.js.map +1 -0
  78. package/dist/beeq/p-c414e7c0.entry.js +6 -0
  79. package/dist/beeq/p-c414e7c0.entry.js.map +1 -0
  80. package/dist/beeq/p-d4ffd9f1.entry.js +6 -0
  81. package/dist/beeq/p-d4ffd9f1.entry.js.map +1 -0
  82. package/dist/{components/p-16lKXCDk.js → beeq/p-dfd80d40.entry.js} +2 -2
  83. package/dist/beeq/p-dfd80d40.entry.js.map +1 -0
  84. package/dist/beeq/{p-0bf5e367.entry.js → p-e394c440.entry.js} +2 -2
  85. package/dist/beeq/p-e394c440.entry.js.map +1 -0
  86. package/dist/beeq/p-e39e3d9c.entry.js +6 -0
  87. package/dist/beeq/{bq-switch.entry.esm.js.map → p-e39e3d9c.entry.js.map} +1 -1
  88. package/dist/beeq/p-ecef6efa.entry.js +6 -0
  89. package/dist/beeq/p-ecef6efa.entry.js.map +1 -0
  90. package/dist/beeq/p-f477b7ac.entry.js +6 -0
  91. package/dist/beeq/p-f477b7ac.entry.js.map +1 -0
  92. package/dist/beeq.html-custom-data.json +103 -48
  93. package/dist/cjs/beeq.cjs.js +5 -3
  94. package/dist/cjs/beeq.cjs.js.map +1 -1
  95. package/dist/cjs/bq-accordion-group.cjs.entry.js +20 -9
  96. package/dist/cjs/bq-accordion-group.cjs.entry.js.map +1 -0
  97. package/dist/cjs/bq-accordion.cjs.entry.js +31 -20
  98. package/dist/cjs/bq-accordion.cjs.entry.js.map +1 -0
  99. package/dist/cjs/bq-alert.cjs.entry.js +31 -20
  100. package/dist/cjs/bq-alert.cjs.entry.js.map +1 -0
  101. package/dist/cjs/bq-avatar.cjs.entry.js +32 -19
  102. package/dist/cjs/bq-avatar.cjs.entry.js.map +1 -0
  103. package/dist/cjs/bq-badge.cjs.entry.js +17 -12
  104. package/dist/cjs/bq-badge.cjs.entry.js.map +1 -0
  105. package/dist/cjs/bq-breadcrumb-item.cjs.entry.js +7 -4
  106. package/dist/cjs/bq-breadcrumb-item.cjs.entry.js.map +1 -0
  107. package/dist/cjs/bq-breadcrumb.cjs.entry.js +11 -8
  108. package/dist/cjs/bq-breadcrumb.cjs.entry.js.map +1 -0
  109. package/dist/cjs/bq-button_2.cjs.entry.js +63 -30
  110. package/dist/cjs/bq-button_2.cjs.entry.js.map +1 -0
  111. package/dist/cjs/bq-card.cjs.entry.js +15 -10
  112. package/dist/cjs/bq-card.cjs.entry.js.map +1 -0
  113. package/dist/cjs/bq-checkbox.cjs.entry.js +16 -9
  114. package/dist/cjs/bq-checkbox.cjs.entry.js.map +1 -0
  115. package/dist/cjs/bq-date-picker.cjs.entry.js +189 -137
  116. package/dist/cjs/bq-date-picker.cjs.entry.js.map +1 -0
  117. package/dist/cjs/bq-dialog.cjs.entry.js +29 -20
  118. package/dist/cjs/bq-dialog.cjs.entry.js.map +1 -0
  119. package/dist/cjs/bq-divider.cjs.entry.js +29 -20
  120. package/dist/cjs/{bq-divider.entry.cjs.js.map → bq-divider.cjs.entry.js.map} +1 -1
  121. package/dist/cjs/bq-drawer.cjs.entry.js +33 -24
  122. package/dist/cjs/bq-drawer.cjs.entry.js.map +1 -0
  123. package/dist/cjs/bq-dropdown_2.cjs.entry.js +37 -18
  124. package/dist/cjs/bq-dropdown_2.cjs.entry.js.map +1 -0
  125. package/dist/cjs/bq-empty-state.cjs.entry.js +34 -29
  126. package/dist/cjs/bq-empty-state.cjs.entry.js.map +1 -0
  127. package/dist/cjs/bq-input.cjs.entry.js +31 -26
  128. package/dist/cjs/bq-input.cjs.entry.js.map +1 -0
  129. package/dist/cjs/bq-notification.cjs.entry.js +29 -18
  130. package/dist/cjs/bq-notification.cjs.entry.js.map +1 -0
  131. package/dist/cjs/bq-option-group.cjs.entry.js +7 -4
  132. package/dist/cjs/bq-option-group.cjs.entry.js.map +1 -0
  133. package/dist/cjs/bq-option-list_2.cjs.entry.js +25 -18
  134. package/dist/cjs/bq-option-list_2.cjs.entry.js.map +1 -0
  135. package/dist/cjs/bq-option.cjs.entry.js +20 -17
  136. package/dist/cjs/bq-option.cjs.entry.js.map +1 -0
  137. package/dist/cjs/bq-page-title.cjs.entry.js +16 -13
  138. package/dist/cjs/bq-page-title.cjs.entry.js.map +1 -0
  139. package/dist/cjs/bq-progress.cjs.entry.js +30 -19
  140. package/dist/cjs/bq-progress.cjs.entry.js.map +1 -0
  141. package/dist/cjs/bq-radio-group.cjs.entry.js +33 -12
  142. package/dist/cjs/bq-radio-group.cjs.entry.js.map +1 -0
  143. package/dist/cjs/bq-radio.cjs.entry.js +14 -11
  144. package/dist/cjs/bq-radio.cjs.entry.js.map +1 -0
  145. package/dist/cjs/bq-select.cjs.entry.js +56 -34
  146. package/dist/cjs/bq-select.cjs.entry.js.map +1 -0
  147. package/dist/cjs/bq-side-menu-item.cjs.entry.js +11 -8
  148. package/dist/cjs/bq-side-menu-item.cjs.entry.js.map +1 -0
  149. package/dist/cjs/bq-side-menu.cjs.entry.js +13 -8
  150. package/dist/cjs/bq-side-menu.cjs.entry.js.map +1 -0
  151. package/dist/cjs/bq-slider.cjs.entry.js +38 -29
  152. package/dist/cjs/bq-slider.cjs.entry.js.map +1 -0
  153. package/dist/cjs/bq-spinner.cjs.entry.js +25 -16
  154. package/dist/cjs/bq-spinner.cjs.entry.js.map +1 -0
  155. package/dist/cjs/bq-status.cjs.entry.js +10 -5
  156. package/dist/cjs/bq-status.cjs.entry.js.map +1 -0
  157. package/dist/cjs/bq-step-item.cjs.entry.js +37 -19
  158. package/dist/cjs/bq-step-item.cjs.entry.js.map +1 -0
  159. package/dist/cjs/bq-steps.cjs.entry.js +34 -10
  160. package/dist/cjs/bq-steps.cjs.entry.js.map +1 -0
  161. package/dist/cjs/{bq-steps.types-D4B3f19X.js → bq-steps.types-BvbHJAPO.js} +4 -2
  162. package/dist/cjs/bq-steps.types-BvbHJAPO.js.map +1 -0
  163. package/dist/cjs/bq-switch.cjs.entry.js +18 -13
  164. package/dist/cjs/bq-switch.cjs.entry.js.map +1 -0
  165. package/dist/cjs/bq-tab-group.cjs.entry.js +29 -16
  166. package/dist/cjs/bq-tab-group.cjs.entry.js.map +1 -0
  167. package/dist/cjs/bq-tab.cjs.entry.js +19 -10
  168. package/dist/cjs/bq-tab.cjs.entry.js.map +1 -0
  169. package/dist/cjs/bq-textarea.cjs.entry.js +28 -21
  170. package/dist/cjs/bq-textarea.cjs.entry.js.map +1 -0
  171. package/dist/cjs/bq-toast.cjs.entry.js +19 -8
  172. package/dist/cjs/bq-toast.cjs.entry.js.map +1 -0
  173. package/dist/cjs/bq-tooltip.cjs.entry.js +28 -15
  174. package/dist/cjs/bq-tooltip.cjs.entry.js.map +1 -0
  175. package/dist/{collection/shared/utils/date.js → cjs/form-COLxwVaW.js} +146 -3
  176. package/dist/cjs/form-COLxwVaW.js.map +1 -0
  177. package/dist/cjs/index-C09ZVaB4.js +154 -0
  178. package/dist/cjs/index-C09ZVaB4.js.map +1 -0
  179. package/dist/cjs/{index-g8MkV15i.js → index-Cnm84YLJ.js} +294 -365
  180. package/dist/cjs/index-Cnm84YLJ.js.map +1 -0
  181. package/dist/cjs/index.cjs.js +13 -4
  182. package/dist/cjs/index.cjs.js.map +1 -1
  183. package/dist/cjs/{isHTMLElement-DMA6t4n4.js → isHTMLElement-CtkOWsTF.js} +3 -3
  184. package/dist/{esm/isHTMLElement-BxgDLPzX.js.map → cjs/isHTMLElement-CtkOWsTF.js.map} +1 -1
  185. package/dist/cjs/loader.cjs.js +4 -2
  186. package/dist/collection/collection-manifest.json +2 -2
  187. package/dist/collection/components/accordion/bq-accordion.js +18 -16
  188. package/dist/collection/components/accordion/bq-accordion.js.map +1 -1
  189. package/dist/collection/components/accordion-group/bq-accordion-group.js +6 -4
  190. package/dist/collection/components/accordion-group/bq-accordion-group.js.map +1 -1
  191. package/dist/collection/components/alert/bq-alert.js +20 -17
  192. package/dist/collection/components/alert/bq-alert.js.map +1 -1
  193. package/dist/collection/components/alert/scss/bq-alert.css +1 -1
  194. package/dist/collection/components/avatar/bq-avatar.js +18 -15
  195. package/dist/collection/components/avatar/bq-avatar.js.map +1 -1
  196. package/dist/collection/components/badge/bq-badge.js +12 -10
  197. package/dist/collection/components/badge/bq-badge.js.map +1 -1
  198. package/dist/collection/components/breadcrumb/bq-breadcrumb.js +7 -6
  199. package/dist/collection/components/breadcrumb/bq-breadcrumb.js.map +1 -1
  200. package/dist/collection/components/breadcrumb-item/bq-breadcrumb-item.js +2 -2
  201. package/dist/collection/components/breadcrumb-item/bq-breadcrumb-item.js.map +1 -1
  202. package/dist/collection/components/button/bq-button.js +93 -36
  203. package/dist/collection/components/button/bq-button.js.map +1 -1
  204. package/dist/collection/components/button/scss/bq-button.css +1 -1
  205. package/dist/collection/components/card/bq-card.js +12 -9
  206. package/dist/collection/components/card/bq-card.js.map +1 -1
  207. package/dist/collection/components/checkbox/bq-checkbox.js +5 -5
  208. package/dist/collection/components/checkbox/bq-checkbox.js.map +1 -1
  209. package/dist/collection/components/date-picker/bq-date-picker.js +113 -102
  210. package/dist/collection/components/date-picker/bq-date-picker.js.map +1 -1
  211. package/dist/collection/components/date-picker/bq-date-picker.types.js +1 -0
  212. package/dist/collection/components/date-picker/bq-date-picker.types.js.map +1 -1
  213. package/dist/collection/components/date-picker/helper/constants.js +23 -0
  214. package/dist/collection/components/date-picker/helper/constants.js.map +1 -0
  215. package/dist/collection/components/date-picker/{helper → libs}/callyLibrary.js +57 -38
  216. package/dist/collection/components/date-picker/libs/callyLibrary.js.map +1 -0
  217. package/dist/collection/components/date-picker/scss/bq-date-picker.css +1 -1
  218. package/dist/collection/components/dialog/bq-dialog.js +21 -18
  219. package/dist/collection/components/dialog/bq-dialog.js.map +1 -1
  220. package/dist/collection/components/dialog/scss/bq-dialog.css +1 -1
  221. package/dist/collection/components/divider/bq-divider.js +22 -18
  222. package/dist/collection/components/divider/bq-divider.js.map +1 -1
  223. package/dist/collection/components/divider/scss/bq-divider.css +1 -1
  224. package/dist/collection/components/drawer/bq-drawer.js +24 -21
  225. package/dist/collection/components/drawer/bq-drawer.js.map +1 -1
  226. package/dist/collection/components/drawer/scss/bq-drawer.css +1 -1
  227. package/dist/collection/components/dropdown/bq-dropdown.js +4 -3
  228. package/dist/collection/components/dropdown/bq-dropdown.js.map +1 -1
  229. package/dist/collection/components/empty-state/bq-empty-state.js +28 -27
  230. package/dist/collection/components/empty-state/bq-empty-state.js.map +1 -1
  231. package/dist/collection/components/icon/bq-icon.js +5 -3
  232. package/dist/collection/components/icon/bq-icon.js.map +1 -1
  233. package/dist/collection/components/input/bq-input.js +28 -25
  234. package/dist/collection/components/input/bq-input.js.map +1 -1
  235. package/dist/collection/components/input/scss/bq-input.css +1 -1
  236. package/dist/collection/components/notification/bq-notification.js +17 -14
  237. package/dist/collection/components/notification/bq-notification.js.map +1 -1
  238. package/dist/collection/components/notification/scss/bq-notification.css +1 -1
  239. package/dist/collection/components/option/bq-option.js +16 -15
  240. package/dist/collection/components/option/bq-option.js.map +1 -1
  241. package/dist/collection/components/option-group/bq-option-group.js +2 -2
  242. package/dist/collection/components/option-group/bq-option-group.js.map +1 -1
  243. package/dist/collection/components/option-list/bq-option-list.js +2 -2
  244. package/dist/collection/components/option-list/bq-option-list.js.map +1 -1
  245. package/dist/collection/components/page-title/bq-page-title.js +11 -11
  246. package/dist/collection/components/page-title/bq-page-title.js.map +1 -1
  247. package/dist/collection/components/panel/bq-panel.js +5 -4
  248. package/dist/collection/components/panel/bq-panel.js.map +1 -1
  249. package/dist/collection/components/progress/bq-progress.js +20 -16
  250. package/dist/collection/components/progress/bq-progress.js.map +1 -1
  251. package/dist/collection/components/radio/bq-radio.js +10 -9
  252. package/dist/collection/components/radio/bq-radio.js.map +1 -1
  253. package/dist/collection/components/radio-group/bq-radio-group.js +5 -3
  254. package/dist/collection/components/radio-group/bq-radio-group.js.map +1 -1
  255. package/dist/collection/components/select/bq-select.js +48 -29
  256. package/dist/collection/components/select/bq-select.js.map +1 -1
  257. package/dist/collection/components/select/scss/bq-select.css +1 -1
  258. package/dist/collection/components/side-menu/bq-side-menu.js +8 -6
  259. package/dist/collection/components/side-menu/bq-side-menu.js.map +1 -1
  260. package/dist/collection/components/side-menu-item/bq-side-menu-item.js +6 -6
  261. package/dist/collection/components/side-menu-item/bq-side-menu-item.js.map +1 -1
  262. package/dist/collection/components/slider/bq-slider.js +30 -27
  263. package/dist/collection/components/slider/bq-slider.js.map +1 -1
  264. package/dist/collection/components/spinner/bq-spinner.js +14 -12
  265. package/dist/collection/components/spinner/bq-spinner.js.map +1 -1
  266. package/dist/collection/components/status/bq-status.js +4 -3
  267. package/dist/collection/components/status/bq-status.js.map +1 -1
  268. package/dist/collection/components/step-item/bq-step-item.js +105 -17
  269. package/dist/collection/components/step-item/bq-step-item.js.map +1 -1
  270. package/dist/collection/components/step-item/scss/bq-step-item.css +1 -1
  271. package/dist/collection/components/steps/bq-steps.js +55 -8
  272. package/dist/collection/components/steps/bq-steps.js.map +1 -1
  273. package/dist/collection/components/steps/bq-steps.types.js +1 -0
  274. package/dist/collection/components/steps/bq-steps.types.js.map +1 -1
  275. package/dist/collection/components/steps/scss/bq-steps.css +1 -1
  276. package/dist/collection/components/switch/bq-switch.js +15 -12
  277. package/dist/collection/components/switch/bq-switch.js.map +1 -1
  278. package/dist/collection/components/tab/bq-tab.js +11 -8
  279. package/dist/collection/components/tab/bq-tab.js.map +1 -1
  280. package/dist/collection/components/tab-group/bq-tab-group.js +15 -11
  281. package/dist/collection/components/tab-group/bq-tab-group.js.map +1 -1
  282. package/dist/collection/components/tag/bq-tag.js +19 -14
  283. package/dist/collection/components/tag/bq-tag.js.map +1 -1
  284. package/dist/collection/components/tag/scss/bq-tag.css +1 -1
  285. package/dist/collection/components/textarea/bq-textarea.js +22 -19
  286. package/dist/collection/components/textarea/bq-textarea.js.map +1 -1
  287. package/dist/collection/components/toast/bq-toast.js +9 -5
  288. package/dist/collection/components/toast/bq-toast.js.map +1 -1
  289. package/dist/collection/components/tooltip/bq-tooltip.js +10 -9
  290. package/dist/collection/components/tooltip/bq-tooltip.js.map +1 -1
  291. package/dist/collection/shared/utils/date/dateFormatting.js +86 -0
  292. package/dist/collection/shared/utils/date/dateFormatting.js.map +1 -0
  293. package/dist/{cjs/date-C-h2CBps.js → collection/shared/utils/date/dateParsing.js} +19 -8
  294. package/dist/collection/shared/utils/date/dateParsing.js.map +1 -0
  295. package/dist/collection/shared/utils/date/index.js +7 -0
  296. package/dist/collection/shared/utils/date/index.js.map +1 -0
  297. package/dist/collection/shared/utils/form.js +35 -0
  298. package/dist/collection/shared/utils/form.js.map +1 -0
  299. package/dist/collection/shared/utils/index.js +1 -0
  300. package/dist/collection/shared/utils/index.js.map +1 -1
  301. package/dist/collection/shared/utils/isHTMLElement.js +1 -1
  302. package/dist/collection/shared/utils/isHTMLElement.js.map +1 -1
  303. package/dist/components/bq-accordion-group.js +1 -1
  304. package/dist/components/bq-accordion-group.js.map +1 -1
  305. package/dist/components/bq-accordion.js +1 -1
  306. package/dist/components/bq-accordion.js.map +1 -1
  307. package/dist/components/bq-alert.js +1 -1
  308. package/dist/components/bq-alert.js.map +1 -1
  309. package/dist/components/bq-avatar.js +1 -1
  310. package/dist/components/bq-avatar.js.map +1 -1
  311. package/dist/components/bq-badge.js +1 -1
  312. package/dist/components/bq-breadcrumb-item.js +1 -1
  313. package/dist/components/bq-breadcrumb-item.js.map +1 -1
  314. package/dist/components/bq-breadcrumb.js +1 -1
  315. package/dist/components/bq-breadcrumb.js.map +1 -1
  316. package/dist/components/bq-button.js +1 -1
  317. package/dist/components/bq-card.js +1 -1
  318. package/dist/components/bq-card.js.map +1 -1
  319. package/dist/components/bq-checkbox.js +1 -1
  320. package/dist/components/bq-checkbox.js.map +1 -1
  321. package/dist/components/bq-date-picker.js +1 -1
  322. package/dist/components/bq-date-picker.js.map +1 -1
  323. package/dist/components/bq-dialog.js +1 -1
  324. package/dist/components/bq-dialog.js.map +1 -1
  325. package/dist/components/bq-divider.js +1 -1
  326. package/dist/components/bq-drawer.js +1 -1
  327. package/dist/components/bq-drawer.js.map +1 -1
  328. package/dist/components/bq-dropdown.js +1 -1
  329. package/dist/components/bq-empty-state.js +1 -1
  330. package/dist/components/bq-empty-state.js.map +1 -1
  331. package/dist/components/bq-icon.js +1 -1
  332. package/dist/components/bq-input.js +1 -1
  333. package/dist/components/bq-input.js.map +1 -1
  334. package/dist/components/bq-notification.js +1 -1
  335. package/dist/components/bq-notification.js.map +1 -1
  336. package/dist/components/bq-option-group.js +1 -1
  337. package/dist/components/bq-option-group.js.map +1 -1
  338. package/dist/components/bq-option-list.js +1 -1
  339. package/dist/components/bq-option.js +1 -1
  340. package/dist/components/bq-option.js.map +1 -1
  341. package/dist/components/bq-page-title.js +1 -1
  342. package/dist/components/bq-page-title.js.map +1 -1
  343. package/dist/components/bq-panel.js +1 -1
  344. package/dist/components/bq-progress.js +1 -1
  345. package/dist/components/bq-progress.js.map +1 -1
  346. package/dist/components/bq-radio-group.js +1 -1
  347. package/dist/components/bq-radio-group.js.map +1 -1
  348. package/dist/components/bq-radio.js +1 -1
  349. package/dist/components/bq-radio.js.map +1 -1
  350. package/dist/components/bq-select.js +1 -1
  351. package/dist/components/bq-select.js.map +1 -1
  352. package/dist/components/bq-side-menu-item.js +1 -1
  353. package/dist/components/bq-side-menu-item.js.map +1 -1
  354. package/dist/components/bq-side-menu.js +1 -1
  355. package/dist/components/bq-side-menu.js.map +1 -1
  356. package/dist/components/bq-slider.js +1 -1
  357. package/dist/components/bq-slider.js.map +1 -1
  358. package/dist/components/bq-spinner.js +1 -1
  359. package/dist/components/bq-spinner.js.map +1 -1
  360. package/dist/components/bq-status.js +1 -1
  361. package/dist/components/bq-status.js.map +1 -1
  362. package/dist/components/bq-step-item.js +1 -1
  363. package/dist/components/bq-step-item.js.map +1 -1
  364. package/dist/components/bq-steps.js +1 -1
  365. package/dist/components/bq-steps.js.map +1 -1
  366. package/dist/components/bq-switch.js +1 -1
  367. package/dist/components/bq-switch.js.map +1 -1
  368. package/dist/components/bq-tab-group.js +1 -1
  369. package/dist/components/bq-tab-group.js.map +1 -1
  370. package/dist/components/bq-tab.js +1 -1
  371. package/dist/components/bq-tab.js.map +1 -1
  372. package/dist/components/bq-tag.js +1 -1
  373. package/dist/components/bq-textarea.js +1 -1
  374. package/dist/components/bq-textarea.js.map +1 -1
  375. package/dist/components/bq-toast.js +1 -1
  376. package/dist/components/bq-toast.js.map +1 -1
  377. package/dist/components/bq-tooltip.js +1 -1
  378. package/dist/components/index.d.ts +1 -0
  379. package/dist/components/index.js +1 -1
  380. package/dist/components/index.js.map +1 -1
  381. package/dist/{beeq/p-4647a0fb.entry.js → components/p-B93kqFqH.js} +2 -2
  382. package/dist/components/p-B93kqFqH.js.map +1 -0
  383. package/dist/components/p-BRMw_HGf.js +6 -0
  384. package/dist/components/p-BRMw_HGf.js.map +1 -0
  385. package/dist/components/p-BcmnHFqE.js +6 -0
  386. package/dist/components/p-BcmnHFqE.js.map +1 -0
  387. package/dist/components/p-Bi6ozE0v.js +6 -0
  388. package/dist/components/p-Bi6ozE0v.js.map +1 -0
  389. package/dist/{beeq/p-b1d2e472.entry.js → components/p-C6pBQ61U.js} +2 -2
  390. package/dist/components/p-C6pBQ61U.js.map +1 -0
  391. package/dist/components/{p-DGysEMss.js → p-CCQ_5HvV.js} +2 -2
  392. package/dist/components/p-CCQ_5HvV.js.map +1 -0
  393. package/dist/components/p-D1A0LpG_.js +6 -0
  394. package/dist/components/{p-BxgDLPzX.js.map → p-D1A0LpG_.js.map} +1 -1
  395. package/dist/components/p-DhVt1fuD.js +6 -0
  396. package/dist/components/p-DhVt1fuD.js.map +1 -0
  397. package/dist/components/p-SKH1pCPg.js +6 -0
  398. package/dist/components/p-SKH1pCPg.js.map +1 -0
  399. package/dist/components/{p-A6e1tN-B.js → p-plkW8XNd.js} +2 -2
  400. package/dist/components/p-plkW8XNd.js.map +1 -0
  401. package/dist/components/p-qVvRSuP7.js +6 -0
  402. package/dist/components/p-qVvRSuP7.js.map +1 -0
  403. package/dist/components/p-yO5LAmkd.js +6 -0
  404. package/dist/components/p-yO5LAmkd.js.map +1 -0
  405. package/dist/custom-elements.json +1543 -811
  406. package/dist/esm/beeq.js +6 -4
  407. package/dist/esm/beeq.js.map +1 -1
  408. package/dist/esm/bq-accordion-group.entry.js +20 -9
  409. package/dist/esm/bq-accordion-group.entry.js.map +1 -1
  410. package/dist/esm/bq-accordion.entry.js +31 -20
  411. package/dist/esm/bq-accordion.entry.js.map +1 -1
  412. package/dist/esm/bq-alert.entry.js +31 -20
  413. package/dist/esm/bq-alert.entry.js.map +1 -1
  414. package/dist/esm/bq-avatar.entry.js +32 -19
  415. package/dist/esm/bq-avatar.entry.js.map +1 -1
  416. package/dist/esm/bq-badge.entry.js +17 -12
  417. package/dist/esm/bq-badge.entry.js.map +1 -1
  418. package/dist/esm/bq-breadcrumb-item.entry.js +7 -4
  419. package/dist/esm/bq-breadcrumb-item.entry.js.map +1 -1
  420. package/dist/esm/bq-breadcrumb.entry.js +11 -8
  421. package/dist/esm/bq-breadcrumb.entry.js.map +1 -1
  422. package/dist/esm/bq-button_2.entry.js +63 -30
  423. package/dist/esm/bq-button_2.entry.js.map +1 -0
  424. package/dist/esm/bq-card.entry.js +15 -10
  425. package/dist/esm/bq-card.entry.js.map +1 -1
  426. package/dist/esm/bq-checkbox.entry.js +16 -9
  427. package/dist/esm/bq-checkbox.entry.js.map +1 -1
  428. package/dist/esm/bq-date-picker.entry.js +188 -136
  429. package/dist/esm/bq-date-picker.entry.js.map +1 -1
  430. package/dist/esm/bq-dialog.entry.js +29 -20
  431. package/dist/esm/bq-dialog.entry.js.map +1 -1
  432. package/dist/esm/bq-divider.entry.js +29 -20
  433. package/dist/esm/bq-divider.entry.js.map +1 -1
  434. package/dist/esm/bq-drawer.entry.js +33 -24
  435. package/dist/esm/bq-drawer.entry.js.map +1 -1
  436. package/dist/esm/bq-dropdown_2.entry.js +35 -16
  437. package/dist/esm/bq-dropdown_2.entry.js.map +1 -0
  438. package/dist/esm/bq-empty-state.entry.js +34 -29
  439. package/dist/esm/bq-empty-state.entry.js.map +1 -1
  440. package/dist/esm/bq-input.entry.js +31 -26
  441. package/dist/esm/bq-input.entry.js.map +1 -1
  442. package/dist/esm/bq-notification.entry.js +29 -18
  443. package/dist/esm/bq-notification.entry.js.map +1 -1
  444. package/dist/esm/bq-option-group.entry.js +7 -4
  445. package/dist/esm/bq-option-group.entry.js.map +1 -1
  446. package/dist/esm/bq-option-list_2.entry.js +25 -18
  447. package/dist/esm/bq-option-list_2.entry.js.map +1 -0
  448. package/dist/esm/bq-option.entry.js +20 -17
  449. package/dist/esm/bq-option.entry.js.map +1 -1
  450. package/dist/esm/bq-page-title.entry.js +16 -13
  451. package/dist/esm/bq-page-title.entry.js.map +1 -1
  452. package/dist/esm/bq-progress.entry.js +30 -19
  453. package/dist/esm/bq-progress.entry.js.map +1 -1
  454. package/dist/esm/bq-radio-group.entry.js +33 -12
  455. package/dist/esm/bq-radio-group.entry.js.map +1 -1
  456. package/dist/esm/bq-radio.entry.js +14 -11
  457. package/dist/esm/bq-radio.entry.js.map +1 -1
  458. package/dist/esm/bq-select.entry.js +53 -31
  459. package/dist/esm/bq-select.entry.js.map +1 -1
  460. package/dist/esm/bq-side-menu-item.entry.js +11 -8
  461. package/dist/esm/bq-side-menu-item.entry.js.map +1 -1
  462. package/dist/esm/bq-side-menu.entry.js +13 -8
  463. package/dist/esm/bq-side-menu.entry.js.map +1 -1
  464. package/dist/esm/bq-slider.entry.js +38 -29
  465. package/dist/esm/bq-slider.entry.js.map +1 -1
  466. package/dist/esm/bq-spinner.entry.js +25 -16
  467. package/dist/esm/bq-spinner.entry.js.map +1 -1
  468. package/dist/esm/bq-status.entry.js +10 -5
  469. package/dist/esm/bq-status.entry.js.map +1 -1
  470. package/dist/esm/bq-step-item.entry.js +37 -19
  471. package/dist/esm/bq-step-item.entry.js.map +1 -1
  472. package/dist/esm/bq-steps.entry.js +34 -10
  473. package/dist/esm/bq-steps.entry.js.map +1 -1
  474. package/dist/esm/bq-steps.types-BRMw_HGf.js +12 -0
  475. package/dist/esm/bq-steps.types-BRMw_HGf.js.map +1 -0
  476. package/dist/esm/bq-switch.entry.js +18 -13
  477. package/dist/esm/bq-switch.entry.js.map +1 -1
  478. package/dist/esm/bq-tab-group.entry.js +29 -16
  479. package/dist/esm/bq-tab-group.entry.js.map +1 -1
  480. package/dist/esm/bq-tab.entry.js +19 -10
  481. package/dist/esm/bq-tab.entry.js.map +1 -1
  482. package/dist/esm/bq-textarea.entry.js +28 -21
  483. package/dist/esm/bq-textarea.entry.js.map +1 -1
  484. package/dist/esm/bq-toast.entry.js +19 -8
  485. package/dist/esm/bq-toast.entry.js.map +1 -1
  486. package/dist/esm/bq-tooltip.entry.js +28 -15
  487. package/dist/esm/bq-tooltip.entry.js.map +1 -1
  488. package/dist/esm/{date-igOoibr-.js → form-DLjuE3KX.js} +132 -3
  489. package/dist/esm/form-DLjuE3KX.js.map +1 -0
  490. package/dist/esm/{index-BOf9EC3C.js → index-BIw6Ac7W.js} +295 -365
  491. package/dist/esm/index-BIw6Ac7W.js.map +1 -0
  492. package/dist/esm/index-C33fRBEf.js +151 -0
  493. package/dist/esm/index-C33fRBEf.js.map +1 -0
  494. package/dist/esm/index.js +4 -2
  495. package/dist/esm/{isHTMLElement-BxgDLPzX.js → isHTMLElement-D1A0LpG_.js} +3 -3
  496. package/dist/{cjs/isHTMLElement-DMA6t4n4.js.map → esm/isHTMLElement-D1A0LpG_.js.map} +1 -1
  497. package/dist/esm/loader.js +5 -3
  498. package/dist/hydrate/index.d.ts +12 -0
  499. package/dist/hydrate/index.js +6360 -2418
  500. package/dist/hydrate/index.mjs +6359 -2419
  501. package/dist/stencil.config.js +1 -0
  502. package/dist/stencil.config.js.map +1 -1
  503. package/dist/types/components/accordion/bq-accordion.d.ts +1 -1
  504. package/dist/types/components/accordion-group/bq-accordion-group.d.ts +1 -1
  505. package/dist/types/components/alert/bq-alert.d.ts +2 -2
  506. package/dist/types/components/avatar/bq-avatar.d.ts +1 -1
  507. package/dist/types/components/badge/bq-badge.d.ts +1 -1
  508. package/dist/types/components/breadcrumb/bq-breadcrumb.d.ts +1 -1
  509. package/dist/types/components/breadcrumb-item/bq-breadcrumb-item.d.ts +1 -1
  510. package/dist/types/components/button/bq-button.d.ts +18 -15
  511. package/dist/types/components/card/bq-card.d.ts +1 -1
  512. package/dist/types/components/checkbox/bq-checkbox.d.ts +1 -1
  513. package/dist/types/components/date-picker/bq-date-picker.d.ts +63 -18
  514. package/dist/types/components/date-picker/bq-date-picker.types.d.ts +31 -5
  515. package/dist/types/components/date-picker/helper/constants.d.ts +18 -0
  516. package/dist/types/components/date-picker/libs/callyLibrary.d.ts +15 -0
  517. package/dist/types/components/dialog/bq-dialog.d.ts +1 -1
  518. package/dist/types/components/divider/bq-divider.d.ts +1 -1
  519. package/dist/types/components/drawer/bq-drawer.d.ts +1 -1
  520. package/dist/types/components/dropdown/bq-dropdown.d.ts +1 -1
  521. package/dist/types/components/empty-state/bq-empty-state.d.ts +1 -1
  522. package/dist/types/components/icon/bq-icon.d.ts +1 -1
  523. package/dist/types/components/input/bq-input.d.ts +1 -1
  524. package/dist/types/components/notification/bq-notification.d.ts +1 -1
  525. package/dist/types/components/option/bq-option.d.ts +1 -1
  526. package/dist/types/components/option-group/bq-option-group.d.ts +1 -1
  527. package/dist/types/components/option-list/bq-option-list.d.ts +1 -1
  528. package/dist/types/components/page-title/bq-page-title.d.ts +1 -1
  529. package/dist/types/components/panel/bq-panel.d.ts +1 -1
  530. package/dist/types/components/progress/bq-progress.d.ts +1 -1
  531. package/dist/types/components/radio/bq-radio.d.ts +1 -1
  532. package/dist/types/components/radio-group/bq-radio-group.d.ts +1 -1
  533. package/dist/types/components/select/bq-select.d.ts +2 -1
  534. package/dist/types/components/side-menu/bq-side-menu.d.ts +1 -1
  535. package/dist/types/components/side-menu-item/bq-side-menu-item.d.ts +1 -1
  536. package/dist/types/components/slider/bq-slider.d.ts +1 -1
  537. package/dist/types/components/spinner/bq-spinner.d.ts +1 -1
  538. package/dist/types/components/status/bq-status.d.ts +1 -1
  539. package/dist/types/components/step-item/bq-step-item.d.ts +12 -2
  540. package/dist/types/components/steps/bq-steps.d.ts +6 -2
  541. package/dist/types/components/steps/bq-steps.types.d.ts +2 -0
  542. package/dist/types/components/switch/bq-switch.d.ts +1 -1
  543. package/dist/types/components/tab/bq-tab.d.ts +1 -1
  544. package/dist/types/components/tab-group/bq-tab-group.d.ts +1 -1
  545. package/dist/types/components/tag/bq-tag.d.ts +1 -1
  546. package/dist/types/components/textarea/bq-textarea.d.ts +1 -1
  547. package/dist/types/components/toast/bq-toast.d.ts +1 -1
  548. package/dist/types/components/tooltip/bq-tooltip.d.ts +1 -1
  549. package/dist/types/components.d.ts +114 -27
  550. package/dist/types/shared/utils/date/dateFormatting.d.ts +29 -0
  551. package/dist/types/shared/utils/{date.d.ts → date/dateParsing.d.ts} +16 -2
  552. package/dist/types/shared/utils/date/index.d.ts +2 -0
  553. package/dist/types/shared/utils/form.d.ts +28 -0
  554. package/dist/types/shared/utils/index.d.ts +1 -0
  555. package/dist/types/stencil-public-runtime.d.ts +87 -4
  556. package/package.json +3 -2
  557. package/dist/beeq/bq-accordion-group.entry.esm.js.map +0 -1
  558. package/dist/beeq/bq-accordion.entry.esm.js.map +0 -1
  559. package/dist/beeq/bq-alert.entry.esm.js.map +0 -1
  560. package/dist/beeq/bq-avatar.entry.esm.js.map +0 -1
  561. package/dist/beeq/bq-badge.entry.esm.js.map +0 -1
  562. package/dist/beeq/bq-breadcrumb-item.entry.esm.js.map +0 -1
  563. package/dist/beeq/bq-breadcrumb.entry.esm.js.map +0 -1
  564. package/dist/beeq/bq-button.bq-icon.entry.esm.js.map +0 -1
  565. package/dist/beeq/bq-card.entry.esm.js.map +0 -1
  566. package/dist/beeq/bq-checkbox.entry.esm.js.map +0 -1
  567. package/dist/beeq/bq-date-picker.entry.esm.js.map +0 -1
  568. package/dist/beeq/bq-dialog.entry.esm.js.map +0 -1
  569. package/dist/beeq/bq-divider.entry.esm.js.map +0 -1
  570. package/dist/beeq/bq-drawer.entry.esm.js.map +0 -1
  571. package/dist/beeq/bq-dropdown.bq-panel.entry.esm.js.map +0 -1
  572. package/dist/beeq/bq-empty-state.entry.esm.js.map +0 -1
  573. package/dist/beeq/bq-input.entry.esm.js.map +0 -1
  574. package/dist/beeq/bq-notification.entry.esm.js.map +0 -1
  575. package/dist/beeq/bq-option-group.entry.esm.js.map +0 -1
  576. package/dist/beeq/bq-option-list.bq-tag.entry.esm.js.map +0 -1
  577. package/dist/beeq/bq-option.entry.esm.js.map +0 -1
  578. package/dist/beeq/bq-page-title.entry.esm.js.map +0 -1
  579. package/dist/beeq/bq-progress.entry.esm.js.map +0 -1
  580. package/dist/beeq/bq-radio-group.entry.esm.js.map +0 -1
  581. package/dist/beeq/bq-radio.entry.esm.js.map +0 -1
  582. package/dist/beeq/bq-select.entry.esm.js.map +0 -1
  583. package/dist/beeq/bq-side-menu-item.entry.esm.js.map +0 -1
  584. package/dist/beeq/bq-side-menu.entry.esm.js.map +0 -1
  585. package/dist/beeq/bq-slider.entry.esm.js.map +0 -1
  586. package/dist/beeq/bq-spinner.entry.esm.js.map +0 -1
  587. package/dist/beeq/bq-status.entry.esm.js.map +0 -1
  588. package/dist/beeq/bq-step-item.entry.esm.js.map +0 -1
  589. package/dist/beeq/bq-steps.entry.esm.js.map +0 -1
  590. package/dist/beeq/bq-tab-group.entry.esm.js.map +0 -1
  591. package/dist/beeq/bq-tab.entry.esm.js.map +0 -1
  592. package/dist/beeq/bq-textarea.entry.esm.js.map +0 -1
  593. package/dist/beeq/bq-toast.entry.esm.js.map +0 -1
  594. package/dist/beeq/bq-tooltip.entry.esm.js.map +0 -1
  595. package/dist/beeq/loader.esm.js.map +0 -1
  596. package/dist/beeq/p-0bf5e367.entry.js.map +0 -1
  597. package/dist/beeq/p-16defa87.entry.js +0 -6
  598. package/dist/beeq/p-16defa87.entry.js.map +0 -1
  599. package/dist/beeq/p-17de1ba4.entry.js +0 -6
  600. package/dist/beeq/p-17de1ba4.entry.js.map +0 -1
  601. package/dist/beeq/p-1df8fe61.entry.js +0 -6
  602. package/dist/beeq/p-1df8fe61.entry.js.map +0 -1
  603. package/dist/beeq/p-24749f67.entry.js +0 -6
  604. package/dist/beeq/p-24749f67.entry.js.map +0 -1
  605. package/dist/beeq/p-38add122.entry.js +0 -6
  606. package/dist/beeq/p-38add122.entry.js.map +0 -1
  607. package/dist/beeq/p-454fa535.entry.js +0 -6
  608. package/dist/beeq/p-454fa535.entry.js.map +0 -1
  609. package/dist/beeq/p-4647a0fb.entry.js.map +0 -1
  610. package/dist/beeq/p-4725a142.entry.js +0 -6
  611. package/dist/beeq/p-4725a142.entry.js.map +0 -1
  612. package/dist/beeq/p-51351eed.entry.js +0 -6
  613. package/dist/beeq/p-51351eed.entry.js.map +0 -1
  614. package/dist/beeq/p-5b0a56e7.entry.js +0 -6
  615. package/dist/beeq/p-5b0a56e7.entry.js.map +0 -1
  616. package/dist/beeq/p-5c23324d.entry.js +0 -6
  617. package/dist/beeq/p-5c23324d.entry.js.map +0 -1
  618. package/dist/beeq/p-5df7df5d.entry.js +0 -6
  619. package/dist/beeq/p-5df7df5d.entry.js.map +0 -1
  620. package/dist/beeq/p-5e8c8e90.entry.js +0 -6
  621. package/dist/beeq/p-5e8c8e90.entry.js.map +0 -1
  622. package/dist/beeq/p-662578a2.entry.js.map +0 -1
  623. package/dist/beeq/p-6ae2ca4b.entry.js +0 -6
  624. package/dist/beeq/p-6ae2ca4b.entry.js.map +0 -1
  625. package/dist/beeq/p-7ca73c06.entry.js +0 -6
  626. package/dist/beeq/p-7ca73c06.entry.js.map +0 -1
  627. package/dist/beeq/p-84e62655.entry.js.map +0 -1
  628. package/dist/beeq/p-93d6f4f0.entry.js +0 -6
  629. package/dist/beeq/p-93d6f4f0.entry.js.map +0 -1
  630. package/dist/beeq/p-9585221e.entry.js +0 -6
  631. package/dist/beeq/p-9585221e.entry.js.map +0 -1
  632. package/dist/beeq/p-9c9a83f8.entry.js +0 -6
  633. package/dist/beeq/p-9c9a83f8.entry.js.map +0 -1
  634. package/dist/beeq/p-9e9baa82.entry.js +0 -6
  635. package/dist/beeq/p-9e9baa82.entry.js.map +0 -1
  636. package/dist/beeq/p-BOf9EC3C.js +0 -7
  637. package/dist/beeq/p-BOf9EC3C.js.map +0 -1
  638. package/dist/beeq/p-BxgDLPzX.js +0 -6
  639. package/dist/beeq/p-DEUOprS4.js +0 -6
  640. package/dist/beeq/p-DEUOprS4.js.map +0 -1
  641. package/dist/beeq/p-b1d2e472.entry.js.map +0 -1
  642. package/dist/beeq/p-b7efb629.entry.js +0 -6
  643. package/dist/beeq/p-b7efb629.entry.js.map +0 -1
  644. package/dist/beeq/p-b88b2573.entry.js.map +0 -1
  645. package/dist/beeq/p-bfca08f5.entry.js +0 -6
  646. package/dist/beeq/p-bfca08f5.entry.js.map +0 -1
  647. package/dist/beeq/p-c63b89d2.entry.js +0 -6
  648. package/dist/beeq/p-c63b89d2.entry.js.map +0 -1
  649. package/dist/beeq/p-ca93325b.entry.js +0 -6
  650. package/dist/beeq/p-ca93325b.entry.js.map +0 -1
  651. package/dist/beeq/p-cb0639d5.entry.js.map +0 -1
  652. package/dist/beeq/p-cd53041f.entry.js.map +0 -1
  653. package/dist/beeq/p-d31e8b6a.entry.js +0 -6
  654. package/dist/beeq/p-d31e8b6a.entry.js.map +0 -1
  655. package/dist/beeq/p-d8118f0b.entry.js +0 -6
  656. package/dist/beeq/p-d8118f0b.entry.js.map +0 -1
  657. package/dist/beeq/p-d9c5ab1d.entry.js +0 -6
  658. package/dist/beeq/p-d9c5ab1d.entry.js.map +0 -1
  659. package/dist/beeq/p-dc5aa386.entry.js.map +0 -1
  660. package/dist/beeq/p-dcda1181.entry.js +0 -6
  661. package/dist/beeq/p-dcda1181.entry.js.map +0 -1
  662. package/dist/beeq/p-eaa8c123.entry.js +0 -6
  663. package/dist/beeq/p-eaa8c123.entry.js.map +0 -1
  664. package/dist/beeq/p-eb47c1ae.entry.js.map +0 -1
  665. package/dist/beeq/p-eb6eac82.entry.js +0 -6
  666. package/dist/beeq/p-eb6eac82.entry.js.map +0 -1
  667. package/dist/beeq/p-f691f00c.entry.js +0 -6
  668. package/dist/beeq/p-f691f00c.entry.js.map +0 -1
  669. package/dist/beeq/p-igOoibr-.js +0 -6
  670. package/dist/beeq/p-igOoibr-.js.map +0 -1
  671. package/dist/cjs/bq-accordion-group.entry.cjs.js.map +0 -1
  672. package/dist/cjs/bq-accordion.entry.cjs.js.map +0 -1
  673. package/dist/cjs/bq-alert.entry.cjs.js.map +0 -1
  674. package/dist/cjs/bq-avatar.entry.cjs.js.map +0 -1
  675. package/dist/cjs/bq-badge.entry.cjs.js.map +0 -1
  676. package/dist/cjs/bq-breadcrumb-item.entry.cjs.js.map +0 -1
  677. package/dist/cjs/bq-breadcrumb.entry.cjs.js.map +0 -1
  678. package/dist/cjs/bq-button.bq-icon.entry.cjs.js.map +0 -1
  679. package/dist/cjs/bq-card.entry.cjs.js.map +0 -1
  680. package/dist/cjs/bq-checkbox.entry.cjs.js.map +0 -1
  681. package/dist/cjs/bq-date-picker.entry.cjs.js.map +0 -1
  682. package/dist/cjs/bq-dialog.entry.cjs.js.map +0 -1
  683. package/dist/cjs/bq-drawer.entry.cjs.js.map +0 -1
  684. package/dist/cjs/bq-dropdown.bq-panel.entry.cjs.js.map +0 -1
  685. package/dist/cjs/bq-empty-state.entry.cjs.js.map +0 -1
  686. package/dist/cjs/bq-input.entry.cjs.js.map +0 -1
  687. package/dist/cjs/bq-notification.entry.cjs.js.map +0 -1
  688. package/dist/cjs/bq-option-group.entry.cjs.js.map +0 -1
  689. package/dist/cjs/bq-option-list.bq-tag.entry.cjs.js.map +0 -1
  690. package/dist/cjs/bq-option.entry.cjs.js.map +0 -1
  691. package/dist/cjs/bq-page-title.entry.cjs.js.map +0 -1
  692. package/dist/cjs/bq-progress.entry.cjs.js.map +0 -1
  693. package/dist/cjs/bq-radio-group.entry.cjs.js.map +0 -1
  694. package/dist/cjs/bq-radio.entry.cjs.js.map +0 -1
  695. package/dist/cjs/bq-select.entry.cjs.js.map +0 -1
  696. package/dist/cjs/bq-side-menu-item.entry.cjs.js.map +0 -1
  697. package/dist/cjs/bq-side-menu.entry.cjs.js.map +0 -1
  698. package/dist/cjs/bq-slider.entry.cjs.js.map +0 -1
  699. package/dist/cjs/bq-spinner.entry.cjs.js.map +0 -1
  700. package/dist/cjs/bq-status.entry.cjs.js.map +0 -1
  701. package/dist/cjs/bq-step-item.entry.cjs.js.map +0 -1
  702. package/dist/cjs/bq-steps.entry.cjs.js.map +0 -1
  703. package/dist/cjs/bq-steps.types-D4B3f19X.js.map +0 -1
  704. package/dist/cjs/bq-switch.entry.cjs.js.map +0 -1
  705. package/dist/cjs/bq-tab-group.entry.cjs.js.map +0 -1
  706. package/dist/cjs/bq-textarea.entry.cjs.js.map +0 -1
  707. package/dist/cjs/bq-toast.entry.cjs.js.map +0 -1
  708. package/dist/cjs/bq-tooltip.entry.cjs.js.map +0 -1
  709. package/dist/cjs/date-C-h2CBps.js.map +0 -1
  710. package/dist/cjs/index-g8MkV15i.js.map +0 -1
  711. package/dist/collection/components/date-picker/helper/callyLibrary.js.map +0 -1
  712. package/dist/collection/shared/utils/date.js.map +0 -1
  713. package/dist/components/p-16lKXCDk.js.map +0 -1
  714. package/dist/components/p-A6e1tN-B.js.map +0 -1
  715. package/dist/components/p-B5XEhmuc.js.map +0 -1
  716. package/dist/components/p-BxgDLPzX.js +0 -6
  717. package/dist/components/p-CIV0haMJ.js +0 -6
  718. package/dist/components/p-CIV0haMJ.js.map +0 -1
  719. package/dist/components/p-CXUO6Zub.js.map +0 -1
  720. package/dist/components/p-D14_9VoZ.js +0 -6
  721. package/dist/components/p-D14_9VoZ.js.map +0 -1
  722. package/dist/components/p-DEUOprS4.js +0 -6
  723. package/dist/components/p-DEUOprS4.js.map +0 -1
  724. package/dist/components/p-DGysEMss.js.map +0 -1
  725. package/dist/components/p-DHdYy1q5.js.map +0 -1
  726. package/dist/components/p-DokL_HVP.js +0 -6
  727. package/dist/components/p-DokL_HVP.js.map +0 -1
  728. package/dist/components/p-eRUe5rRq.js +0 -6
  729. package/dist/components/p-eRUe5rRq.js.map +0 -1
  730. package/dist/esm/bq-button.bq-icon.entry.js.map +0 -1
  731. package/dist/esm/bq-dropdown.bq-panel.entry.js.map +0 -1
  732. package/dist/esm/bq-option-list.bq-tag.entry.js.map +0 -1
  733. package/dist/esm/bq-steps.types-DEUOprS4.js +0 -11
  734. package/dist/esm/bq-steps.types-DEUOprS4.js.map +0 -1
  735. package/dist/esm/date-igOoibr-.js.map +0 -1
  736. package/dist/esm/index-BOf9EC3C.js.map +0 -1
  737. package/dist/types/components/date-picker/helper/callyLibrary.d.ts +0 -11
@@ -1 +1 @@
1
- {"version":3,"file":"bq-panel.js","sourceRoot":"","sources":["../../../../../../packages/beeq/src/components/panel/bq-panel.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAGnE,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEhF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AAMH,MAAM,OAAO,OAAO;IAClB,iBAAiB;IACjB,uBAAuB;IAEf,KAAK,CAAc;IACnB,UAAU,CAAa;IACvB,OAAO,CAAmB;IAElC,iCAAiC;IACjC,sCAAsC;IAE3B,EAAE,CAAsB;IAEnC,oBAAoB;IACpB,wCAAwC;IACxC,0CAA0C;IAE1C,sBAAsB;IACtB,2BAA2B;IAE3B,uEAAuE;IAC9C,iBAAiB,GAAa,KAAK,CAAC;IAE7D,4FAA4F;IACnE,QAAQ,GAAY,CAAC,CAAC;IAE/C,4BAA4B;IACH,SAAS,GAAe,cAAc,CAAC;IAEhE,0CAA0C;IACF,IAAI,GAAa,KAAK,CAAC;IAE/D,0EAA0E;IACjD,SAAS,GAAa,KAAK,CAAC;IAErD,0EAA0E;IACjD,QAAQ,GAAY,CAAC,CAAC;IAE/C,iDAAiD;IACxB,QAAQ,GAA0B,OAAO,CAAC;IAEnE,wBAAwB;IACxB,0BAA0B;IAG1B,gBAAgB;QACd,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YACf,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAOD,YAAY;QACV,IAAI,CAAC,QAAQ,EAAE;YAAE,OAAO;QAExB,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IAC7C,CAAC;IAED,iBAAiB;IACjB,+CAA+C;IAC/C,iDAAiD;IAEjD,6BAA6B;IAC7B,sCAAsC;IACtC,wCAAwC;IAExC,gBAAgB;QACd,IAAI,CAAC,QAAQ,EAAE;YAAE,OAAO;QAExB,4FAA4F;QAC5F,MAAM,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC;QAEjF,IAAI,CAAC,aAAa;YAAE,OAAO;QAE3B,IAAI,CAAC,OAAO,GAAG;YACb,qBAAqB,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE;YAClE,cAAc,EAAE,aAAa;SAC9B,CAAC;QAEF,IAAI,CAAC,UAAU,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,KAAK,EAAE,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QAChF,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,QAAQ,EAAE;YAAE,OAAO;QAExB,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,CAAC;QAE3B,0FAA0F;QAC1F,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzC,gBAAgB,EAAE,CAAC;QACrB,CAAC;IACH,CAAC;IAED,YAAY;IACZ,iBAAiB;IAEjB,qBAAqB;IACrB,iDAAiD;IACjD,wBAAwB;IACxB,gCAAgC;IAChC,gDAAgD;IAChD,kDAAkD;IAElD,gBAAgB;IAChB,2BAA2B;IAC3B,wDAAwD;IACxD,0DAA0D;IAElD,SAAS;QACf,IAAI,CAAC,QAAQ,EAAE;YAAE,OAAO;QAExB,IAAI,CAAC,UAAU,EAAE,MAAM,EAAE,CAAC;QAE1B,kEAAkE;QAClE,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC5B,cAAc,EAAE,CAAC;QACnB,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,SAAS;QACrB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAElB,oEAAoE;QACpE,IAAI,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC1C,gBAAgB,EAAE,CAAC;QACrB,CAAC;IACH,CAAC;IAED,IAAY,OAAO;QACjB,OAAO;YACL,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC;IACJ,CAAC;IAED,oBAAoB;IACpB,oCAAoC;IACpC,sCAAsC;IAEtC,MAAM;QACJ,OAAO,CACL,2EACe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EAC1C,KAAK,EAAC,UAAU,EAChB,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,EAClB,IAAI,EAAC,OAAO,EACZ,GAAG,EAAE,CAAC,EAAE,EAAE,EAAE;gBACV,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;YAClB,CAAC;YAED,8DAAQ,CACJ,CACP,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import type { ReferenceElement } from '@floating-ui/dom';\nimport { Component, Element, h, Prop, Watch } from '@stencil/core';\n\nimport type { Placement } from '../../services/interfaces';\nimport { FloatingUI } from '../../services/libraries';\nimport { isClient, lockBodyScroll, unlockBodyScroll } from '../../shared/utils';\n\n/**\n * The Panel component is a versatile and essential element used to wrap and display content in a floating panel.\n *\n * @example How to use it\n * ```html\n * <bq-panel open>\n * <div>Panel content</div>\n * </bq-panel>\n * ```\n *\n * @status stable\n *\n * @attr {number} distance - Represents the distance (gutter or margin) between the panel and the trigger element.\n * @attr {\"top\" | \"bottom\" | \"left\" | \"right\" | \"top-start\" | \"top-end\" | \"bottom-start\" | \"bottom-end\" | \"left-start\" | \"left-end\" | \"right-start\" | \"right-end\"} placement - Position of the panel.\n * @attr {boolean} open - If true, the panel will be visible.\n * @attr {boolean} same-width - Whether the panel should have the same width as the trigger element.\n * @attr {number} skidding - Represents the skidding between the panel and the trigger element.\n * @attr {\"fixed\" | \"absolute\"} strategy - Defines the strategy to position the panel.\n *\n * @slot - The content of the panel.\n *\n * @part panel - The `<div>` element used to display and style the panel\n *\n * @prop --bq-panel--background - Panel background color\n * @prop --bq-panel--border-color - Panel border color\n * @prop --bq-panel--border-radius - Panel border radius\n * @prop --bq-panel--border-style - Panel border style\n * @prop --bq-panel--border-width - Panel border width\n * @prop --bq-panel--box-shadow - Panel box shadow\n * @prop --bq-panel--padding - Panel padding\n * @prop --bq-panel--height - Panel height\n * @prop --bq-panel--width - Panel width\n * @prop --bq-panel-z-index - Panel z-index applied when opened\n */\n@Component({\n tag: 'bq-panel',\n styleUrl: './scss/bq-panel.scss',\n shadow: true,\n})\nexport class BqPanel {\n // Own Properties\n // ====================\n\n private panel: HTMLElement;\n private floatingUI: FloatingUI;\n private trigger: ReferenceElement;\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqPanelElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n // Public Property API\n // ========================\n\n /** If true, the panel will not lock the page body scroll when open. */\n @Prop({ reflect: true }) disableScrollLock?: boolean = false;\n\n /** Represents the distance (gutter or margin) between the panel and the trigger element. */\n @Prop({ reflect: true }) distance?: number = 4;\n\n /** Position of the panel */\n @Prop({ reflect: true }) placement?: Placement = 'bottom-start';\n\n /** If true, the panel will be visible. */\n @Prop({ reflect: true, mutable: true }) open?: boolean = false;\n\n /** Whether the panel should have the same width as the trigger element */\n @Prop({ reflect: true }) sameWidth?: boolean = false;\n\n /** Represents the skidding between the panel and the trigger element. */\n @Prop({ reflect: true }) skidding?: number = 0;\n\n /** Defines the strategy to position the panel */\n @Prop({ reflect: true }) strategy?: 'fixed' | 'absolute' = 'fixed';\n\n // Prop lifecycle events\n // =======================\n\n @Watch('open')\n handleOpenChange() {\n if (!this.open) {\n this.hidePanel();\n return;\n }\n\n this.showPanel();\n }\n\n @Watch('distance')\n @Watch('placement')\n @Watch('sameWidth')\n @Watch('skidding')\n @Watch('strategy')\n onPropChange() {\n if (!isClient()) return;\n\n this.floatingUI?.init({ ...this.options });\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n componentDidLoad() {\n if (!isClient()) return;\n\n // We need to find the trigger element from the parent to position the panel relative to it.\n const parentTrigger = this.el.parentElement.querySelector('div[part=\"trigger\"]');\n\n if (!parentTrigger) return;\n\n this.trigger = {\n getBoundingClientRect: () => parentTrigger.getBoundingClientRect(),\n contextElement: parentTrigger,\n };\n\n this.floatingUI = new FloatingUI(this.trigger, this.panel, { ...this.options });\n this.handleOpenChange();\n }\n\n disconnectedCallback() {\n if (!isClient()) return;\n\n this.floatingUI?.destroy();\n\n // Ensure scroll lock is removed if the component is disconnected while the panel is open.\n if (this.open && !this.disableScrollLock) {\n unlockBodyScroll();\n }\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 // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n private showPanel() {\n if (!isClient()) return;\n\n this.floatingUI?.update();\n\n // Lock the body scroll if the disableScrollLock prop is not true.\n if (!this.disableScrollLock) {\n lockBodyScroll();\n }\n }\n\n private async hidePanel() {\n this.open = false;\n\n // Unlock the body scroll if the disableScrollLock prop is not true.\n if (isClient() && !this.disableScrollLock) {\n unlockBodyScroll();\n }\n }\n\n private get options() {\n return {\n distance: this.distance,\n placement: this.placement,\n sameWidth: this.sameWidth,\n skidding: this.skidding,\n strategy: this.strategy,\n };\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <div\n aria-hidden={!this.open ? 'true' : 'false'}\n class=\"bq-panel\"\n hidden={!this.open}\n part=\"panel\"\n ref={(el) => {\n this.panel = el;\n }}\n >\n <slot />\n </div>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"bq-panel.js","sourceRoot":"","sources":["../../../../../../packages/beeq/src/components/panel/bq-panel.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { ReferenceElement } from '@floating-ui/dom';\nimport { Component, Element, Prop, Watch } from '@stencil/core';\n\nimport type { Placement } from '../../services/interfaces';\nimport { FloatingUI } from '../../services/libraries';\nimport { isClient, lockBodyScroll, unlockBodyScroll } from '../../shared/utils';\n\n/**\n * The Panel component is a versatile and essential element used to wrap and display content in a floating panel.\n *\n * @example How to use it\n * ```html\n * <bq-panel open>\n * <div>Panel content</div>\n * </bq-panel>\n * ```\n *\n * @status stable\n *\n * @attr {number} distance - Represents the distance (gutter or margin) between the panel and the trigger element.\n * @attr {\"top\" | \"bottom\" | \"left\" | \"right\" | \"top-start\" | \"top-end\" | \"bottom-start\" | \"bottom-end\" | \"left-start\" | \"left-end\" | \"right-start\" | \"right-end\"} placement - Position of the panel.\n * @attr {boolean} open - If true, the panel will be visible.\n * @attr {boolean} same-width - Whether the panel should have the same width as the trigger element.\n * @attr {number} skidding - Represents the skidding between the panel and the trigger element.\n * @attr {\"fixed\" | \"absolute\"} strategy - Defines the strategy to position the panel.\n *\n * @slot - The content of the panel.\n *\n * @part panel - The `<div>` element used to display and style the panel\n *\n * @prop --bq-panel--background - Panel background color\n * @prop --bq-panel--border-color - Panel border color\n * @prop --bq-panel--border-radius - Panel border radius\n * @prop --bq-panel--border-style - Panel border style\n * @prop --bq-panel--border-width - Panel border width\n * @prop --bq-panel--box-shadow - Panel box shadow\n * @prop --bq-panel--padding - Panel padding\n * @prop --bq-panel--height - Panel height\n * @prop --bq-panel--width - Panel width\n * @prop --bq-panel-z-index - Panel z-index applied when opened\n */\n@Component({\n tag: 'bq-panel',\n styleUrl: './scss/bq-panel.scss',\n shadow: true,\n})\nexport class BqPanel {\n // Own Properties\n // ====================\n\n private panel: HTMLElement;\n private floatingUI: FloatingUI;\n private trigger: ReferenceElement;\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqPanelElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n // Public Property API\n // ========================\n\n /** If true, the panel will not lock the page body scroll when open. */\n @Prop({ reflect: true }) disableScrollLock?: boolean = false;\n\n /** Represents the distance (gutter or margin) between the panel and the trigger element. */\n @Prop({ reflect: true }) distance?: number = 4;\n\n /** Position of the panel */\n @Prop({ reflect: true }) placement?: Placement = 'bottom-start';\n\n /** If true, the panel will be visible. */\n @Prop({ reflect: true, mutable: true }) open?: boolean = false;\n\n /** Whether the panel should have the same width as the trigger element */\n @Prop({ reflect: true }) sameWidth?: boolean = false;\n\n /** Represents the skidding between the panel and the trigger element. */\n @Prop({ reflect: true }) skidding?: number = 0;\n\n /** Defines the strategy to position the panel */\n @Prop({ reflect: true }) strategy?: 'fixed' | 'absolute' = 'fixed';\n\n // Prop lifecycle events\n // =======================\n\n @Watch('open')\n handleOpenChange() {\n if (!this.open) {\n this.hidePanel();\n return;\n }\n\n this.showPanel();\n }\n\n @Watch('distance')\n @Watch('placement')\n @Watch('sameWidth')\n @Watch('skidding')\n @Watch('strategy')\n onPropChange() {\n if (!isClient()) return;\n\n this.floatingUI?.init({ ...this.options });\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n componentDidLoad() {\n if (!isClient()) return;\n\n // We need to find the trigger element from the parent to position the panel relative to it.\n const parentTrigger = this.el.parentElement.querySelector('div[part=\"trigger\"]');\n\n if (!parentTrigger) return;\n\n this.trigger = {\n getBoundingClientRect: () => parentTrigger.getBoundingClientRect(),\n contextElement: parentTrigger,\n };\n\n this.floatingUI = new FloatingUI(this.trigger, this.panel, { ...this.options });\n this.handleOpenChange();\n }\n\n disconnectedCallback() {\n if (!isClient()) return;\n\n this.floatingUI?.destroy();\n\n // Ensure scroll lock is removed if the component is disconnected while the panel is open.\n if (this.open && !this.disableScrollLock) {\n unlockBodyScroll();\n }\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 // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n private showPanel() {\n if (!isClient()) return;\n\n this.floatingUI?.update();\n\n // Lock the body scroll if the disableScrollLock prop is not true.\n if (!this.disableScrollLock) {\n lockBodyScroll();\n }\n }\n\n private async hidePanel() {\n this.open = false;\n\n // Unlock the body scroll if the disableScrollLock prop is not true.\n if (isClient() && !this.disableScrollLock) {\n unlockBodyScroll();\n }\n }\n\n private get options() {\n return {\n distance: this.distance,\n placement: this.placement,\n sameWidth: this.sameWidth,\n skidding: this.skidding,\n strategy: this.strategy,\n };\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <div\n aria-hidden={!this.open ? 'true' : 'false'}\n class=\"bq-panel\"\n hidden={!this.open}\n part=\"panel\"\n ref={(el) => {\n this.panel = el;\n }}\n >\n <slot />\n </div>\n );\n }\n}\n"]}
@@ -2,7 +2,8 @@
2
2
  * Built by Endavans
3
3
  * © https://beeq.design - Apache 2 License.
4
4
  */
5
- import { Host, h } from "@stencil/core";
5
+ import { jsx as _jsx, jsxs as _jsxs } from "@stencil/core/jsx-runtime";
6
+ import { Host } from "@stencil/core";
6
7
  import { validatePropValue } from "../../shared/utils";
7
8
  import { PROGRESS_BORDER_SHAPE, PROGRESS_THICKNESS, PROGRESS_TYPE } from "./bq-progress.types";
8
9
  /**
@@ -112,18 +113,18 @@ export class BqProgress {
112
113
  ...(this.thickness === 'large' && { '--bq-progress-bar--height': 'var(--bq-spacing-xs)' }),
113
114
  ...(this.type === 'error' && { '--bq-progress-bar--indicatorColor': 'var(--bq-ui--danger)' }),
114
115
  };
115
- return (h(Host, { key: 'db2ef23caba8731b42a7c74fd7d19aa366a1ba30', style: style }, h("div", { key: 'b657b368fa271571de30a925c2c7e8ab77380524', class: "flex items-center", part: "wrapper" }, h("div", { key: '97cafbe2deceb4c979b2765dfdeb8be6296722cd', class: "is-full relative flex items-center", part: "progress" }, h("progress", { key: '5d9e1a576b18383ca67135e1fffe4cc71c57fcc4', class: {
116
- [`progress-bar progress-bar__${this.type} ${this.thickness}`]: true,
117
- 'progress-bar__border-shape rounded-full': this.borderShape === 'rounded',
118
- }, max: "100", part: "progress-bar", value: this.indeterminate ? undefined : this.value }), this.enableTooltip && !this.indeterminate && (h("bq-tooltip", { key: 'c903b6e6f689610b6285e484702ea8fca1c20bff', alwaysVisible: true, class: "absolute [&::part(panel)]:absolute", distance: 16, exportparts: "base,trigger,panel", style: { insetInlineStart: `${this.value}%`, fontVariant: 'tabular-nums' } }, h("div", { key: '558222b0e2ab822fb4d59fe7665157fa8dd22dcf', class: "bs-1 is-1 absolute", slot: "trigger" }), this.value)), this.indeterminate && (h("div", { key: 'e1a35b5e085b7853e8599bc9b7ff00417a15ee11', class: {
119
- 'progress-bar__indeterminate bs-[--bq-progress-bar--height] is-[--bq-progress-bar--indeterminateWidth] absolute bg-[--bq-progress-bar--indicatorColor]': true,
120
- 'rounded-full': this.borderShape === 'rounded',
121
- }, part: "indeterminate" }))), h("div", { key: 'c3bf63045c31d9eb98f2b5c4033630b835ed076d', "aria-hidden": !this.label || this.indeterminate ? 'true' : 'false', class: {
122
- 'ms-xs font-medium leading-regular': true,
123
- 'text-primary': this.type !== 'error',
124
- 'text-danger': this.type === 'error',
125
- 'is-0 invisible ms-0': !this.label || this.indeterminate,
126
- }, part: "label", style: { fontVariant: 'tabular-nums' } }, h("span", { key: '9e2413dcea94c034f7106203085c35ad27bcbdd7' }, this.value, "%")))));
116
+ return (_jsx(Host, { style: style, children: _jsxs("div", { class: "flex items-center", part: "wrapper", children: [_jsxs("div", { class: "is-full relative flex items-center", part: "progress", children: [_jsx("progress", { class: {
117
+ [`progress-bar progress-bar__${this.type} ${this.thickness}`]: true,
118
+ 'progress-bar__border-shape rounded-full': this.borderShape === 'rounded',
119
+ }, max: "100", part: "progress-bar", value: this.indeterminate ? undefined : this.value }, '19c00704a46d96cc0be5556317d5380c95106e2e'), this.enableTooltip && !this.indeterminate && (_jsxs("bq-tooltip", { alwaysVisible: true, class: "absolute [&::part(panel)]:absolute", distance: 16, exportparts: "base,trigger,panel", style: { insetInlineStart: `${this.value}%`, fontVariant: 'tabular-nums' }, children: [_jsx("div", { class: "bs-1 is-1 absolute", slot: "trigger" }, '28dfb829158c3a6812cd61e97b84fc027993fd05'), this.value] }, '7699f03950fb94de937970f4c3e9118c619d2d26')), this.indeterminate && (_jsx("div", { class: {
120
+ 'progress-bar__indeterminate bs-[--bq-progress-bar--height] is-[--bq-progress-bar--indeterminateWidth] absolute bg-[--bq-progress-bar--indicatorColor]': true,
121
+ 'rounded-full': this.borderShape === 'rounded',
122
+ }, part: "indeterminate" }, '037d60aa30c798e97f548ace3c5ee6255bd2fde3'))] }, 'c4dead7cc9abb330f8f3ac96fe45469478f5b962'), _jsx("div", { "aria-hidden": !this.label || this.indeterminate ? 'true' : 'false', class: {
123
+ 'ms-xs font-medium leading-regular': true,
124
+ 'text-primary': this.type !== 'error',
125
+ 'text-danger': this.type === 'error',
126
+ 'is-0 invisible ms-0': !this.label || this.indeterminate,
127
+ }, part: "label", style: { fontVariant: 'tabular-nums' }, children: _jsxs("span", { children: [this.value, "%"] }, 'b6d258a746a5954ca6e100adf06f77cb1341b167') }, '2e32d6fe7f84029cadd1187e0277038d1204b3a7')] }, 'd3042ea61b8cfb058ebfc30fd659f294e69090b4') }, '5d52cdbdd0e11f1732764f17e1787f4fd8d19c97'));
127
128
  }
128
129
  static get is() { return "bq-progress"; }
129
130
  static get encapsulation() { return "shadow"; }
@@ -149,7 +150,8 @@ export class BqProgress {
149
150
  "TProgressBorderShape": {
150
151
  "location": "import",
151
152
  "path": "./bq-progress.types",
152
- "id": "../../packages/beeq/src/components/progress/bq-progress.types.ts::TProgressBorderShape"
153
+ "id": "../../packages/beeq/src/components/progress/bq-progress.types.ts::TProgressBorderShape",
154
+ "referenceLocation": "TProgressBorderShape"
153
155
  }
154
156
  }
155
157
  },
@@ -235,7 +237,8 @@ export class BqProgress {
235
237
  "TProgressThickness": {
236
238
  "location": "import",
237
239
  "path": "./bq-progress.types",
238
- "id": "../../packages/beeq/src/components/progress/bq-progress.types.ts::TProgressThickness"
240
+ "id": "../../packages/beeq/src/components/progress/bq-progress.types.ts::TProgressThickness",
241
+ "referenceLocation": "TProgressThickness"
239
242
  }
240
243
  }
241
244
  },
@@ -261,7 +264,8 @@ export class BqProgress {
261
264
  "TProgressType": {
262
265
  "location": "import",
263
266
  "path": "./bq-progress.types",
264
- "id": "../../packages/beeq/src/components/progress/bq-progress.types.ts::TProgressType"
267
+ "id": "../../packages/beeq/src/components/progress/bq-progress.types.ts::TProgressType",
268
+ "referenceLocation": "TProgressType"
265
269
  }
266
270
  }
267
271
  },
@@ -1 +1 @@
1
- {"version":3,"file":"bq-progress.js","sourceRoot":"","sources":["../../../../../../packages/beeq/src/components/progress/bq-progress.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, Host, h, Prop, Watch } from '@stencil/core';\n\nimport { validatePropValue } from '../../shared/utils';\nimport type { TProgressBorderShape, TProgressThickness, TProgressType } from './bq-progress.types';\nimport { PROGRESS_BORDER_SHAPE, PROGRESS_THICKNESS, PROGRESS_TYPE } from './bq-progress.types';\n\n/**\n * The progress bar is a user interface component that visually represents the completion status of a task or process.\n *\n * @example How to use it\n * ```html\n * <bq-progress value=\"50\"></bq-progress>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/691cb3-progress\n * @status stable\n *\n * @dependency bq-tooltip\n *\n * @attr {\"rounded\" | \"rounded-full\"} border-shape - It will set the border style of the progress bar\n * @attr {boolean} enable-tooltip - If `true`, a tooltip will be shown displaying the progress value\n * @attr {boolean} indeterminate - If `true` the indeterminate state of progress bar is enabled\n * @attr {boolean} label - If `true`, a label text showing the value (in percentage) will be shown\n * @attr {\"small\" | \"medium\" | \"large\"} thickness - Progress bar thickness\n * @attr {\"default\" | \"error\"} type - Progress type\n * @attr {number} value - A number representing the current value of the progress bar\n *\n * @part wrapper - The component wrapper container inside the shadow DOM\n * @part progress - The `<div>` container that holds the native progress element\n * @part progress-bar - The native html for progress element\n * @part label - The `<div>` container that holds the label value (in percentage)\n * @part indeterminate - The `<div>` container that holds the indeterminate progress bar\n * @part base - The base container for the tooltip component inside the shadow DOM when hovering over the progress bar\n * @part trigger - The container holding the element that triggers the tooltip display when hovering over the progress bar\n * @part panel - The container holding the content of the tooltip when hovering over the progress bar\n *\n * @cssprop --bq-progress-bar--height - The progress bars height\n * @cssprop --bq-progress-bar--indeterminateWidth - The progress bar width when its indeterminate\n * @cssprop --bq-progress-bar--indicatorColor - The progress bar color (inside the track area)\n * @cssprop --bq-progress-bar--trackColor - The progress bar track area (the grey one)\n */\n@Component({\n tag: 'bq-progress',\n styleUrl: './scss/bq-progress.scss',\n shadow: true,\n})\nexport class BqProgress {\n // Own Properties\n // ====================\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqProgressElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n // Public Property API\n // ========================\n\n /** It will set the border style of the progress bar */\n @Prop({ reflect: true }) borderShape: TProgressBorderShape = 'rounded';\n\n /** If `true`, a tooltip will be shown displaying the progress value */\n @Prop({ reflect: true }) enableTooltip: boolean = false;\n\n /** If `true` the indeterminate state of progress bar is enabled */\n @Prop({ reflect: true }) indeterminate: boolean = false;\n\n /** If `true, a label text showing the value (in percentage) will be shown */\n @Prop({ reflect: true }) label: boolean = false;\n\n /** Progress bar thickness */\n @Prop({ reflect: true }) thickness: TProgressThickness = 'medium';\n\n /** Progress type */\n @Prop({ reflect: true }) type: TProgressType = 'default';\n\n /** A number representing the current value of the progress bar */\n @Prop({ reflect: true, mutable: true }) value = 0;\n\n // Prop lifecycle events\n // =======================\n\n @Watch('borderShape')\n @Watch('thickness')\n @Watch('type')\n handleTypePropChange() {\n validatePropValue(PROGRESS_BORDER_SHAPE, 'rounded', this.el, 'borderShape');\n validatePropValue(PROGRESS_THICKNESS, 'medium', this.el, 'thickness');\n validatePropValue(PROGRESS_TYPE, 'default', this.el, 'type');\n }\n\n @Watch('value')\n handleValuePropChange(newValue: number) {\n this.validateValue(newValue);\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n componentWillLoad() {\n this.handleTypePropChange();\n this.handleValuePropChange(this.value);\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 // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n private validateValue(newValue: number) {\n const clampedValue = Math.max(0, Math.min(100, newValue));\n if (newValue !== clampedValue) {\n this.value = clampedValue;\n }\n return this.value;\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n const style = {\n ...(this.thickness === 'large' && { '--bq-progress-bar--height': 'var(--bq-spacing-xs)' }),\n ...(this.type === 'error' && { '--bq-progress-bar--indicatorColor': 'var(--bq-ui--danger)' }),\n };\n\n return (\n <Host style={style}>\n <div class=\"flex items-center\" part=\"wrapper\">\n <div class=\"is-full relative flex items-center\" part=\"progress\">\n <progress\n class={{\n [`progress-bar progress-bar__${this.type} ${this.thickness}`]: true,\n 'progress-bar__border-shape rounded-full': this.borderShape === 'rounded',\n }}\n max=\"100\"\n part=\"progress-bar\"\n value={this.indeterminate ? undefined : this.value}\n />\n {this.enableTooltip && !this.indeterminate && (\n <bq-tooltip\n alwaysVisible={true}\n class=\"absolute [&::part(panel)]:absolute\"\n distance={16}\n exportparts=\"base,trigger,panel\"\n style={{ insetInlineStart: `${this.value}%`, fontVariant: 'tabular-nums' }}\n >\n <div class=\"bs-1 is-1 absolute\" slot=\"trigger\"></div>\n {this.value}\n </bq-tooltip>\n )}\n {this.indeterminate && (\n <div\n class={{\n 'progress-bar__indeterminate bs-[--bq-progress-bar--height] is-[--bq-progress-bar--indeterminateWidth] absolute bg-[--bq-progress-bar--indicatorColor]': true,\n 'rounded-full': this.borderShape === 'rounded',\n }}\n part=\"indeterminate\"\n />\n )}\n </div>\n <div\n aria-hidden={!this.label || this.indeterminate ? 'true' : 'false'}\n class={{\n 'ms-xs font-medium leading-regular': true,\n 'text-primary': this.type !== 'error',\n 'text-danger': this.type === 'error',\n 'is-0 invisible ms-0': !this.label || this.indeterminate,\n }}\n part=\"label\"\n style={{ fontVariant: 'tabular-nums' }}\n >\n <span>{this.value}%</span>\n </div>\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"bq-progress.js","sourceRoot":"","sources":["../../../../../../packages/beeq/src/components/progress/bq-progress.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, Host, Prop, Watch } from '@stencil/core';\n\nimport { validatePropValue } from '../../shared/utils';\nimport type { TProgressBorderShape, TProgressThickness, TProgressType } from './bq-progress.types';\nimport { PROGRESS_BORDER_SHAPE, PROGRESS_THICKNESS, PROGRESS_TYPE } from './bq-progress.types';\n\n/**\n * The progress bar is a user interface component that visually represents the completion status of a task or process.\n *\n * @example How to use it\n * ```html\n * <bq-progress value=\"50\"></bq-progress>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/691cb3-progress\n * @status stable\n *\n * @dependency bq-tooltip\n *\n * @attr {\"rounded\" | \"rounded-full\"} border-shape - It will set the border style of the progress bar\n * @attr {boolean} enable-tooltip - If `true`, a tooltip will be shown displaying the progress value\n * @attr {boolean} indeterminate - If `true` the indeterminate state of progress bar is enabled\n * @attr {boolean} label - If `true`, a label text showing the value (in percentage) will be shown\n * @attr {\"small\" | \"medium\" | \"large\"} thickness - Progress bar thickness\n * @attr {\"default\" | \"error\"} type - Progress type\n * @attr {number} value - A number representing the current value of the progress bar\n *\n * @part wrapper - The component wrapper container inside the shadow DOM\n * @part progress - The `<div>` container that holds the native progress element\n * @part progress-bar - The native html for progress element\n * @part label - The `<div>` container that holds the label value (in percentage)\n * @part indeterminate - The `<div>` container that holds the indeterminate progress bar\n * @part base - The base container for the tooltip component inside the shadow DOM when hovering over the progress bar\n * @part trigger - The container holding the element that triggers the tooltip display when hovering over the progress bar\n * @part panel - The container holding the content of the tooltip when hovering over the progress bar\n *\n * @cssprop --bq-progress-bar--height - The progress bars height\n * @cssprop --bq-progress-bar--indeterminateWidth - The progress bar width when its indeterminate\n * @cssprop --bq-progress-bar--indicatorColor - The progress bar color (inside the track area)\n * @cssprop --bq-progress-bar--trackColor - The progress bar track area (the grey one)\n */\n@Component({\n tag: 'bq-progress',\n styleUrl: './scss/bq-progress.scss',\n shadow: true,\n})\nexport class BqProgress {\n // Own Properties\n // ====================\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqProgressElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n // Public Property API\n // ========================\n\n /** It will set the border style of the progress bar */\n @Prop({ reflect: true }) borderShape: TProgressBorderShape = 'rounded';\n\n /** If `true`, a tooltip will be shown displaying the progress value */\n @Prop({ reflect: true }) enableTooltip: boolean = false;\n\n /** If `true` the indeterminate state of progress bar is enabled */\n @Prop({ reflect: true }) indeterminate: boolean = false;\n\n /** If `true, a label text showing the value (in percentage) will be shown */\n @Prop({ reflect: true }) label: boolean = false;\n\n /** Progress bar thickness */\n @Prop({ reflect: true }) thickness: TProgressThickness = 'medium';\n\n /** Progress type */\n @Prop({ reflect: true }) type: TProgressType = 'default';\n\n /** A number representing the current value of the progress bar */\n @Prop({ reflect: true, mutable: true }) value = 0;\n\n // Prop lifecycle events\n // =======================\n\n @Watch('borderShape')\n @Watch('thickness')\n @Watch('type')\n handleTypePropChange() {\n validatePropValue(PROGRESS_BORDER_SHAPE, 'rounded', this.el, 'borderShape');\n validatePropValue(PROGRESS_THICKNESS, 'medium', this.el, 'thickness');\n validatePropValue(PROGRESS_TYPE, 'default', this.el, 'type');\n }\n\n @Watch('value')\n handleValuePropChange(newValue: number) {\n this.validateValue(newValue);\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n componentWillLoad() {\n this.handleTypePropChange();\n this.handleValuePropChange(this.value);\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 // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n private validateValue(newValue: number) {\n const clampedValue = Math.max(0, Math.min(100, newValue));\n if (newValue !== clampedValue) {\n this.value = clampedValue;\n }\n return this.value;\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n const style = {\n ...(this.thickness === 'large' && { '--bq-progress-bar--height': 'var(--bq-spacing-xs)' }),\n ...(this.type === 'error' && { '--bq-progress-bar--indicatorColor': 'var(--bq-ui--danger)' }),\n };\n\n return (\n <Host style={style}>\n <div class=\"flex items-center\" part=\"wrapper\">\n <div class=\"is-full relative flex items-center\" part=\"progress\">\n <progress\n class={{\n [`progress-bar progress-bar__${this.type} ${this.thickness}`]: true,\n 'progress-bar__border-shape rounded-full': this.borderShape === 'rounded',\n }}\n max=\"100\"\n part=\"progress-bar\"\n value={this.indeterminate ? undefined : this.value}\n />\n {this.enableTooltip && !this.indeterminate && (\n <bq-tooltip\n alwaysVisible={true}\n class=\"absolute [&::part(panel)]:absolute\"\n distance={16}\n exportparts=\"base,trigger,panel\"\n style={{ insetInlineStart: `${this.value}%`, fontVariant: 'tabular-nums' }}\n >\n <div class=\"bs-1 is-1 absolute\" slot=\"trigger\"></div>\n {this.value}\n </bq-tooltip>\n )}\n {this.indeterminate && (\n <div\n class={{\n 'progress-bar__indeterminate bs-[--bq-progress-bar--height] is-[--bq-progress-bar--indeterminateWidth] absolute bg-[--bq-progress-bar--indicatorColor]': true,\n 'rounded-full': this.borderShape === 'rounded',\n }}\n part=\"indeterminate\"\n />\n )}\n </div>\n <div\n aria-hidden={!this.label || this.indeterminate ? 'true' : 'false'}\n class={{\n 'ms-xs font-medium leading-regular': true,\n 'text-primary': this.type !== 'error',\n 'text-danger': this.type === 'error',\n 'is-0 invisible ms-0': !this.label || this.indeterminate,\n }}\n part=\"label\"\n style={{ fontVariant: 'tabular-nums' }}\n >\n <span>{this.value}%</span>\n </div>\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -2,7 +2,8 @@
2
2
  * Built by Endavans
3
3
  * © https://beeq.design - Apache 2 License.
4
4
  */
5
- import { Host, h } from "@stencil/core";
5
+ import { jsx as _jsx, jsxs as _jsxs } from "@stencil/core/jsx-runtime";
6
+ import { Host } from "@stencil/core";
6
7
  /**
7
8
  * The radio button is a user interface element that allows users to select a single option.
8
9
  *
@@ -153,14 +154,14 @@ export class BqRadio {
153
154
  // Always the last one in the class.
154
155
  // ===================================
155
156
  render() {
156
- return (h(Host, { key: '249afdf1c2d2cc1c16ae7fd6df091e4e9b67080f' }, h("label", { key: '8ccd3bd89aacea77cf04f3c772d0e244442f02a3', class: {
157
- 'bq-radio group': true,
158
- 'is-disabled': this.isDisabled,
159
- 'is-checked': this.checked,
160
- 'has-background': this.backgroundOnHover,
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" })))));
157
+ return (_jsx(Host, { children: _jsxs("label", { class: {
158
+ 'bq-radio group': true,
159
+ 'is-disabled': this.isDisabled,
160
+ 'is-checked': this.checked,
161
+ 'has-background': this.backgroundOnHover,
162
+ }, part: "base", children: [_jsxs("div", { class: "bq-radio__control", children: [_jsx("input", { "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) => {
163
+ this.inputElement = element;
164
+ }, required: this.required, type: "radio", value: this.value }, 'f66c4b4c9f6198ce9633427d72aa53633cf0a755'), _jsx("div", { class: "bq-radio__circle", part: "radio", children: _jsx("div", { class: "bq-radio__checked" }, '5ec3e348bfa8b603d985706ab461a7efd21fb486') }, 'b96eb2344583b5d863ecb5826454e3013677c345')] }, '08e24ae8593a75299931e672f968b7c03322080b'), _jsx("span", { class: "bq-radio__label group-hover:text-text-primary-hover group-[.is-disabled]:text-text-primary-disabled", part: "label", children: _jsx("slot", { id: "bq-radio__label" }, '79d783632d8c11da457b4ec343999bcc2d8b7bb2') }, '1f8d0690de7c18068a32b314bb40dad2be46f953')] }, '0df6f0b244d4d87d794ac71090fbccd98d5b8eb0') }, '2d1547345897731128ca2bf8260d19346fddfc48'));
164
165
  }
165
166
  static get is() { return "bq-radio"; }
166
167
  static get encapsulation() { return "shadow"; }
@@ -1 +1 @@
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"]}
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, 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,7 +2,8 @@
2
2
  * Built by Endavans
3
3
  * © https://beeq.design - Apache 2 License.
4
4
  */
5
- import { Host, h } from "@stencil/core";
5
+ import { jsx as _jsx, jsxs as _jsxs } from "@stencil/core/jsx-runtime";
6
+ import { Host } from "@stencil/core";
6
7
  import { debounce, getNextElement, isDefined, isEventTargetChildOfElement, isNil, validatePropValue, } from "../../shared/utils";
7
8
  import { RADIO_GROUP_ORIENTATION } from "./bq-radio-group.types";
8
9
  const KEY_MAP = {
@@ -353,7 +354,7 @@ export class BqRadioGroup {
353
354
  // Always the last one in the class.
354
355
  // ===================================
355
356
  render() {
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 })))));
357
+ return (_jsx(Host, { tabindex: this.tabIndex, children: _jsxs("fieldset", { "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", children: [_jsx("legend", { part: "label", children: _jsx("slot", { id: "bq-radiogroup__label", name: "label" }, '2d93d0a2f8221720db47166c17d895a47775c072') }, 'a69f7d64021961d1e6661f0557f5b35302ecff62'), _jsx("div", { class: `bq-radio-group--${this.orientation}`, part: "group", children: _jsx("slot", { id: "bq-radiogroup", onSlotchange: this.handleSlotChange }, '17c0d89bba704ab545c3af8d55e711d20860f136') }, '85f121e16f40e45ee6812844aacb3893f067101f')] }, '33ebb252ebcf5dda6d69bf3992c4474fea32723c') }, '2bca24f2a90e889546558e2787b44af2ff437f80'));
357
358
  }
358
359
  static get is() { return "bq-radio-group"; }
359
360
  static get encapsulation() { return "shadow"; }
@@ -480,7 +481,8 @@ export class BqRadioGroup {
480
481
  "TRadioGroupOrientation": {
481
482
  "location": "import",
482
483
  "path": "./bq-radio-group.types",
483
- "id": "../../packages/beeq/src/components/radio-group/bq-radio-group.types.ts::TRadioGroupOrientation"
484
+ "id": "../../packages/beeq/src/components/radio-group/bq-radio-group.types.ts::TRadioGroupOrientation",
485
+ "referenceLocation": "TRadioGroupOrientation"
484
486
  }
485
487
  }
486
488
  },
@@ -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 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"]}
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, 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"]}