@beeq/core 1.8.4-beta.0 → 1.8.5-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (898) hide show
  1. package/LICENSE +201 -0
  2. package/dist/beeq/beeq.esm.js +1 -1
  3. package/dist/beeq/beeq.esm.js.map +1 -1
  4. package/dist/beeq/bq-accordion-group.entry.esm.js.map +1 -0
  5. package/dist/beeq/bq-accordion.entry.esm.js.map +1 -0
  6. package/dist/beeq/bq-alert.entry.esm.js.map +1 -0
  7. package/dist/beeq/bq-avatar.entry.esm.js.map +1 -0
  8. package/dist/beeq/bq-badge.entry.esm.js.map +1 -0
  9. package/dist/beeq/bq-breadcrumb-item.entry.esm.js.map +1 -0
  10. package/dist/beeq/bq-breadcrumb.entry.esm.js.map +1 -0
  11. package/dist/beeq/bq-button.bq-icon.entry.esm.js.map +1 -0
  12. package/dist/beeq/bq-card.entry.esm.js.map +1 -0
  13. package/dist/beeq/bq-checkbox.entry.esm.js.map +1 -0
  14. package/dist/beeq/bq-date-picker.entry.esm.js.map +1 -0
  15. package/dist/beeq/bq-dialog.entry.esm.js.map +1 -0
  16. package/dist/beeq/bq-divider.entry.esm.js.map +1 -0
  17. package/dist/beeq/bq-drawer.entry.esm.js.map +1 -0
  18. package/dist/beeq/bq-dropdown.bq-panel.entry.esm.js.map +1 -0
  19. package/dist/beeq/bq-empty-state.entry.esm.js.map +1 -0
  20. package/dist/beeq/bq-input.entry.esm.js.map +1 -0
  21. package/dist/beeq/bq-notification.entry.esm.js.map +1 -0
  22. package/dist/beeq/bq-option-group.entry.esm.js.map +1 -0
  23. package/dist/beeq/bq-option-list.bq-tag.entry.esm.js.map +1 -0
  24. package/dist/beeq/bq-option.entry.esm.js.map +1 -0
  25. package/dist/beeq/bq-page-title.entry.esm.js.map +1 -0
  26. package/dist/beeq/bq-progress.entry.esm.js.map +1 -0
  27. package/dist/beeq/bq-radio-group.entry.esm.js.map +1 -0
  28. package/dist/beeq/bq-radio.entry.esm.js.map +1 -0
  29. package/dist/beeq/bq-select.entry.esm.js.map +1 -0
  30. package/dist/beeq/bq-side-menu-item.entry.esm.js.map +1 -0
  31. package/dist/beeq/bq-side-menu.entry.esm.js.map +1 -0
  32. package/dist/beeq/bq-slider.entry.esm.js.map +1 -0
  33. package/dist/beeq/bq-spinner.entry.esm.js.map +1 -0
  34. package/dist/beeq/bq-status.entry.esm.js.map +1 -0
  35. package/dist/beeq/bq-step-item.entry.esm.js.map +1 -0
  36. package/dist/beeq/bq-steps.entry.esm.js.map +1 -0
  37. package/dist/beeq/bq-switch.entry.esm.js.map +1 -0
  38. package/dist/beeq/bq-tab-group.entry.esm.js.map +1 -0
  39. package/dist/beeq/bq-tab.entry.esm.js.map +1 -0
  40. package/dist/beeq/bq-textarea.entry.esm.js.map +1 -0
  41. package/dist/beeq/bq-toast.entry.esm.js.map +1 -0
  42. package/dist/beeq/bq-tooltip.entry.esm.js.map +1 -0
  43. package/dist/beeq/index.esm.js +1 -1
  44. package/dist/beeq/index.esm.js.map +1 -1
  45. package/dist/beeq/loader.esm.js.map +1 -0
  46. package/dist/beeq/p-00022fe8.entry.js +6 -0
  47. package/dist/beeq/p-00022fe8.entry.js.map +1 -0
  48. package/dist/beeq/{p-abda6f6c.entry.js → p-0b25af76.entry.js} +2 -2
  49. package/dist/beeq/p-0b25af76.entry.js.map +1 -0
  50. package/dist/beeq/{p-f48c3ca7.entry.js → p-0d137bf6.entry.js} +2 -2
  51. package/dist/beeq/p-0d137bf6.entry.js.map +1 -0
  52. package/dist/beeq/{p-7ff775a3.entry.js → p-0d37b636.entry.js} +2 -2
  53. package/dist/beeq/p-0d37b636.entry.js.map +1 -0
  54. package/dist/beeq/{p-9a803ecf.entry.js → p-165744f3.entry.js} +2 -2
  55. package/dist/beeq/p-165744f3.entry.js.map +1 -0
  56. package/dist/beeq/{p-63b4f8f9.entry.js → p-217d6ad4.entry.js} +2 -2
  57. package/dist/beeq/p-217d6ad4.entry.js.map +1 -0
  58. package/dist/beeq/{p-7bb8664c.entry.js → p-29209d90.entry.js} +2 -2
  59. package/dist/beeq/p-29209d90.entry.js.map +1 -0
  60. package/dist/beeq/{p-a661454e.entry.js → p-2bb8c586.entry.js} +2 -2
  61. package/dist/beeq/p-2bb8c586.entry.js.map +1 -0
  62. package/dist/beeq/{p-45bfda93.entry.js → p-2ca0624c.entry.js} +2 -2
  63. package/dist/beeq/p-2ca0624c.entry.js.map +1 -0
  64. package/dist/beeq/{p-24135e46.entry.js → p-3df3af93.entry.js} +2 -2
  65. package/dist/beeq/p-3df3af93.entry.js.map +1 -0
  66. package/dist/beeq/{p-260877e5.entry.js → p-44c2a6b9.entry.js} +2 -2
  67. package/dist/beeq/p-44c2a6b9.entry.js.map +1 -0
  68. package/dist/beeq/{p-9eea4f4f.entry.js → p-4f3809da.entry.js} +2 -2
  69. package/dist/beeq/p-4f3809da.entry.js.map +1 -0
  70. package/dist/beeq/{p-115ed5b2.js → p-4iHDua0i.js} +1 -1
  71. package/dist/beeq/p-4iHDua0i.js.map +1 -0
  72. package/dist/beeq/p-52ae6a62.entry.js +6 -0
  73. package/dist/beeq/p-52ae6a62.entry.js.map +1 -0
  74. package/dist/beeq/p-542eb8fa.entry.js +6 -0
  75. package/dist/beeq/p-542eb8fa.entry.js.map +1 -0
  76. package/dist/beeq/{p-b1ab6b7f.entry.js → p-58c37e96.entry.js} +2 -2
  77. package/dist/beeq/p-58c37e96.entry.js.map +1 -0
  78. package/dist/beeq/{p-b044c5f6.entry.js → p-5ea58411.entry.js} +2 -2
  79. package/dist/beeq/p-5ea58411.entry.js.map +1 -0
  80. package/dist/beeq/p-8570c34a.entry.js +6 -0
  81. package/dist/beeq/p-8570c34a.entry.js.map +1 -0
  82. package/dist/beeq/{p-ba8b92f1.entry.js → p-90fd4b0c.entry.js} +2 -2
  83. package/dist/beeq/p-90fd4b0c.entry.js.map +1 -0
  84. package/dist/beeq/{p-34f25f24.entry.js → p-999f9e20.entry.js} +2 -2
  85. package/dist/beeq/p-999f9e20.entry.js.map +1 -0
  86. package/dist/{components/p-07b82e50.js → beeq/p-B4sM1t6Z.js} +1 -1
  87. package/dist/beeq/p-B4sM1t6Z.js.map +1 -0
  88. package/dist/{components/p-99829fc7.js → beeq/p-BcPwGxIn.js} +1 -1
  89. package/dist/beeq/p-BcPwGxIn.js.map +1 -0
  90. package/dist/beeq/{p-45800965.js → p-BtYhUEAn.js} +1 -1
  91. package/dist/beeq/p-BtYhUEAn.js.map +1 -0
  92. package/dist/{components/p-57621be1.js → beeq/p-BxgDLPzX.js} +1 -1
  93. package/dist/beeq/p-BxgDLPzX.js.map +1 -0
  94. package/dist/beeq/{p-ecd27cf2.js → p-CVMdKx0v.js} +1 -1
  95. package/dist/beeq/p-CVMdKx0v.js.map +1 -0
  96. package/dist/beeq/{p-1f3a4359.js → p-Cau9SvT4.js} +1 -1
  97. package/dist/beeq/p-Cau9SvT4.js.map +1 -0
  98. package/dist/beeq/p-Ci39rxuU.js +6 -0
  99. package/dist/beeq/p-Ci39rxuU.js.map +1 -0
  100. package/dist/beeq/{p-1defeea3.js → p-D9ofIraD.js} +2 -2
  101. package/dist/beeq/p-D9ofIraD.js.map +1 -0
  102. package/dist/beeq/{p-a8cad5ab.js → p-DEUOprS4.js} +1 -1
  103. package/dist/beeq/p-DEUOprS4.js.map +1 -0
  104. package/dist/beeq/p-DG51kDIQ.js +6 -0
  105. package/dist/beeq/p-DG51kDIQ.js.map +1 -0
  106. package/dist/beeq/p-DJ_hypV7.js +6 -0
  107. package/dist/beeq/p-DJ_hypV7.js.map +1 -0
  108. package/dist/{components/p-a5dc1c94.js → beeq/p-DdvbF5yL.js} +1 -1
  109. package/dist/beeq/p-DdvbF5yL.js.map +1 -0
  110. package/dist/beeq/{p-af062402.js → p-DnkZCdMA.js} +1 -1
  111. package/dist/beeq/p-DnkZCdMA.js.map +1 -0
  112. package/dist/{components/p-1c8b6eb4.js → beeq/p-Dx-CEPSQ.js} +1 -1
  113. package/dist/beeq/p-Dx-CEPSQ.js.map +1 -0
  114. package/dist/beeq/p-DxsVp5np.js +7 -0
  115. package/dist/beeq/p-DxsVp5np.js.map +1 -0
  116. package/dist/beeq/{p-c3a0bd23.js → p-_RvVpeh2.js} +2 -2
  117. package/dist/beeq/p-_RvVpeh2.js.map +1 -0
  118. package/dist/beeq/{p-c63ee3df.entry.js → p-a68fbc9a.entry.js} +2 -2
  119. package/dist/beeq/p-a68fbc9a.entry.js.map +1 -0
  120. package/dist/beeq/{p-abf83b5c.entry.js → p-a72768fd.entry.js} +2 -2
  121. package/dist/beeq/p-a72768fd.entry.js.map +1 -0
  122. package/dist/beeq/{p-8b63d8fc.entry.js → p-a96ffa70.entry.js} +2 -2
  123. package/dist/beeq/p-a96ffa70.entry.js.map +1 -0
  124. package/dist/beeq/{p-2f9fc4d4.entry.js → p-ab5ce46e.entry.js} +2 -2
  125. package/dist/{components/p-6c1e486c.js.map → beeq/p-ab5ce46e.entry.js.map} +1 -1
  126. package/dist/beeq/{p-a620392e.entry.js → p-b07e39c4.entry.js} +2 -2
  127. package/dist/beeq/p-b07e39c4.entry.js.map +1 -0
  128. package/dist/beeq/{p-22188233.entry.js → p-b724504a.entry.js} +2 -2
  129. package/dist/beeq/p-b724504a.entry.js.map +1 -0
  130. package/dist/beeq/{p-a3c36d6c.entry.js → p-bee9cc2b.entry.js} +2 -2
  131. package/dist/beeq/p-bee9cc2b.entry.js.map +1 -0
  132. package/dist/beeq/{p-a7c4f022.entry.js → p-cab20c11.entry.js} +2 -2
  133. package/dist/beeq/{p-a7c4f022.entry.js.map → p-cab20c11.entry.js.map} +1 -1
  134. package/dist/beeq/{p-0ac37ff8.entry.js → p-ccc302f0.entry.js} +2 -2
  135. package/dist/beeq/p-ccc302f0.entry.js.map +1 -0
  136. package/dist/beeq/{p-6195e6e5.entry.js → p-cd4f1493.entry.js} +2 -2
  137. package/dist/beeq/p-cd4f1493.entry.js.map +1 -0
  138. package/dist/beeq/p-cfec306f.entry.js +6 -0
  139. package/dist/beeq/p-cfec306f.entry.js.map +1 -0
  140. package/dist/beeq/{p-4ddb6bdb.entry.js → p-d153a008.entry.js} +2 -2
  141. package/dist/beeq/p-d153a008.entry.js.map +1 -0
  142. package/dist/beeq/{p-3f5865c0.entry.js → p-d7564e29.entry.js} +2 -2
  143. package/dist/beeq/p-d7564e29.entry.js.map +1 -0
  144. package/dist/beeq/{p-801f7b25.entry.js → p-da8596cf.entry.js} +2 -2
  145. package/dist/beeq/p-da8596cf.entry.js.map +1 -0
  146. package/dist/beeq/{p-1a8f376a.entry.js → p-e0257fb4.entry.js} +2 -2
  147. package/dist/beeq/p-e0257fb4.entry.js.map +1 -0
  148. package/dist/beeq/{p-648da701.entry.js → p-e29356c6.entry.js} +2 -2
  149. package/dist/beeq/p-e29356c6.entry.js.map +1 -0
  150. package/dist/beeq/{p-01b3d2a5.entry.js → p-f5b3e9be.entry.js} +2 -2
  151. package/dist/beeq/p-f5b3e9be.entry.js.map +1 -0
  152. package/dist/beeq/{p-b89dcf37.entry.js → p-fd79697e.entry.js} +2 -2
  153. package/dist/beeq/p-fd79697e.entry.js.map +1 -0
  154. package/dist/beeq/{p-bc1980d8.entry.js → p-fea2b8c2.entry.js} +2 -2
  155. package/dist/beeq/p-fea2b8c2.entry.js.map +1 -0
  156. package/dist/beeq/{p-8c011151.entry.js → p-ffcc02f7.entry.js} +2 -2
  157. package/dist/beeq/p-ffcc02f7.entry.js.map +1 -0
  158. package/dist/{components/p-260d4ca0.js → beeq/p-uqkxeAeG.js} +1 -1
  159. package/dist/beeq/p-uqkxeAeG.js.map +1 -0
  160. package/dist/beeq/{p-687da041.js → p-zh4P02Kn.js} +1 -1
  161. package/dist/beeq/p-zh4P02Kn.js.map +1 -0
  162. package/dist/beeq.html-custom-data.json +200 -200
  163. package/dist/cjs/{app-globals-42eaedec.js → app-globals-BY_z0SzA.js} +2 -1
  164. package/dist/cjs/app-globals-BY_z0SzA.js.map +1 -0
  165. package/dist/cjs/{assetsPath-95e7f5ab.js → assetsPath-CyeA6tpY.js} +4 -4
  166. package/dist/cjs/assetsPath-CyeA6tpY.js.map +1 -0
  167. package/dist/cjs/beeq.cjs.js +8 -7
  168. package/dist/cjs/beeq.cjs.js.map +1 -1
  169. package/dist/cjs/bq-accordion-group.cjs.entry.js +7 -9
  170. package/dist/cjs/bq-accordion-group.cjs.entry.js.map +1 -1
  171. package/dist/cjs/bq-accordion-group.entry.cjs.js.map +1 -0
  172. package/dist/cjs/bq-accordion.cjs.entry.js +15 -17
  173. package/dist/cjs/bq-accordion.cjs.entry.js.map +1 -1
  174. package/dist/cjs/bq-accordion.entry.cjs.js.map +1 -0
  175. package/dist/cjs/bq-alert.cjs.entry.js +17 -19
  176. package/dist/cjs/bq-alert.cjs.entry.js.map +1 -1
  177. package/dist/cjs/bq-alert.entry.cjs.js.map +1 -0
  178. package/dist/cjs/bq-avatar.cjs.entry.js +8 -10
  179. package/dist/cjs/bq-avatar.cjs.entry.js.map +1 -1
  180. package/dist/cjs/bq-avatar.entry.cjs.js.map +1 -0
  181. package/dist/cjs/bq-badge.cjs.entry.js +10 -12
  182. package/dist/cjs/bq-badge.cjs.entry.js.map +1 -1
  183. package/dist/cjs/bq-badge.entry.cjs.js.map +1 -0
  184. package/dist/cjs/bq-breadcrumb-item.cjs.entry.js +10 -12
  185. package/dist/cjs/bq-breadcrumb-item.cjs.entry.js.map +1 -1
  186. package/dist/cjs/bq-breadcrumb-item.entry.cjs.js.map +1 -0
  187. package/dist/cjs/bq-breadcrumb.cjs.entry.js +4 -6
  188. package/dist/cjs/bq-breadcrumb.cjs.entry.js.map +1 -1
  189. package/dist/cjs/bq-breadcrumb.entry.cjs.js.map +1 -0
  190. package/dist/cjs/bq-button.bq-icon.entry.cjs.js.map +1 -0
  191. package/dist/cjs/bq-button_2.cjs.entry.js +30 -30
  192. package/dist/cjs/bq-button_2.cjs.entry.js.map +1 -1
  193. package/dist/cjs/bq-card.cjs.entry.js +7 -9
  194. package/dist/cjs/bq-card.cjs.entry.js.map +1 -1
  195. package/dist/cjs/bq-card.entry.cjs.js.map +1 -0
  196. package/dist/cjs/bq-checkbox.cjs.entry.js +10 -12
  197. package/dist/cjs/bq-checkbox.cjs.entry.js.map +1 -1
  198. package/dist/cjs/bq-checkbox.entry.cjs.js.map +1 -0
  199. package/dist/cjs/bq-date-picker.cjs.entry.js +22 -24
  200. package/dist/cjs/bq-date-picker.cjs.entry.js.map +1 -1
  201. package/dist/cjs/bq-date-picker.entry.cjs.js.map +1 -0
  202. package/dist/cjs/bq-dialog.cjs.entry.js +16 -18
  203. package/dist/cjs/bq-dialog.cjs.entry.js.map +1 -1
  204. package/dist/cjs/bq-dialog.entry.cjs.js.map +1 -0
  205. package/dist/cjs/bq-divider.cjs.entry.js +12 -14
  206. package/dist/cjs/bq-divider.cjs.entry.js.map +1 -1
  207. package/dist/cjs/bq-divider.entry.cjs.js.map +1 -0
  208. package/dist/cjs/bq-drawer.cjs.entry.js +16 -18
  209. package/dist/cjs/bq-drawer.cjs.entry.js.map +1 -1
  210. package/dist/cjs/bq-drawer.entry.cjs.js.map +1 -0
  211. package/dist/cjs/bq-dropdown.bq-panel.entry.cjs.js.map +1 -0
  212. package/dist/cjs/bq-dropdown_2.cjs.entry.js +10 -13
  213. package/dist/cjs/bq-dropdown_2.cjs.entry.js.map +1 -1
  214. package/dist/cjs/bq-empty-state.cjs.entry.js +10 -12
  215. package/dist/cjs/bq-empty-state.cjs.entry.js.map +1 -1
  216. package/dist/cjs/bq-empty-state.entry.cjs.js.map +1 -0
  217. package/dist/cjs/bq-input.cjs.entry.js +19 -21
  218. package/dist/cjs/bq-input.cjs.entry.js.map +1 -1
  219. package/dist/cjs/bq-input.entry.cjs.js.map +1 -0
  220. package/dist/cjs/bq-notification.cjs.entry.js +16 -18
  221. package/dist/cjs/bq-notification.cjs.entry.js.map +1 -1
  222. package/dist/cjs/bq-notification.entry.cjs.js.map +1 -0
  223. package/dist/cjs/bq-option-group.cjs.entry.js +4 -6
  224. package/dist/cjs/bq-option-group.cjs.entry.js.map +1 -1
  225. package/dist/cjs/bq-option-group.entry.cjs.js.map +1 -0
  226. package/dist/cjs/bq-option-list.bq-tag.entry.cjs.js.map +1 -0
  227. package/dist/cjs/bq-option-list_2.cjs.entry.js +22 -25
  228. package/dist/cjs/bq-option-list_2.cjs.entry.js.map +1 -1
  229. package/dist/cjs/bq-option.cjs.entry.js +12 -14
  230. package/dist/cjs/bq-option.cjs.entry.js.map +1 -1
  231. package/dist/cjs/bq-option.entry.cjs.js.map +1 -0
  232. package/dist/cjs/bq-page-title.cjs.entry.js +5 -7
  233. package/dist/cjs/bq-page-title.cjs.entry.js.map +1 -1
  234. package/dist/cjs/bq-page-title.entry.cjs.js.map +1 -0
  235. package/dist/cjs/bq-progress.cjs.entry.js +9 -11
  236. package/dist/cjs/bq-progress.cjs.entry.js.map +1 -1
  237. package/dist/cjs/bq-progress.entry.cjs.js.map +1 -0
  238. package/dist/cjs/bq-radio-group.cjs.entry.js +10 -12
  239. package/dist/cjs/bq-radio-group.cjs.entry.js.map +1 -1
  240. package/dist/cjs/bq-radio-group.entry.cjs.js.map +1 -0
  241. package/dist/cjs/bq-radio.cjs.entry.js +10 -12
  242. package/dist/cjs/bq-radio.cjs.entry.js.map +1 -1
  243. package/dist/cjs/bq-radio.entry.cjs.js.map +1 -0
  244. package/dist/cjs/bq-select.cjs.entry.js +19 -21
  245. package/dist/cjs/bq-select.cjs.entry.js.map +1 -1
  246. package/dist/cjs/bq-select.entry.cjs.js.map +1 -0
  247. package/dist/cjs/bq-side-menu-item.cjs.entry.js +8 -10
  248. package/dist/cjs/bq-side-menu-item.cjs.entry.js.map +1 -1
  249. package/dist/cjs/bq-side-menu-item.entry.cjs.js.map +1 -0
  250. package/dist/cjs/bq-side-menu.cjs.entry.js +9 -11
  251. package/dist/cjs/bq-side-menu.cjs.entry.js.map +1 -1
  252. package/dist/cjs/bq-side-menu.entry.cjs.js.map +1 -0
  253. package/dist/cjs/bq-slider.cjs.entry.js +12 -14
  254. package/dist/cjs/bq-slider.cjs.entry.js.map +1 -1
  255. package/dist/cjs/bq-slider.entry.cjs.js.map +1 -0
  256. package/dist/cjs/bq-spinner.cjs.entry.js +14 -16
  257. package/dist/cjs/bq-spinner.cjs.entry.js.map +1 -1
  258. package/dist/cjs/bq-spinner.entry.cjs.js.map +1 -0
  259. package/dist/cjs/bq-status.cjs.entry.js +6 -8
  260. package/dist/cjs/bq-status.cjs.entry.js.map +1 -1
  261. package/dist/cjs/bq-status.entry.cjs.js.map +1 -0
  262. package/dist/cjs/bq-step-item.cjs.entry.js +11 -13
  263. package/dist/cjs/bq-step-item.cjs.entry.js.map +1 -1
  264. package/dist/cjs/bq-step-item.entry.cjs.js.map +1 -0
  265. package/dist/cjs/bq-steps.cjs.entry.js +7 -9
  266. package/dist/cjs/bq-steps.cjs.entry.js.map +1 -1
  267. package/dist/cjs/bq-steps.entry.cjs.js.map +1 -0
  268. package/dist/cjs/{bq-steps.types-4d1836d0.js → bq-steps.types-D4B3f19X.js} +2 -1
  269. package/dist/cjs/bq-steps.types-D4B3f19X.js.map +1 -0
  270. package/dist/cjs/bq-switch.cjs.entry.js +11 -13
  271. package/dist/cjs/bq-switch.cjs.entry.js.map +1 -1
  272. package/dist/cjs/bq-switch.entry.cjs.js.map +1 -0
  273. package/dist/cjs/bq-tab-group.cjs.entry.js +13 -15
  274. package/dist/cjs/bq-tab-group.cjs.entry.js.map +1 -1
  275. package/dist/cjs/bq-tab-group.entry.cjs.js.map +1 -0
  276. package/dist/cjs/bq-tab.cjs.entry.js +13 -15
  277. package/dist/cjs/bq-tab.cjs.entry.js.map +1 -1
  278. package/dist/cjs/bq-tab.entry.cjs.js.map +1 -0
  279. package/dist/cjs/{bq-tab.types-a8b320b0.js → bq-tab.types-EbesjHYK.js} +2 -1
  280. package/dist/cjs/bq-tab.types-EbesjHYK.js.map +1 -0
  281. package/dist/cjs/bq-textarea.cjs.entry.js +16 -18
  282. package/dist/cjs/bq-textarea.cjs.entry.js.map +1 -1
  283. package/dist/cjs/bq-textarea.entry.cjs.js.map +1 -0
  284. package/dist/cjs/bq-toast.cjs.entry.js +11 -13
  285. package/dist/cjs/bq-toast.cjs.entry.js.map +1 -1
  286. package/dist/cjs/bq-toast.entry.cjs.js.map +1 -0
  287. package/dist/cjs/bq-tooltip.cjs.entry.js +6 -8
  288. package/dist/cjs/bq-tooltip.cjs.entry.js.map +1 -1
  289. package/dist/cjs/bq-tooltip.entry.cjs.js.map +1 -0
  290. package/dist/cjs/{clamp-dbbea7bf.js → clamp-CceB5h7D.js} +2 -1
  291. package/dist/cjs/clamp-CceB5h7D.js.map +1 -0
  292. package/dist/cjs/{cssVariables-55ad4942.js → cssVariables-exM7Oz37.js} +3 -2
  293. package/dist/cjs/cssVariables-exM7Oz37.js.map +1 -0
  294. package/dist/cjs/{debounce-1f7e1176.js → debounce-DFaAa1Cu.js} +3 -2
  295. package/dist/cjs/debounce-DFaAa1Cu.js.map +1 -0
  296. package/dist/cjs/{event-7d21e426.js → event-BhuEFC-I.js} +2 -1
  297. package/dist/cjs/event-BhuEFC-I.js.map +1 -0
  298. package/dist/cjs/{getNextElement-4b790655.js → getNextElement-B5h_gmRG.js} +2 -1
  299. package/dist/cjs/getNextElement-B5h_gmRG.js.map +1 -0
  300. package/dist/cjs/{index-30fbd193.js → index-CD2anR4A.js} +2 -325
  301. package/dist/cjs/index-CD2anR4A.js.map +1 -0
  302. package/dist/cjs/{index-d734f710.js → index-DkHCSxhS.js} +481 -192
  303. package/dist/cjs/index-DkHCSxhS.js.map +1 -0
  304. package/dist/cjs/index.cjs.js +15 -17
  305. package/dist/cjs/index.cjs.js.map +1 -1
  306. package/dist/cjs/{isClient-c22372aa.js → isClient-CrXhXxbA.js} +2 -1
  307. package/dist/cjs/isClient-CrXhXxbA.js.map +1 -0
  308. package/dist/cjs/{isDefined-642f676a.js → isDefined-K4EcmGLZ.js} +3 -3
  309. package/dist/cjs/isDefined-K4EcmGLZ.js.map +1 -0
  310. package/dist/cjs/{isHTMLElement-729e6be0.js → isHTMLElement-DMA6t4n4.js} +2 -1
  311. package/dist/cjs/isHTMLElement-DMA6t4n4.js.map +1 -0
  312. package/dist/cjs/{isNil-f93429a2.js → isNil-CFhdj92S.js} +2 -1
  313. package/dist/cjs/isNil-CFhdj92S.js.map +1 -0
  314. package/dist/cjs/{isString-f8847c11.js → isString-CHgmxASW.js} +2 -1
  315. package/dist/cjs/isString-CHgmxASW.js.map +1 -0
  316. package/dist/cjs/loader.cjs.js +4 -5
  317. package/dist/cjs/loader.cjs.js.map +1 -1
  318. package/dist/cjs/{props-2653e993.js → props-DzFXZXSF.js} +2 -1
  319. package/dist/cjs/props-DzFXZXSF.js.map +1 -0
  320. package/dist/cjs/{slot-c3eeb29f.js → slot-DKWrtk4b.js} +2 -1
  321. package/dist/cjs/slot-DKWrtk4b.js.map +1 -0
  322. package/dist/cjs/{transition-be315790.js → transition-C0S-pYqN.js} +2 -1
  323. package/dist/cjs/transition-C0S-pYqN.js.map +1 -0
  324. package/dist/collection/_storybook/foundation/helper/index.js.map +1 -1
  325. package/dist/collection/collection-manifest.json +1 -1
  326. package/dist/collection/components/accordion/bq-accordion.js +9 -9
  327. package/dist/collection/components/accordion/bq-accordion.js.map +1 -1
  328. package/dist/collection/components/accordion/bq-accordion.types.js.map +1 -1
  329. package/dist/collection/components/accordion/helper/index.js.map +1 -1
  330. package/dist/collection/components/accordion-group/bq-accordion-group.js +6 -6
  331. package/dist/collection/components/accordion-group/bq-accordion-group.js.map +1 -1
  332. package/dist/collection/components/alert/bq-alert.js +12 -12
  333. package/dist/collection/components/alert/bq-alert.js.map +1 -1
  334. package/dist/collection/components/alert/bq-alert.types.js.map +1 -1
  335. package/dist/collection/components/avatar/bq-avatar.js +9 -9
  336. package/dist/collection/components/avatar/bq-avatar.js.map +1 -1
  337. package/dist/collection/components/avatar/bq-avatar.types.js.map +1 -1
  338. package/dist/collection/components/badge/bq-badge.js +5 -5
  339. package/dist/collection/components/badge/bq-badge.js.map +1 -1
  340. package/dist/collection/components/badge/bq-badge.types.js.map +1 -1
  341. package/dist/collection/components/breadcrumb/bq-breadcrumb.js +1 -1
  342. package/dist/collection/components/breadcrumb/bq-breadcrumb.js.map +1 -1
  343. package/dist/collection/components/breadcrumb-item/bq-breadcrumb-item.js +4 -4
  344. package/dist/collection/components/breadcrumb-item/bq-breadcrumb-item.js.map +1 -1
  345. package/dist/collection/components/button/bq-button.js +15 -15
  346. package/dist/collection/components/button/bq-button.js.map +1 -1
  347. package/dist/collection/components/button/bq-button.types.js.map +1 -1
  348. package/dist/collection/components/card/bq-card.js +4 -4
  349. package/dist/collection/components/card/bq-card.js.map +1 -1
  350. package/dist/collection/components/card/bq-card.types.js.map +1 -1
  351. package/dist/collection/components/checkbox/bq-checkbox.js +11 -11
  352. package/dist/collection/components/checkbox/bq-checkbox.js.map +1 -1
  353. package/dist/collection/components/date-picker/bq-date-picker.js +35 -33
  354. package/dist/collection/components/date-picker/bq-date-picker.js.map +1 -1
  355. package/dist/collection/components/date-picker/bq-date-picker.types.js.map +1 -1
  356. package/dist/collection/components/date-picker/helper/callyLibrary.js.map +1 -1
  357. package/dist/collection/components/dialog/bq-dialog.js +13 -13
  358. package/dist/collection/components/dialog/bq-dialog.js.map +1 -1
  359. package/dist/collection/components/dialog/bq-dialog.types.js.map +1 -1
  360. package/dist/collection/components/dialog/scss/bq-dialog.css +1 -1
  361. package/dist/collection/components/divider/bq-divider.js +13 -13
  362. package/dist/collection/components/divider/bq-divider.js.map +1 -1
  363. package/dist/collection/components/divider/bq-divider.types.js.map +1 -1
  364. package/dist/collection/components/drawer/bq-drawer.js +10 -10
  365. package/dist/collection/components/drawer/bq-drawer.js.map +1 -1
  366. package/dist/collection/components/drawer/bq-drawer.types.js.map +1 -1
  367. package/dist/collection/components/drawer/scss/bq-drawer.css +1 -1
  368. package/dist/collection/components/dropdown/bq-dropdown.js +10 -10
  369. package/dist/collection/components/dropdown/bq-dropdown.js.map +1 -1
  370. package/dist/collection/components/empty-state/bq-empty-state.js +5 -5
  371. package/dist/collection/components/empty-state/bq-empty-state.js.map +1 -1
  372. package/dist/collection/components/empty-state/bq-empty-state.types.js.map +1 -1
  373. package/dist/collection/components/icon/bq-icon.js +8 -8
  374. package/dist/collection/components/icon/bq-icon.js.map +1 -1
  375. package/dist/collection/components/icon/bq-icon.types.js.map +1 -1
  376. package/dist/collection/components/icon/helper/request.js +4 -3
  377. package/dist/collection/components/icon/helper/request.js.map +1 -1
  378. package/dist/collection/components/input/bq-input.js +28 -28
  379. package/dist/collection/components/input/bq-input.js.map +1 -1
  380. package/dist/collection/components/input/bq-input.types.js.map +1 -1
  381. package/dist/collection/components/notification/bq-notification.js +9 -9
  382. package/dist/collection/components/notification/bq-notification.js.map +1 -1
  383. package/dist/collection/components/notification/bq-notification.types.js.map +1 -1
  384. package/dist/collection/components/notification/scss/bq-notification.css +1 -1
  385. package/dist/collection/components/option/bq-option.js +8 -8
  386. package/dist/collection/components/option/bq-option.js.map +1 -1
  387. package/dist/collection/components/option-group/bq-option-group.js.map +1 -1
  388. package/dist/collection/components/option-list/bq-option-list.js +2 -2
  389. package/dist/collection/components/option-list/bq-option-list.js.map +1 -1
  390. package/dist/collection/components/page-title/bq-page-title.js.map +1 -1
  391. package/dist/collection/components/panel/bq-panel.js +7 -7
  392. package/dist/collection/components/panel/bq-panel.js.map +1 -1
  393. package/dist/collection/components/progress/bq-progress.js +12 -12
  394. package/dist/collection/components/progress/bq-progress.js.map +1 -1
  395. package/dist/collection/components/progress/bq-progress.types.js.map +1 -1
  396. package/dist/collection/components/radio/bq-radio.js +9 -9
  397. package/dist/collection/components/radio/bq-radio.js.map +1 -1
  398. package/dist/collection/components/radio-group/bq-radio-group.js +10 -10
  399. package/dist/collection/components/radio-group/bq-radio-group.js.map +1 -1
  400. package/dist/collection/components/radio-group/bq-radio-group.types.js.map +1 -1
  401. package/dist/collection/components/select/bq-select.js +28 -28
  402. package/dist/collection/components/select/bq-select.js.map +1 -1
  403. package/dist/collection/components/select/scss/bq-select.css +1 -1
  404. package/dist/collection/components/side-menu/bq-side-menu.js +5 -5
  405. package/dist/collection/components/side-menu/bq-side-menu.js.map +1 -1
  406. package/dist/collection/components/side-menu/bq-side-menu.types.js.map +1 -1
  407. package/dist/collection/components/side-menu-item/bq-side-menu-item.js +3 -3
  408. package/dist/collection/components/side-menu-item/bq-side-menu-item.js.map +1 -1
  409. package/dist/collection/components/slider/bq-slider.js +14 -14
  410. package/dist/collection/components/slider/bq-slider.js.map +1 -1
  411. package/dist/collection/components/slider/bq-slider.types.js.map +1 -1
  412. package/dist/collection/components/spinner/bq-spinner.js +7 -7
  413. package/dist/collection/components/spinner/bq-spinner.js.map +1 -1
  414. package/dist/collection/components/spinner/bq-spinner.types.js.map +1 -1
  415. package/dist/collection/components/status/bq-status.js +2 -2
  416. package/dist/collection/components/status/bq-status.js.map +1 -1
  417. package/dist/collection/components/status/bq-status.types.js.map +1 -1
  418. package/dist/collection/components/step-item/bq-step-item.js +7 -7
  419. package/dist/collection/components/step-item/bq-step-item.js.map +1 -1
  420. package/dist/collection/components/step-item/bq-step-item.types.js.map +1 -1
  421. package/dist/collection/components/steps/bq-steps.js +4 -4
  422. package/dist/collection/components/steps/bq-steps.js.map +1 -1
  423. package/dist/collection/components/steps/bq-steps.types.js.map +1 -1
  424. package/dist/collection/components/switch/bq-switch.js +14 -14
  425. package/dist/collection/components/switch/bq-switch.js.map +1 -1
  426. package/dist/collection/components/switch/bq-switch.types.js.map +1 -1
  427. package/dist/collection/components/tab/bq-tab.js +9 -9
  428. package/dist/collection/components/tab/bq-tab.js.map +1 -1
  429. package/dist/collection/components/tab/bq-tab.types.js.map +1 -1
  430. package/dist/collection/components/tab-group/bq-tab-group.js +10 -10
  431. package/dist/collection/components/tab-group/bq-tab-group.js.map +1 -1
  432. package/dist/collection/components/tag/bq-tag.js +12 -12
  433. package/dist/collection/components/tag/bq-tag.js.map +1 -1
  434. package/dist/collection/components/tag/bq-tag.types.js.map +1 -1
  435. package/dist/collection/components/tag/helper/index.js.map +1 -1
  436. package/dist/collection/components/textarea/bq-textarea.js +23 -23
  437. package/dist/collection/components/textarea/bq-textarea.js.map +1 -1
  438. package/dist/collection/components/textarea/bq-textarea.types.js.map +1 -1
  439. package/dist/collection/components/toast/bq-toast.js +7 -7
  440. package/dist/collection/components/toast/bq-toast.js.map +1 -1
  441. package/dist/collection/components/toast/bq-toast.types.js.map +1 -1
  442. package/dist/collection/components/tooltip/bq-tooltip.js +8 -8
  443. package/dist/collection/components/tooltip/bq-tooltip.js.map +1 -1
  444. package/dist/collection/components/tooltip/bq-tooltip.types.js.map +1 -1
  445. package/dist/collection/index.js.map +1 -1
  446. package/dist/collection/services/interfaces/floating-ui.js.map +1 -1
  447. package/dist/collection/services/interfaces/index.js.map +1 -1
  448. package/dist/collection/services/libraries/floating-ui/index.js.map +1 -1
  449. package/dist/collection/services/libraries/index.js.map +1 -1
  450. package/dist/collection/shared/test-utils/computedStyle.js.map +1 -1
  451. package/dist/collection/shared/test-utils/index.js.map +1 -1
  452. package/dist/collection/shared/test-utils/setProperties.js.map +1 -1
  453. package/dist/collection/shared/test-utils/sleep.js.map +1 -1
  454. package/dist/collection/shared/utils/assetsPath.js +2 -3
  455. package/dist/collection/shared/utils/assetsPath.js.map +1 -1
  456. package/dist/collection/shared/utils/clamp.js.map +1 -1
  457. package/dist/collection/shared/utils/cssVariables.js.map +1 -1
  458. package/dist/collection/shared/utils/debounce.js.map +1 -1
  459. package/dist/collection/shared/utils/event.js.map +1 -1
  460. package/dist/collection/shared/utils/getNextElement.js.map +1 -1
  461. package/dist/collection/shared/utils/getRandom.js.map +1 -1
  462. package/dist/collection/shared/utils/index.js.map +1 -1
  463. package/dist/collection/shared/utils/isClient.js.map +1 -1
  464. package/dist/collection/shared/utils/isDefined.js.map +1 -1
  465. package/dist/collection/shared/utils/isEmpty.js.map +1 -1
  466. package/dist/collection/shared/utils/isHTMLElement.js.map +1 -1
  467. package/dist/collection/shared/utils/isNil.js.map +1 -1
  468. package/dist/collection/shared/utils/isString.js.map +1 -1
  469. package/dist/collection/shared/utils/props.js.map +1 -1
  470. package/dist/collection/shared/utils/setRafTimeout.js.map +1 -1
  471. package/dist/collection/shared/utils/slot.js.map +1 -1
  472. package/dist/collection/shared/utils/transition.js.map +1 -1
  473. package/dist/collection/tools/angular-value-accessor-config.js.map +1 -1
  474. package/dist/collection/tools/generate-custom-elements-json.js.map +1 -1
  475. package/dist/collection/tools/index.js.map +1 -1
  476. package/dist/collection/tools/vue-model-config.js.map +1 -1
  477. package/dist/components/bq-accordion-group.js +1 -1
  478. package/dist/components/bq-accordion-group.js.map +1 -1
  479. package/dist/components/bq-accordion.js +1 -1
  480. package/dist/components/bq-accordion.js.map +1 -1
  481. package/dist/components/bq-alert.js +1 -1
  482. package/dist/components/bq-alert.js.map +1 -1
  483. package/dist/components/bq-avatar.js +1 -1
  484. package/dist/components/bq-avatar.js.map +1 -1
  485. package/dist/components/bq-badge.js +1 -1
  486. package/dist/components/bq-breadcrumb-item.js +1 -1
  487. package/dist/components/bq-breadcrumb-item.js.map +1 -1
  488. package/dist/components/bq-breadcrumb.js +1 -1
  489. package/dist/components/bq-breadcrumb.js.map +1 -1
  490. package/dist/components/bq-button.js +1 -1
  491. package/dist/components/bq-card.js +1 -1
  492. package/dist/components/bq-card.js.map +1 -1
  493. package/dist/components/bq-checkbox.js +1 -1
  494. package/dist/components/bq-checkbox.js.map +1 -1
  495. package/dist/components/bq-date-picker.js +1 -1
  496. package/dist/components/bq-date-picker.js.map +1 -1
  497. package/dist/components/bq-dialog.js +1 -1
  498. package/dist/components/bq-dialog.js.map +1 -1
  499. package/dist/components/bq-divider.js +1 -1
  500. package/dist/components/bq-drawer.js +1 -1
  501. package/dist/components/bq-drawer.js.map +1 -1
  502. package/dist/components/bq-dropdown.js +1 -1
  503. package/dist/components/bq-empty-state.js +1 -1
  504. package/dist/components/bq-empty-state.js.map +1 -1
  505. package/dist/components/bq-icon.js +1 -1
  506. package/dist/components/bq-input.js +1 -1
  507. package/dist/components/bq-input.js.map +1 -1
  508. package/dist/components/bq-notification.js +1 -1
  509. package/dist/components/bq-notification.js.map +1 -1
  510. package/dist/components/bq-option-group.js +1 -1
  511. package/dist/components/bq-option-group.js.map +1 -1
  512. package/dist/components/bq-option-list.js +1 -1
  513. package/dist/components/bq-option.js +1 -1
  514. package/dist/components/bq-option.js.map +1 -1
  515. package/dist/components/bq-page-title.js +1 -1
  516. package/dist/components/bq-page-title.js.map +1 -1
  517. package/dist/components/bq-panel.js +1 -1
  518. package/dist/components/bq-progress.js +1 -1
  519. package/dist/components/bq-progress.js.map +1 -1
  520. package/dist/components/bq-radio-group.js +1 -1
  521. package/dist/components/bq-radio-group.js.map +1 -1
  522. package/dist/components/bq-radio.js +1 -1
  523. package/dist/components/bq-radio.js.map +1 -1
  524. package/dist/components/bq-select.js +1 -1
  525. package/dist/components/bq-select.js.map +1 -1
  526. package/dist/components/bq-side-menu-item.js +1 -1
  527. package/dist/components/bq-side-menu-item.js.map +1 -1
  528. package/dist/components/bq-side-menu.js +1 -1
  529. package/dist/components/bq-side-menu.js.map +1 -1
  530. package/dist/components/bq-slider.js +1 -1
  531. package/dist/components/bq-slider.js.map +1 -1
  532. package/dist/components/bq-spinner.js +1 -1
  533. package/dist/components/bq-spinner.js.map +1 -1
  534. package/dist/components/bq-status.js +1 -1
  535. package/dist/components/bq-status.js.map +1 -1
  536. package/dist/components/bq-step-item.js +1 -1
  537. package/dist/components/bq-step-item.js.map +1 -1
  538. package/dist/components/bq-steps.js +1 -1
  539. package/dist/components/bq-steps.js.map +1 -1
  540. package/dist/components/bq-switch.js +1 -1
  541. package/dist/components/bq-switch.js.map +1 -1
  542. package/dist/components/bq-tab-group.js +1 -1
  543. package/dist/components/bq-tab-group.js.map +1 -1
  544. package/dist/components/bq-tab.js +1 -1
  545. package/dist/components/bq-tab.js.map +1 -1
  546. package/dist/components/bq-tag.js +1 -1
  547. package/dist/components/bq-textarea.js +1 -1
  548. package/dist/components/bq-textarea.js.map +1 -1
  549. package/dist/components/bq-toast.js +1 -1
  550. package/dist/components/bq-toast.js.map +1 -1
  551. package/dist/components/bq-tooltip.js +1 -1
  552. package/dist/components/index.js +1 -1
  553. package/dist/components/index.js.map +1 -1
  554. package/dist/components/{p-6478d24c.js → p-3yNfc1gW.js} +2 -2
  555. package/dist/components/p-3yNfc1gW.js.map +1 -0
  556. package/dist/{beeq/p-07b82e50.js → components/p-B4sM1t6Z.js} +1 -1
  557. package/dist/components/{p-07b82e50.js.map → p-B4sM1t6Z.js.map} +1 -1
  558. package/dist/{beeq/p-99829fc7.js → components/p-BcPwGxIn.js} +1 -1
  559. package/dist/{beeq/p-99829fc7.js.map → components/p-BcPwGxIn.js.map} +1 -1
  560. package/dist/{beeq/p-57621be1.js → components/p-BxgDLPzX.js} +1 -1
  561. package/dist/components/{p-46f7e0e3.js → p-BzsDSFgf.js} +2 -2
  562. package/dist/components/p-BzsDSFgf.js.map +1 -0
  563. package/dist/components/{p-ecd27cf2.js → p-CVMdKx0v.js} +1 -1
  564. package/dist/{beeq/p-ecd27cf2.js.map → components/p-CVMdKx0v.js.map} +1 -1
  565. package/dist/components/p-Ci39rxuU.js +6 -0
  566. package/dist/{beeq/p-2b530ad4.js.map → components/p-Ci39rxuU.js.map} +1 -1
  567. package/dist/components/{p-1defeea3.js → p-D9ofIraD.js} +2 -2
  568. package/dist/{beeq/p-1defeea3.js.map → components/p-D9ofIraD.js.map} +1 -1
  569. package/dist/components/{p-5c61f1f5.js → p-DBUH9nOd.js} +2 -2
  570. package/dist/components/p-DBUH9nOd.js.map +1 -0
  571. package/dist/components/{p-a8cad5ab.js → p-DEUOprS4.js} +1 -1
  572. package/dist/{beeq/p-a8cad5ab.js.map → components/p-DEUOprS4.js.map} +1 -1
  573. package/dist/components/p-DFcM00d7.js +6 -0
  574. package/dist/components/p-DFcM00d7.js.map +1 -0
  575. package/dist/components/p-DJ_hypV7.js +6 -0
  576. package/dist/{esm/index-d4eea621.js.map → components/p-DJ_hypV7.js.map} +1 -1
  577. package/dist/components/{p-8d04a487.js → p-DWElqaGc.js} +2 -2
  578. package/dist/components/p-DWElqaGc.js.map +1 -0
  579. package/dist/{beeq/p-a5dc1c94.js → components/p-DdvbF5yL.js} +1 -1
  580. package/dist/{beeq/p-a5dc1c94.js.map → components/p-DdvbF5yL.js.map} +1 -1
  581. package/dist/components/p-DkbxITg_.js +6 -0
  582. package/dist/components/p-DkbxITg_.js.map +1 -0
  583. package/dist/components/{p-af062402.js → p-DnkZCdMA.js} +1 -1
  584. package/dist/{beeq/p-af062402.js.map → components/p-DnkZCdMA.js.map} +1 -1
  585. package/dist/{beeq/p-1c8b6eb4.js → components/p-Dx-CEPSQ.js} +1 -1
  586. package/dist/components/{p-263a1cc6.js → p-VAzCkxML.js} +2 -2
  587. package/dist/components/p-VAzCkxML.js.map +1 -0
  588. package/dist/components/{p-71751caa.js → p-WHcChQx3.js} +2 -2
  589. package/dist/components/p-WHcChQx3.js.map +1 -0
  590. package/dist/components/{p-c3a0bd23.js → p-_RvVpeh2.js} +2 -2
  591. package/dist/{beeq/p-c3a0bd23.js.map → components/p-_RvVpeh2.js.map} +1 -1
  592. package/dist/components/{p-33faef06.js → p-iu8JIKCE.js} +2 -2
  593. package/dist/components/p-iu8JIKCE.js.map +1 -0
  594. package/dist/{beeq/p-260d4ca0.js → components/p-uqkxeAeG.js} +1 -1
  595. package/dist/components/{p-260d4ca0.js.map → p-uqkxeAeG.js.map} +1 -1
  596. package/dist/components/{p-6c1e486c.js → p-vwcgzTkx.js} +2 -2
  597. package/dist/components/p-vwcgzTkx.js.map +1 -0
  598. package/dist/components/{p-687da041.js → p-zh4P02Kn.js} +1 -1
  599. package/dist/{beeq/p-687da041.js.map → components/p-zh4P02Kn.js.map} +1 -1
  600. package/dist/custom-elements.json +2970 -2970
  601. package/dist/esm/{app-globals-7655df21.js → app-globals-BtYhUEAn.js} +2 -1
  602. package/dist/esm/app-globals-BtYhUEAn.js.map +1 -0
  603. package/dist/esm/{assetsPath-060da522.js → assetsPath-v2hVBSPV.js} +4 -4
  604. package/dist/esm/assetsPath-v2hVBSPV.js.map +1 -0
  605. package/dist/esm/beeq.js +7 -5
  606. package/dist/esm/beeq.js.map +1 -1
  607. package/dist/esm/bq-accordion-group.entry.js +7 -7
  608. package/dist/esm/bq-accordion-group.entry.js.map +1 -1
  609. package/dist/esm/bq-accordion.entry.js +15 -15
  610. package/dist/esm/bq-accordion.entry.js.map +1 -1
  611. package/dist/esm/bq-alert.entry.js +17 -17
  612. package/dist/esm/bq-alert.entry.js.map +1 -1
  613. package/dist/esm/bq-avatar.entry.js +8 -8
  614. package/dist/esm/bq-avatar.entry.js.map +1 -1
  615. package/dist/esm/bq-badge.entry.js +10 -10
  616. package/dist/esm/bq-badge.entry.js.map +1 -1
  617. package/dist/esm/bq-breadcrumb-item.entry.js +10 -10
  618. package/dist/esm/bq-breadcrumb-item.entry.js.map +1 -1
  619. package/dist/esm/bq-breadcrumb.entry.js +4 -4
  620. package/dist/esm/bq-breadcrumb.entry.js.map +1 -1
  621. package/dist/esm/bq-button.bq-icon.entry.js.map +1 -0
  622. package/dist/esm/bq-button_2.entry.js +30 -28
  623. package/dist/esm/bq-button_2.entry.js.map +1 -1
  624. package/dist/esm/bq-card.entry.js +7 -7
  625. package/dist/esm/bq-card.entry.js.map +1 -1
  626. package/dist/esm/bq-checkbox.entry.js +10 -10
  627. package/dist/esm/bq-checkbox.entry.js.map +1 -1
  628. package/dist/esm/bq-date-picker.entry.js +22 -22
  629. package/dist/esm/bq-date-picker.entry.js.map +1 -1
  630. package/dist/esm/bq-dialog.entry.js +16 -16
  631. package/dist/esm/bq-dialog.entry.js.map +1 -1
  632. package/dist/esm/bq-divider.entry.js +12 -12
  633. package/dist/esm/bq-divider.entry.js.map +1 -1
  634. package/dist/esm/bq-drawer.entry.js +16 -16
  635. package/dist/esm/bq-drawer.entry.js.map +1 -1
  636. package/dist/esm/bq-dropdown.bq-panel.entry.js.map +1 -0
  637. package/dist/esm/bq-dropdown_2.entry.js +10 -11
  638. package/dist/esm/bq-dropdown_2.entry.js.map +1 -1
  639. package/dist/esm/bq-empty-state.entry.js +10 -10
  640. package/dist/esm/bq-empty-state.entry.js.map +1 -1
  641. package/dist/esm/bq-input.entry.js +19 -19
  642. package/dist/esm/bq-input.entry.js.map +1 -1
  643. package/dist/esm/bq-notification.entry.js +16 -16
  644. package/dist/esm/bq-notification.entry.js.map +1 -1
  645. package/dist/esm/bq-option-group.entry.js +4 -4
  646. package/dist/esm/bq-option-group.entry.js.map +1 -1
  647. package/dist/esm/bq-option-list.bq-tag.entry.js.map +1 -0
  648. package/dist/esm/bq-option-list_2.entry.js +22 -23
  649. package/dist/esm/bq-option-list_2.entry.js.map +1 -1
  650. package/dist/esm/bq-option.entry.js +12 -12
  651. package/dist/esm/bq-option.entry.js.map +1 -1
  652. package/dist/esm/bq-page-title.entry.js +5 -5
  653. package/dist/esm/bq-page-title.entry.js.map +1 -1
  654. package/dist/esm/bq-progress.entry.js +9 -9
  655. package/dist/esm/bq-progress.entry.js.map +1 -1
  656. package/dist/esm/bq-radio-group.entry.js +10 -10
  657. package/dist/esm/bq-radio-group.entry.js.map +1 -1
  658. package/dist/esm/bq-radio.entry.js +10 -10
  659. package/dist/esm/bq-radio.entry.js.map +1 -1
  660. package/dist/esm/bq-select.entry.js +19 -19
  661. package/dist/esm/bq-select.entry.js.map +1 -1
  662. package/dist/esm/bq-side-menu-item.entry.js +8 -8
  663. package/dist/esm/bq-side-menu-item.entry.js.map +1 -1
  664. package/dist/esm/bq-side-menu.entry.js +9 -9
  665. package/dist/esm/bq-side-menu.entry.js.map +1 -1
  666. package/dist/esm/bq-slider.entry.js +12 -12
  667. package/dist/esm/bq-slider.entry.js.map +1 -1
  668. package/dist/esm/bq-spinner.entry.js +14 -14
  669. package/dist/esm/bq-spinner.entry.js.map +1 -1
  670. package/dist/esm/bq-status.entry.js +6 -6
  671. package/dist/esm/bq-status.entry.js.map +1 -1
  672. package/dist/esm/bq-step-item.entry.js +11 -11
  673. package/dist/esm/bq-step-item.entry.js.map +1 -1
  674. package/dist/esm/bq-steps.entry.js +7 -7
  675. package/dist/esm/bq-steps.entry.js.map +1 -1
  676. package/dist/esm/{bq-steps.types-3a84b1e3.js → bq-steps.types-DEUOprS4.js} +2 -1
  677. package/dist/{components/p-a8cad5ab.js.map → esm/bq-steps.types-DEUOprS4.js.map} +1 -1
  678. package/dist/esm/bq-switch.entry.js +11 -11
  679. package/dist/esm/bq-switch.entry.js.map +1 -1
  680. package/dist/esm/bq-tab-group.entry.js +13 -13
  681. package/dist/esm/bq-tab-group.entry.js.map +1 -1
  682. package/dist/esm/bq-tab.entry.js +13 -13
  683. package/dist/esm/bq-tab.entry.js.map +1 -1
  684. package/dist/esm/{bq-tab.types-36e2666e.js → bq-tab.types-DnkZCdMA.js} +2 -1
  685. package/dist/esm/bq-tab.types-DnkZCdMA.js.map +1 -0
  686. package/dist/esm/bq-textarea.entry.js +16 -16
  687. package/dist/esm/bq-textarea.entry.js.map +1 -1
  688. package/dist/esm/bq-toast.entry.js +11 -11
  689. package/dist/esm/bq-toast.entry.js.map +1 -1
  690. package/dist/esm/bq-tooltip.entry.js +6 -6
  691. package/dist/esm/bq-tooltip.entry.js.map +1 -1
  692. package/dist/esm/{clamp-efa6c596.js → clamp-Cau9SvT4.js} +2 -1
  693. package/dist/esm/clamp-Cau9SvT4.js.map +1 -0
  694. package/dist/esm/{cssVariables-3665b51c.js → cssVariables-CyiWA5Ok.js} +3 -2
  695. package/dist/esm/cssVariables-CyiWA5Ok.js.map +1 -0
  696. package/dist/esm/{debounce-3e72f418.js → debounce-cjfQylgg.js} +3 -2
  697. package/dist/esm/debounce-cjfQylgg.js.map +1 -0
  698. package/dist/esm/{event-9ce1db79.js → event-Dx-CEPSQ.js} +2 -1
  699. package/dist/esm/event-Dx-CEPSQ.js.map +1 -0
  700. package/dist/esm/{getNextElement-8bcc2025.js → getNextElement-4iHDua0i.js} +2 -1
  701. package/dist/esm/getNextElement-4iHDua0i.js.map +1 -0
  702. package/dist/esm/{index-d4eea621.js → index-DJ_hypV7.js} +2 -325
  703. package/dist/esm/index-DJ_hypV7.js.map +1 -0
  704. package/dist/esm/{index-46823bdb.js → index-DxsVp5np.js} +479 -170
  705. package/dist/esm/index-DxsVp5np.js.map +1 -0
  706. package/dist/esm/index.js +16 -18
  707. package/dist/esm/index.js.map +1 -1
  708. package/dist/esm/{isClient-c6eae7ba.js → isClient-B4sM1t6Z.js} +2 -1
  709. package/dist/esm/isClient-B4sM1t6Z.js.map +1 -0
  710. package/dist/esm/{isDefined-8bdbf6b8.js → isDefined-DjmcVyb_.js} +3 -3
  711. package/dist/esm/isDefined-DjmcVyb_.js.map +1 -0
  712. package/dist/esm/{isHTMLElement-0271eefe.js → isHTMLElement-BxgDLPzX.js} +2 -1
  713. package/dist/esm/isHTMLElement-BxgDLPzX.js.map +1 -0
  714. package/dist/esm/{isNil-2290f64e.js → isNil-BcPwGxIn.js} +2 -1
  715. package/dist/esm/isNil-BcPwGxIn.js.map +1 -0
  716. package/dist/esm/{isString-9820a2b7.js → isString-CVMdKx0v.js} +2 -1
  717. package/dist/esm/isString-CVMdKx0v.js.map +1 -0
  718. package/dist/esm/loader.js +5 -4
  719. package/dist/esm/loader.js.map +1 -1
  720. package/dist/esm/{props-3bf7f546.js → props-zh4P02Kn.js} +2 -1
  721. package/dist/esm/props-zh4P02Kn.js.map +1 -0
  722. package/dist/esm/{slot-be230a01.js → slot-uqkxeAeG.js} +2 -1
  723. package/dist/esm/slot-uqkxeAeG.js.map +1 -0
  724. package/dist/esm/{transition-916fd7c0.js → transition-DdvbF5yL.js} +2 -1
  725. package/dist/esm/transition-DdvbF5yL.js.map +1 -0
  726. package/dist/hydrate/index.d.ts +34 -5
  727. package/dist/hydrate/index.js +1983 -1470
  728. package/dist/hydrate/index.mjs +1982 -1469
  729. package/dist/jest.config.js +20 -0
  730. package/dist/jest.config.js.map +1 -0
  731. package/dist/stencil.config.js +3 -3
  732. package/dist/stencil.config.js.map +1 -1
  733. package/dist/types/Users/dramos/PROJECTs/ENDAVA/BEEQ-Design-System/.stencil/packages/beeq/jest.config.d.ts +16 -0
  734. package/dist/types/Users/dramos/PROJECTs/ENDAVA/BEEQ-Design-System/.stencil/packages/beeq/stencil.config.d.ts +2 -0
  735. package/dist/types/components/accordion/bq-accordion.d.ts +2 -2
  736. package/dist/types/components/accordion-group/bq-accordion-group.d.ts +1 -1
  737. package/dist/types/components/alert/bq-alert.d.ts +2 -2
  738. package/dist/types/components/avatar/bq-avatar.d.ts +1 -1
  739. package/dist/types/components/badge/bq-badge.d.ts +1 -1
  740. package/dist/types/components/breadcrumb-item/bq-breadcrumb-item.d.ts +1 -1
  741. package/dist/types/components/button/bq-button.d.ts +2 -2
  742. package/dist/types/components/card/bq-card.d.ts +1 -1
  743. package/dist/types/components/checkbox/bq-checkbox.d.ts +1 -1
  744. package/dist/types/components/date-picker/bq-date-picker.d.ts +4 -4
  745. package/dist/types/components/dialog/bq-dialog.d.ts +2 -2
  746. package/dist/types/components/divider/bq-divider.d.ts +1 -1
  747. package/dist/types/components/drawer/bq-drawer.d.ts +2 -2
  748. package/dist/types/components/dropdown/bq-dropdown.d.ts +2 -2
  749. package/dist/types/components/empty-state/bq-empty-state.d.ts +1 -1
  750. package/dist/types/components/icon/bq-icon.d.ts +2 -2
  751. package/dist/types/components/input/bq-input.d.ts +2 -2
  752. package/dist/types/components/notification/bq-notification.d.ts +2 -2
  753. package/dist/types/components/option/bq-option.d.ts +1 -1
  754. package/dist/types/components/option-list/bq-option-list.d.ts +1 -1
  755. package/dist/types/components/panel/bq-panel.d.ts +1 -1
  756. package/dist/types/components/progress/bq-progress.d.ts +1 -1
  757. package/dist/types/components/radio/bq-radio.d.ts +1 -1
  758. package/dist/types/components/radio-group/bq-radio-group.d.ts +2 -2
  759. package/dist/types/components/select/bq-select.d.ts +3 -3
  760. package/dist/types/components/side-menu/bq-side-menu.d.ts +2 -2
  761. package/dist/types/components/side-menu-item/bq-side-menu-item.d.ts +1 -1
  762. package/dist/types/components/slider/bq-slider.d.ts +2 -2
  763. package/dist/types/components/spinner/bq-spinner.d.ts +1 -1
  764. package/dist/types/components/status/bq-status.d.ts +1 -1
  765. package/dist/types/components/step-item/bq-step-item.d.ts +3 -3
  766. package/dist/types/components/steps/bq-steps.d.ts +1 -1
  767. package/dist/types/components/switch/bq-switch.d.ts +2 -2
  768. package/dist/types/components/tab/bq-tab.d.ts +2 -2
  769. package/dist/types/components/tab-group/bq-tab-group.d.ts +2 -2
  770. package/dist/types/components/tag/bq-tag.d.ts +2 -2
  771. package/dist/types/components/textarea/bq-textarea.d.ts +3 -3
  772. package/dist/types/components/toast/bq-toast.d.ts +2 -2
  773. package/dist/types/components/tooltip/bq-tooltip.d.ts +1 -1
  774. package/dist/types/global.d.ts +18 -0
  775. package/dist/types/services/interfaces/floating-ui.d.ts +1 -1
  776. package/dist/types/stencil-public-runtime.d.ts +22 -0
  777. package/package.json +2 -2
  778. package/dist/beeq/p-01b3d2a5.entry.js.map +0 -1
  779. package/dist/beeq/p-07b82e50.js.map +0 -1
  780. package/dist/beeq/p-0ac37ff8.entry.js.map +0 -1
  781. package/dist/beeq/p-115ed5b2.js.map +0 -1
  782. package/dist/beeq/p-1a8f376a.entry.js.map +0 -1
  783. package/dist/beeq/p-1f3a4359.js.map +0 -1
  784. package/dist/beeq/p-22188233.entry.js.map +0 -1
  785. package/dist/beeq/p-24135e46.entry.js.map +0 -1
  786. package/dist/beeq/p-260877e5.entry.js.map +0 -1
  787. package/dist/beeq/p-260d4ca0.js.map +0 -1
  788. package/dist/beeq/p-28adda86.entry.js +0 -6
  789. package/dist/beeq/p-28adda86.entry.js.map +0 -1
  790. package/dist/beeq/p-2b530ad4.js +0 -6
  791. package/dist/beeq/p-2f9fc4d4.entry.js.map +0 -1
  792. package/dist/beeq/p-34f25f24.entry.js.map +0 -1
  793. package/dist/beeq/p-38ee4c02.entry.js +0 -6
  794. package/dist/beeq/p-38ee4c02.entry.js.map +0 -1
  795. package/dist/beeq/p-397bc507.js +0 -6
  796. package/dist/beeq/p-397bc507.js.map +0 -1
  797. package/dist/beeq/p-3f5865c0.entry.js.map +0 -1
  798. package/dist/beeq/p-45800965.js.map +0 -1
  799. package/dist/beeq/p-45bfda93.entry.js.map +0 -1
  800. package/dist/beeq/p-4a5c07f9.js +0 -7
  801. package/dist/beeq/p-4a5c07f9.js.map +0 -1
  802. package/dist/beeq/p-4ddb6bdb.entry.js.map +0 -1
  803. package/dist/beeq/p-6195e6e5.entry.js.map +0 -1
  804. package/dist/beeq/p-63b4f8f9.entry.js.map +0 -1
  805. package/dist/beeq/p-648da701.entry.js.map +0 -1
  806. package/dist/beeq/p-6764f11f.entry.js +0 -6
  807. package/dist/beeq/p-6764f11f.entry.js.map +0 -1
  808. package/dist/beeq/p-7478cf0a.entry.js +0 -6
  809. package/dist/beeq/p-7478cf0a.entry.js.map +0 -1
  810. package/dist/beeq/p-7bb8664c.entry.js.map +0 -1
  811. package/dist/beeq/p-7ff775a3.entry.js.map +0 -1
  812. package/dist/beeq/p-801f7b25.entry.js.map +0 -1
  813. package/dist/beeq/p-852225bc.js +0 -6
  814. package/dist/beeq/p-852225bc.js.map +0 -1
  815. package/dist/beeq/p-8b63d8fc.entry.js.map +0 -1
  816. package/dist/beeq/p-8c011151.entry.js.map +0 -1
  817. package/dist/beeq/p-8d9f797d.entry.js +0 -6
  818. package/dist/beeq/p-8d9f797d.entry.js.map +0 -1
  819. package/dist/beeq/p-9a803ecf.entry.js.map +0 -1
  820. package/dist/beeq/p-9eea4f4f.entry.js.map +0 -1
  821. package/dist/beeq/p-a3c36d6c.entry.js.map +0 -1
  822. package/dist/beeq/p-a620392e.entry.js.map +0 -1
  823. package/dist/beeq/p-a661454e.entry.js.map +0 -1
  824. package/dist/beeq/p-abda6f6c.entry.js.map +0 -1
  825. package/dist/beeq/p-abf83b5c.entry.js.map +0 -1
  826. package/dist/beeq/p-b044c5f6.entry.js.map +0 -1
  827. package/dist/beeq/p-b1ab6b7f.entry.js.map +0 -1
  828. package/dist/beeq/p-b89dcf37.entry.js.map +0 -1
  829. package/dist/beeq/p-ba8b92f1.entry.js.map +0 -1
  830. package/dist/beeq/p-bc1980d8.entry.js.map +0 -1
  831. package/dist/beeq/p-c63ee3df.entry.js.map +0 -1
  832. package/dist/beeq/p-f48c3ca7.entry.js.map +0 -1
  833. package/dist/cjs/app-globals-42eaedec.js.map +0 -1
  834. package/dist/cjs/assetsPath-95e7f5ab.js.map +0 -1
  835. package/dist/cjs/bq-steps.types-4d1836d0.js.map +0 -1
  836. package/dist/cjs/bq-tab.types-a8b320b0.js.map +0 -1
  837. package/dist/cjs/clamp-dbbea7bf.js.map +0 -1
  838. package/dist/cjs/cssVariables-55ad4942.js.map +0 -1
  839. package/dist/cjs/debounce-1f7e1176.js.map +0 -1
  840. package/dist/cjs/event-7d21e426.js.map +0 -1
  841. package/dist/cjs/getNextElement-4b790655.js.map +0 -1
  842. package/dist/cjs/index-30fbd193.js.map +0 -1
  843. package/dist/cjs/index-d734f710.js.map +0 -1
  844. package/dist/cjs/isClient-c22372aa.js.map +0 -1
  845. package/dist/cjs/isDefined-642f676a.js.map +0 -1
  846. package/dist/cjs/isHTMLElement-729e6be0.js.map +0 -1
  847. package/dist/cjs/isNil-f93429a2.js.map +0 -1
  848. package/dist/cjs/isString-f8847c11.js.map +0 -1
  849. package/dist/cjs/props-2653e993.js.map +0 -1
  850. package/dist/cjs/slot-c3eeb29f.js.map +0 -1
  851. package/dist/cjs/transition-be315790.js.map +0 -1
  852. package/dist/components/p-1c8b6eb4.js.map +0 -1
  853. package/dist/components/p-1defeea3.js.map +0 -1
  854. package/dist/components/p-263a1cc6.js.map +0 -1
  855. package/dist/components/p-33faef06.js.map +0 -1
  856. package/dist/components/p-397bc507.js +0 -6
  857. package/dist/components/p-397bc507.js.map +0 -1
  858. package/dist/components/p-46f7e0e3.js.map +0 -1
  859. package/dist/components/p-57621be1.js.map +0 -1
  860. package/dist/components/p-5c61f1f5.js.map +0 -1
  861. package/dist/components/p-6078fd87.js +0 -6
  862. package/dist/components/p-6078fd87.js.map +0 -1
  863. package/dist/components/p-6478d24c.js.map +0 -1
  864. package/dist/components/p-687da041.js.map +0 -1
  865. package/dist/components/p-71751caa.js.map +0 -1
  866. package/dist/components/p-8d04a487.js.map +0 -1
  867. package/dist/components/p-99829fc7.js.map +0 -1
  868. package/dist/components/p-a5dc1c94.js.map +0 -1
  869. package/dist/components/p-a731ba87.js +0 -6
  870. package/dist/components/p-a731ba87.js.map +0 -1
  871. package/dist/components/p-af062402.js.map +0 -1
  872. package/dist/components/p-c3a0bd23.js.map +0 -1
  873. package/dist/components/p-ecd27cf2.js.map +0 -1
  874. package/dist/components/p-f7c2d883.js +0 -6
  875. package/dist/components/p-f7c2d883.js.map +0 -1
  876. package/dist/esm/app-globals-7655df21.js.map +0 -1
  877. package/dist/esm/assetsPath-060da522.js.map +0 -1
  878. package/dist/esm/bq-steps.types-3a84b1e3.js.map +0 -1
  879. package/dist/esm/bq-tab.types-36e2666e.js.map +0 -1
  880. package/dist/esm/clamp-efa6c596.js.map +0 -1
  881. package/dist/esm/cssVariables-3665b51c.js.map +0 -1
  882. package/dist/esm/debounce-3e72f418.js.map +0 -1
  883. package/dist/esm/event-9ce1db79.js.map +0 -1
  884. package/dist/esm/getNextElement-8bcc2025.js.map +0 -1
  885. package/dist/esm/index-46823bdb.js.map +0 -1
  886. package/dist/esm/isClient-c6eae7ba.js.map +0 -1
  887. package/dist/esm/isDefined-8bdbf6b8.js.map +0 -1
  888. package/dist/esm/isHTMLElement-0271eefe.js.map +0 -1
  889. package/dist/esm/isNil-2290f64e.js.map +0 -1
  890. package/dist/esm/isString-9820a2b7.js.map +0 -1
  891. package/dist/esm/props-3bf7f546.js.map +0 -1
  892. package/dist/esm/slot-be230a01.js.map +0 -1
  893. package/dist/esm/transition-916fd7c0.js.map +0 -1
  894. package/dist/loader/package.json +0 -11
  895. package/dist/types/Users/dramos/PROJECTs/ENDAVA/BEEQ-Design-System/packages/beeq/.stencil/packages/beeq/stencil.config.d.ts +0 -2
  896. /package/dist/{beeq/p-57621be1.js.map → components/p-BxgDLPzX.js.map} +0 -0
  897. /package/dist/{beeq/p-1c8b6eb4.js.map → components/p-Dx-CEPSQ.js.map} +0 -0
  898. /package/dist/types/Users/dramos/PROJECTs/ENDAVA/BEEQ-Design-System/{packages/beeq/.stencil → .stencil}/tailwind.config.d.ts +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"names":["NOTIFICATION_TYPE","bqNotificationCss","BqNotificationStyle0","NOTIFICATION_PORTAL_SELECTOR","BqNotification","autoDismissDebounce","bodyElem","footerElem","notificationElem","hasContent","hasFooter","notificationPortal","isClient","document","querySelector","autoDismiss","border","disableClose","hideIcon","open","time","type","handleTimeout","this","cancel","debounce","hide","handleOpenChange","checkPropValues","validatePropValue","el","bqHide","bqShow","bqAfterOpen","bqAfterClose","connectedCallback","Object","assign","createElement","className","componentWillLoad","componentDidLoad","handleSlotChange","afterNotificationClose","removeChild","tagName","toLowerCase","remove","error","DOMException","handleHide","show","handleShow","toast","parentElement","body","append","appendChild","requestAnimationFrame","async","ev","emit","defaultPrevented","leave","handleTransitionEnd","enter","hasSlotContent","iconName","typeMap","success","warning","render","style","h","Host","key","class","hidden","role","ref","div","part","appearance","size","onClick","name","exportparts","onSlotchange"],"sources":["../../packages/beeq/src/components/notification/bq-notification.types.ts","../../packages/beeq/src/components/notification/scss/bq-notification.scss?tag=bq-notification&encapsulation=shadow","../../packages/beeq/src/components/notification/bq-notification.tsx"],"sourcesContent":["export const NOTIFICATION_TYPE = ['error', 'info', 'neutral', 'success', 'warning'] as const;\nexport type TNotificationType = (typeof NOTIFICATION_TYPE)[number];\n\nexport const NOTIFICATION_BORDER_RADIUS = ['none', 'xs2', 'xs', 's', 'm', 'l', 'full'] as const;\nexport type TNotificationBorderRadius = (typeof NOTIFICATION_BORDER_RADIUS)[number];\n","/* -------------------------------------------------------------------------- */\n/* Notification styles */\n/* -------------------------------------------------------------------------- */\n\n@import './bq-notification.variables';\n\n:host {\n @apply block;\n}\n\n:host(.is-hidden) {\n @apply hidden;\n}\n\n.bq-notification {\n @apply relative flex transition-all min-is-[--bq-notification--min-width] p-b-[--bq-notification--padding] p-i-[--bq-notification--padding];\n @apply rounded-[--bq-notification--border-radius] bg-[--bq-notification--background] shadow-[shadow:--bq-notification--box-shadow];\n}\n\n/**\n * Set the notification icon color based on the type value selected\n */\n.notification--icon.color {\n &-error {\n @apply text-[color:--bq-notification--icon-color-error];\n }\n\n &-info {\n @apply text-[color:--bq-notification--icon-color-info];\n }\n\n &-neutral {\n @apply text-[color:--bq-notification--icon-color-neutral];\n }\n\n &-success {\n @apply text-[color:--bq-notification--icon-color-success];\n }\n\n &-warning {\n @apply text-[color:--bq-notification--icon-color-warning];\n }\n}\n\n/**\n * Tweak the close bq-button styles so it remain small without extra padding\n */\n.notification--close::part(button) {\n @apply rounded-s border-0 bs-fit p-b-0 p-i-0;\n}\n\n/**\n * Here we guarantee that if the footer actions are wrapped in a div container from the consumer side,\n * the styles get applied to the that wrapping container directly\n */\n[part='footer'] ::slotted(*) {\n @apply flex items-start gap-xs;\n}\n\n[part='body'],\n[part='footer'] {\n ::slotted(*) {\n @apply block m-bs-m;\n }\n}\n","import { Component, Element, Event, EventEmitter, h, Host, Listen, Method, Prop, State, Watch } from '@stencil/core';\n\nimport { NOTIFICATION_TYPE, TNotificationBorderRadius, TNotificationType } from './bq-notification.types';\nimport { debounce, enter, hasSlotContent, isClient, leave, TDebounce, validatePropValue } from '../../shared/utils';\n\nconst NOTIFICATION_PORTAL_SELECTOR = 'bq-notification-portal';\n\n/**\n * The Notification component is a user interface element used to provide information or alerts to users in a non-intrusive manner.\n *\n * @example How to use it\n * ```html\n * <bq-notification border=\"s\" time=\"3000\" type=\"info\">\n * Title\n * <span slot=\"body\">\n * This is some description text text\n * <a class=\"bq-link\" href=\"https://example.com\">Link</a>\n * </span>\n * <div class=\"flex gap-xs\" slot=\"footer\">\n * <bq-button appearance=\"primary\" size=\"small\">Button</bq-button>\n * <bq-button appearance=\"link\" size=\"small\">Button</bq-button>\n * </div>\n * </bq-notification>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/945cb6-notification\n * @status stable\n *\n * @dependency bq-button\n * @dependency bq-icon\n *\n * @attr {boolean} auto-dismiss - If true, the notification will automatically hide after the specified amount of time\n * @attr {string} border - The corder radius of the notification component\n * @attr {boolean} disable-close - If true, the close button at the top right of the notification won't be shown\n * @attr {boolean} hide-icon - If true, the notification icon won't be shown\n * @attr {boolean} open - If true, the notification will be shown\n * @attr {number} time - The length of time, in milliseconds, after which the notification will close itself. Only valid if `auto-dismiss=\"true\"`\n * @attr {string} type - Type of Notification\n *\n * @event bqAfterClose - Callback handler to be called after the notification has been closed\n * @event bqAfterOpen - Callback handler to be called after the notification has been opened\n * @event bqHide - Callback handler to be called when the notification is hidden\n * @event bqShow - Callback handler to be called when the notification is shown\n *\n * @slot - The notification title content\n * @slot body - The notification description content\n * @slot footer - The notification footer content\n * @slot icon - The icon to be displayed in the notification\n * @slot btn-close - The close button of the notification\n *\n * @part base - The `<div>` container of the predefined bq-icon component.\n * @part body - The container `<div>` that wraps the notification description content\n * @part btn-close - The `bq-button` used to close the notification\n * @part content - The container `<div>` that wraps all the notification content (title, description, footer)\n * @part footer - The container `<div>` that wraps the notification footer content\n * @part icon - The `<bq-icon>` element used to render a predefined icon based on the notification type\n * @part icon-outline - The container `<div>` that wraps the icon element\n * @part main - The container `<div>` that wraps the notification main content (title, description)\n * @part svg - The `<svg>` element of the predefined bq-icon component.\n * @part title - The container `<div>` that wraps the notification title content\n * @part wrapper - The wrapper container `<div>` of the element inside the shadow DOM\n *\n * @cssprop --bq-notification--background - The notification background color\n * @cssprop --bq-notification--box-shadow - The notification box shadow\n * @cssprop --bq-notification--border-color - The notification border color\n * @cssprop --bq-notification--border-radius - The notification border radius\n * @cssprop --bq-notification--border-style - The notification border style\n * @cssprop --bq-notification--border-width - The notification border width\n * @cssprop --bq-notification--content-footer-gap - The notification content and footer gap\n * @cssprop --bq-notification--title-body-gap - The notification title and body gap\n * @cssprop --bq-notification--icon-color-error - The notification icon color for error type\n * @cssprop --bq-notification--icon-color-info - The notification icon color for info type\n * @cssprop --bq-notification--icon-color-neutral - The notification icon color for neutral type\n * @cssprop --bq-notification--icon-color-success - The notification icon color for success type\n * @cssprop --bq-notification--icon-color-warning - The notification icon color for warning type\n * @cssprop --bq-notification--padding - The notification padding\n * @cssprop --bq-notification--min-width - The notification min width\n */\n@Component({\n tag: 'bq-notification',\n styleUrl: './scss/bq-notification.scss',\n shadow: true,\n})\nexport class BqNotification {\n // Own Properties\n // ====================\n\n private autoDismissDebounce: TDebounce<void>;\n private bodyElem: HTMLDivElement;\n private footerElem: HTMLDivElement;\n private notificationElem: HTMLDivElement;\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqNotificationElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n @State() private hasContent = false;\n @State() private hasFooter = false;\n @State() private notificationPortal = isClient() ? document.querySelector(`.${NOTIFICATION_PORTAL_SELECTOR}`) : null;\n\n // Public Property API\n // ========================\n\n /** If true, the notification will automatically hide after the specified amount of time */\n @Prop({ reflect: true }) autoDismiss: boolean;\n\n /** The corder radius of the notification component */\n @Prop({ reflect: true }) border: TNotificationBorderRadius = 's';\n\n /** If true, the close button at the top right of the notification won't be shown */\n @Prop({ reflect: true }) disableClose: boolean;\n\n /** If true, the notification icon won't be shown */\n @Prop({ reflect: true }) hideIcon: boolean;\n\n /** If true, the notification will be shown */\n @Prop({ reflect: true, mutable: true }) open: boolean;\n\n /** The length of time, in milliseconds, after which the notification will close itself. Only valid if `autoDismiss=\"true\"` */\n @Prop({ reflect: true }) time: number = 3000;\n\n /** Type of Notification */\n @Prop({ reflect: true }) type: TNotificationType = 'info';\n\n // Prop lifecycle events\n // =======================\n @Watch('autoDismiss')\n @Watch('time')\n handleTimeout() {\n this.autoDismissDebounce?.cancel();\n if (!this.autoDismiss) return;\n\n this.autoDismissDebounce = debounce(() => {\n this.hide();\n }, this.time);\n // Make sure to autodismiss the notification if the `auto-dismiss` value changed while open\n if (this.open) this.autoDismissDebounce();\n }\n\n @Watch('open')\n handleOpenChange() {\n this.autoDismissDebounce?.cancel();\n\n if (!(this.autoDismiss && this.open)) return;\n this.autoDismissDebounce();\n }\n\n @Watch('type')\n checkPropValues() {\n validatePropValue(NOTIFICATION_TYPE, 'info', this.el, 'type');\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n /** Callback handler to be called when the notification is hidden */\n @Event() bqHide!: EventEmitter;\n\n /** Callback handler to be called when the notification is shown */\n @Event() bqShow!: EventEmitter;\n\n /** Callback handler to be called after the notification has been opened */\n @Event() bqAfterOpen!: EventEmitter;\n\n /** Callback handler to be called after the notification has been closed */\n @Event() bqAfterClose!: EventEmitter;\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n connectedCallback() {\n if (!isClient()) return;\n\n const { notificationPortal } = this;\n if (!notificationPortal) {\n this.notificationPortal = Object.assign(document.createElement('div'), {\n className: NOTIFICATION_PORTAL_SELECTOR,\n });\n }\n }\n\n componentWillLoad() {\n this.checkPropValues();\n this.handleTimeout();\n }\n\n componentDidLoad() {\n this.handleSlotChange();\n }\n\n // Listeners\n // ==============\n\n @Listen('bqAfterClose')\n afterNotificationClose() {\n try {\n const { notificationPortal } = this;\n notificationPortal.removeChild(this.el);\n // Remove the notification portal from the DOM when there are no more notifications\n if (notificationPortal.querySelector(this.el.tagName.toLowerCase()) === null) {\n notificationPortal.remove();\n }\n } catch (error) {\n /**\n * Skip DOMException error since it could be possible that\n * in some situations the notification portal is missing\n */\n if (error instanceof DOMException) return;\n throw error;\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 /** Method to be called to hide the notification component */\n @Method()\n async hide(): Promise<void> {\n await this.handleHide();\n }\n\n /** Method to be called to show the notification component */\n @Method()\n async show(): Promise<void> {\n await this.handleShow();\n }\n\n /** This method can be used to display notifications in a fixed-position element that allows for stacking multiple notifications vertically */\n @Method()\n async toast() {\n if (!isClient()) return;\n\n const { notificationPortal } = this;\n if (notificationPortal?.parentElement === null) {\n document.body.append(notificationPortal);\n }\n\n notificationPortal?.appendChild(this.el);\n requestAnimationFrame(() => {\n this.show();\n });\n }\n\n // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n private handleHide = async () => {\n const ev = this.bqHide.emit(this.el);\n if (!ev.defaultPrevented) {\n await leave(this.notificationElem);\n this.open = false;\n this.handleTransitionEnd();\n }\n };\n\n private handleShow = async () => {\n const ev = this.bqShow.emit(this.el);\n if (!ev.defaultPrevented) {\n this.open = true;\n await enter(this.notificationElem);\n this.handleTransitionEnd();\n }\n };\n\n private handleTransitionEnd = () => {\n if (this.open) {\n this.bqAfterOpen.emit();\n return;\n }\n\n this.bqAfterClose.emit();\n };\n\n private handleSlotChange = () => {\n this.hasContent = hasSlotContent(this.bodyElem);\n this.hasFooter = hasSlotContent(this.footerElem, 'footer');\n };\n\n private get iconName(): string {\n const typeMap = {\n error: 'x-circle',\n success: 'check-circle',\n warning: 'warning-circle',\n };\n\n return typeMap[this.type] || 'info';\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n const style = {\n ...(this.border && { '--bq-notification--border-radius': `var(--bq-radius--${this.border})` }),\n };\n\n return (\n <Host\n style={style}\n class={{ 'is-hidden': !this.open }}\n aria-hidden={!this.open ? 'true' : 'false'}\n hidden={!this.open ? 'true' : 'false'}\n role=\"alert\"\n >\n <div\n class=\"bq-notification\"\n data-transition-enter=\"transform transition ease-out duration-300\"\n data-transition-enter-start=\"translate-y-xs opacity-0 sm:translate-y-0 sm:translate-x-s\"\n data-transition-enter-end=\"translate-y-0 opacity-100 sm:translate-x-0\"\n data-transition-leave=\"transform transition ease-in duration-100\"\n data-transition-leave-start=\"translate-y-0 opacity-100 sm:translate-x-0\"\n data-transition-leave-end=\"-translate-y-xs opacity-0 sm:translate-y-0 sm:translate-x-s\"\n ref={(div) => (this.notificationElem = div)}\n part=\"wrapper\"\n >\n {/* CLOSE BUTTON */}\n {!this.disableClose && (\n <bq-button\n class=\"notification--close absolute inset-ie-5 [&::part(label)]:inline-flex\"\n appearance=\"text\"\n size=\"small\"\n onClick={() => this.hide()}\n part=\"btn-close\"\n >\n <slot name=\"btn-close\">\n <bq-icon name=\"x\" />\n </slot>\n </bq-button>\n )}\n {/* ICON */}\n <div\n class={{\n '!hidden': this.hideIcon,\n [`color-${this.type}`]: true, // The icon color will be based on the type (info, success, warning, error)\n 'notification--icon me-xs flex text-left align-top': true,\n }}\n part=\"icon-outline\"\n >\n <slot name=\"icon\">\n <bq-icon name={this.iconName} part=\"icon\" exportparts=\"base,svg\" />\n </slot>\n </div>\n {/* MAIN */}\n <div class=\"flex flex-col items-start gap-[--bq-notification--content-footer-gap]\" part=\"main\">\n <div class=\"flex flex-col gap-[--bq-notification--title-body-gap]\" part=\"content\">\n {/* TITLE */}\n <div class=\"title-font font-semibold leading-regular\" part=\"title\">\n <slot />\n </div>\n {/* BODY */}\n <div\n class={{ 'text-s leading-regular': true, '!hidden': !this.hasContent }}\n ref={(div) => (this.bodyElem = div)}\n part=\"body\"\n >\n <slot name=\"body\" onSlotchange={this.handleSlotChange} />\n </div>\n </div>\n {/* FOOTER */}\n <div\n class={{ 'flex items-start gap-xs': true, '!hidden': !this.hasFooter }}\n ref={(div) => (this.footerElem = div)}\n part=\"footer\"\n >\n <slot name=\"footer\" onSlotchange={this.handleSlotChange} />\n </div>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["bqBreadcrumbCss","BqBreadcrumbStyle0","BqBreadcrumb","navElem","spanElem","label","componentDidLoad","this","handleSlotChange","breadcrumbItems","itemCount","length","separatorElem","getSeparatorElem","forEach","item","index","isLastItem","separatorSlot","querySelector","append","cloneNode","setAttribute","clone","separatorFromSlot","slot","assignedElements","flatten","render","h","Host","key","class","ref","elem","part","onSlotchange","hidden","element","name"],"sources":["../../packages/beeq/src/components/breadcrumb/scss/bq-breadcrumb.scss?tag=bq-breadcrumb&encapsulation=shadow","../../packages/beeq/src/components/breadcrumb/bq-breadcrumb.tsx"],"sourcesContent":["/* -------------------------------------------------------------------------- */\n/* Breadcrumb styles */\n/* -------------------------------------------------------------------------- */\n\n:host {\n @apply block;\n}\n","import { Component, Element, h, Host, Prop } from '@stencil/core';\n\n/**\n * The Breadcrumb is used to wraps a series of breadcrumb items to indicate the current page's location within a navigational hierarchy.\n *\n * @example How to use it\n * ```html\n * <bq-breadcrumb label=\"Breadcrumb\">\n * <bq-breadcrumb-item>Home</bq-breadcrumb-item>\n * <bq-breadcrumb-item>Men's clothing</bq-breadcrumb-item>\n * <bq-breadcrumb-item>Shirt</bq-breadcrumb-item>\n * <bq-breadcrumb-item>Casual shirts</bq-breadcrumb-item>\n * </bq-breadcrumb>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/194fd1-breadcrumb\n * @status stable\n *\n * @attr {string} label - The `aria-label` attribute to describe the type of navigation\n *\n * @slot - The default slot is used to add `bq-breadcrumb-item` items to the breadcrumb.\n * @slot separator - The slot to add a separator between breadcrumb items. Default separator is `/`.\n *\n * @part navigation - The `nav` tag that loads the breadcrumb items\n * @part separator - The container that wraps the separator element\n */\n@Component({\n tag: 'bq-breadcrumb',\n styleUrl: './scss/bq-breadcrumb.scss',\n shadow: true,\n})\nexport class BqBreadcrumb {\n // Own Properties\n // ====================\n\n private navElem: HTMLElement;\n private spanElem: HTMLElement;\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqBreadcrumbElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n // Public Property API\n // ========================\n\n /** The `aria-label` attribute to describe the type of navigation */\n @Prop({ reflect: true }) label: string = 'Breadcrumbs';\n\n // Prop lifecycle events\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 this.handleSlotChange();\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 handleSlotChange = (): void => {\n const breadcrumbItems = this.breadcrumbItems;\n const itemCount = breadcrumbItems.length;\n const separatorElem = this.getSeparatorElem();\n\n breadcrumbItems.forEach((item, index) => {\n const isLastItem = index === itemCount - 1;\n const separatorSlot = item.querySelector('[slot=\"separator\"]');\n\n if (!separatorSlot && !isLastItem) {\n item.append(separatorElem.cloneNode(true));\n }\n\n item.setAttribute('aria-current', isLastItem ? 'page' : '');\n });\n };\n\n private getSeparatorElem = (): HTMLElement => {\n const clone = this.separatorFromSlot.cloneNode(true) as HTMLElement;\n clone.slot = 'separator';\n\n return clone;\n };\n\n private get separatorFromSlot() {\n return this.spanElem\n .querySelector<HTMLSlotElement>('slot[name=\"separator\"]')\n .assignedElements({ flatten: true })[0] as HTMLElement;\n }\n\n private get breadcrumbItems(): HTMLBqBreadcrumbItemElement[] {\n return this.navElem\n .querySelector<HTMLSlotElement>('slot')\n .assignedElements({ flatten: true }) as HTMLBqBreadcrumbItemElement[];\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <Host>\n <nav class=\"flex items-center\" aria-label={this.label} ref={(elem) => (this.navElem = elem)} part=\"navigation\">\n <slot onSlotchange={this.handleSlotChange}></slot>\n </nav>\n <span hidden aria-hidden=\"true\" ref={(element) => (this.spanElem = element)} part=\"separator\">\n <slot name=\"separator\">\n <span class=\"flex items-center justify-center is-3\">/</span>\n </slot>\n </span>\n </Host>\n );\n }\n}\n"],"mappings":";;;;yDAAA,MAAMA,EAAkB,g0lBACxB,MAAAC,EAAeD,E,MC8BFE,EAAY,M,yBAIfC,QACAC,S,wBAeiBC,MAAgB,cAazC,gBAAAC,GACEC,KAAKC,kB,CAkBCA,iBAAmB,KACzB,MAAMC,EAAkBF,KAAKE,gBAC7B,MAAMC,EAAYD,EAAgBE,OAClC,MAAMC,EAAgBL,KAAKM,mBAE3BJ,EAAgBK,SAAQ,CAACC,EAAMC,KAC7B,MAAMC,EAAaD,IAAUN,EAAY,EACzC,MAAMQ,EAAgBH,EAAKI,cAAc,sBAEzC,IAAKD,IAAkBD,EAAY,CACjCF,EAAKK,OAAOR,EAAcS,UAAU,M,CAGtCN,EAAKO,aAAa,eAAgBL,EAAa,OAAS,GAAG,GAC3D,EAGIJ,iBAAmB,KACzB,MAAMU,EAAQhB,KAAKiB,kBAAkBH,UAAU,MAC/CE,EAAME,KAAO,YAEb,OAAOF,CAAK,EAGd,qBAAYC,GACV,OAAOjB,KAAKH,SACTe,cAA+B,0BAC/BO,iBAAiB,CAAEC,QAAS,OAAQ,E,CAGzC,mBAAYlB,GACV,OAAOF,KAAKJ,QACTgB,cAA+B,QAC/BO,iBAAiB,CAAEC,QAAS,M,CAOjC,MAAAC,GACE,OACEC,EAACC,EAAI,CAAAC,IAAA,4CACHF,EAAA,OAAAE,IAAA,2CAAKC,MAAM,oBAAmB,aAAazB,KAAKF,MAAO4B,IAAMC,GAAU3B,KAAKJ,QAAU+B,EAAOC,KAAK,cAChGN,EAAA,QAAAE,IAAA,2CAAMK,aAAc7B,KAAKC,oBAE3BqB,EAAA,QAAAE,IAAA,2CAAMM,OAAM,mBAAa,OAAOJ,IAAMK,GAAa/B,KAAKH,SAAWkC,EAAUH,KAAK,aAChFN,EAAA,QAAAE,IAAA,2CAAMQ,KAAK,aACTV,EAAA,QAAAE,IAAA,2CAAMC,MAAM,yCAAuC,O","ignoreList":[]}
@@ -1,6 +0,0 @@
1
- /*!
2
- * Built by Endavans
3
- * © https://beeq.design - Apache 2 License.
4
- */
5
- import{r as a,c as r,g as e,h as b}from"./p-4a5c07f9.js";import{d as t}from"./p-1defeea3.js";import{i as n}from"./p-57621be1.js";import{i}from"./p-99829fc7.js";import{b as q}from"./p-260d4ca0.js";const o='.transform{--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}::backdrop,:root{--bq-blue-100:#e7f0fd;--bq-blue-200:#d0e2fb;--bq-blue-300:#a1c5f7;--bq-blue-400:#73a8f3;--bq-blue-500:#448bef;--bq-blue-600:#156eeb;--bq-blue-700:#1158bc;--bq-blue-800:#0d428d;--bq-blue-900:#082c5e;--bq-blue-1000:#04162f;--bq-corai-100:#fff2f2;--bq-corai-200:#ffe6e6;--bq-corai-300:#ffccce;--bq-corai-400:#ffb3b5;--bq-corai-500:#ff999d;--bq-corai-600:#ff8084;--bq-corai-700:#cc666a;--bq-corai-800:#994d4f;--bq-corai-900:#663335;--bq-corai-1000:#331a1a;--bq-cyan-100:#e8f7fb;--bq-cyan-200:#d2f0f8;--bq-cyan-300:#a5e1f1;--bq-cyan-400:#78d1e9;--bq-cyan-500:#4bc2e2;--bq-cyan-600:#1eb3db;--bq-cyan-700:#188faf;--bq-cyan-800:#126b83;--bq-cyan-900:#0c4858;--bq-cyan-1000:#06242c;--bq-gold-100:#fbf4ec;--bq-gold-200:#f7e9da;--bq-gold-300:#f0d3b6;--bq-gold-400:#e8bc91;--bq-gold-500:#e1a66d;--bq-gold-600:#d99048;--bq-gold-700:#ae733a;--bq-gold-800:#82562b;--bq-gold-900:#573a1d;--bq-gold-1000:#2b1d0e;--bq-green-100:#e8f8ef;--bq-green-200:#d2f1e0;--bq-green-300:#a5e3c1;--bq-green-400:#78d5a1;--bq-green-500:#4bc782;--bq-green-600:#1eb963;--bq-green-700:#18944f;--bq-green-800:#126f3b;--bq-green-900:#0c4a28;--bq-green-1000:#062514;--bq-grey-100:#f1f2f4;--bq-grey-200:#e7e8eb;--bq-grey-300:#caccd2;--bq-grey-400:#a6aab3;--bq-grey-50:#f6f6f8;--bq-grey-500:#898e99;--bq-grey-600:#646a77;--bq-grey-700:#3f4350;--bq-grey-800:#2a2c35;--bq-grey-900:#1c1d23;--bq-grey-950:#15161a;--bq-grey-1000:#0d0e11;--bq-indigo-100:#edecfc;--bq-indigo-200:#dcdafa;--bq-indigo-300:#b9b5f5;--bq-indigo-400:#9590ef;--bq-indigo-500:#726bea;--bq-indigo-600:#4f46e5;--bq-indigo-700:#3f38b7;--bq-indigo-800:#2f2a89;--bq-indigo-900:#201c5c;--bq-indigo-1000:#100e2e;--bq-iris-100:#e9f0ff;--bq-iris-200:#d6e0ff;--bq-iris-300:#b2c0fe;--bq-iris-400:#8691f8;--bq-iris-500:#6061ee;--bq-iris-600:#4f46e5;--bq-iris-700:#413abd;--bq-iris-800:#332e95;--bq-iris-900:#26216d;--bq-iris-1000:#181545;--bq-lime-100:#f5fae8;--bq-lime-200:#ecf6d2;--bq-lime-300:#d9eda5;--bq-lime-400:#c5e379;--bq-lime-500:#b2da4c;--bq-lime-600:#9fd11f;--bq-lime-700:#7fa719;--bq-lime-800:#5f7d13;--bq-lime-900:#40540c;--bq-lime-1000:#202a06;--bq-magenta-100:#fce7f4;--bq-magenta-200:#f9cfea;--bq-magenta-300:#f39fd6;--bq-magenta-400:#ee6fbf;--bq-magenta-500:#e83fab;--bq-magenta-600:#de1395;--bq-magenta-700:#b20f77;--bq-magenta-800:#850c59;--bq-magenta-900:#58083c;--bq-magenta-1000:#2c041e;--bq-neutral-white:#fbfbfc;--bq-neutral-black:#060708;--bq-orange-100:#fbf0e9;--bq-orange-200:#f8e1d4;--bq-orange-300:#f1c2a8;--bq-orange-400:#eaa47d;--bq-orange-500:#e38551;--bq-orange-600:#dc6726;--bq-orange-700:#b0521e;--bq-orange-800:#843e17;--bq-orange-900:#58290f;--bq-orange-1000:#2c1508;--bq-purple-100:#efebf8;--bq-purple-200:#e0d7f2;--bq-purple-300:#c1afe5;--bq-purple-400:#a388d8;--bq-purple-500:#8460cb;--bq-purple-600:#6538be;--bq-purple-700:#512d98;--bq-purple-800:#3d2272;--bq-purple-900:#28164c;--bq-purple-1000:#140b26;--bq-red-100:#fce7ea;--bq-red-200:#f9d1d5;--bq-red-300:#f3a2ac;--bq-red-400:#ed7482;--bq-red-500:#e74559;--bq-red-600:#e1172f;--bq-red-700:#b41226;--bq-red-800:#870e1c;--bq-red-900:#5a0913;--bq-red-1000:#2d0509;--bq-sky-100:#eff4fb;--bq-sky-200:#dfeaf8;--bq-sky-300:#bfd5f1;--bq-sky-400:#9ec1e9;--bq-sky-500:#7eace2;--bq-sky-600:#5e97db;--bq-sky-700:#4b79af;--bq-sky-800:#385b83;--bq-sky-900:#263c58;--bq-sky-1000:#131e2c;--bq-teal-100:#e5f7f5;--bq-teal-200:#ccf0eb;--bq-teal-300:#99e1d8;--bq-teal-400:#66d2c4;--bq-teal-500:#33c3b1;--bq-teal-600:#00b49d;--bq-teal-700:#00907e;--bq-teal-800:#006c5e;--bq-teal-900:#00483f;--bq-teal-1000:#00241f;--bq-volcano-100:#feede7;--bq-volcano-200:#fddbd1;--bq-volcano-300:#fbb8a3;--bq-volcano-400:#fa9474;--bq-volcano-500:#f87146;--bq-volcano-600:#f64d18;--bq-volcano-700:#c53e13;--bq-volcano-800:#942e0e;--bq-volcano-900:#621f0a;--bq-volcano-1000:#310f05;--bq-yellow-100:#fefbe7;--bq-yellow-200:#fcf6d0;--bq-yellow-300:#faeea0;--bq-yellow-400:#f7e571;--bq-yellow-500:#f5dd41;--bq-yellow-600:#f2d412;--bq-yellow-700:#c2aa0e;--bq-yellow-800:#917f0b;--bq-yellow-900:#615507;--bq-yellow-1000:#302a04;--bq-endava-grey-50:#f7f7f8;--bq-endava-grey-100:#e4e6e7;--bq-endava-grey-200:#b5babe;--bq-endava-grey-300:#949ca1;--bq-endava-grey-400:#737d84;--bq-endava-grey-500:#525f67;--bq-endava-grey-600:#30404b;--bq-endava-grey-700:#2b3942;--bq-endava-grey-800:#263139;--bq-endava-grey-900:#192b37;--bq-endava-grey-950:#151b1e;--bq-endava-grey-1000:#0f1316;--bq-endava-neutral-white:#fafbfb;--bq-endava-neutral-black:#060708;--bq-endava-orange-100:#fef3f1;--bq-endava-orange-200:#fbd6d1;--bq-endava-orange-300:#fab7af;--bq-endava-orange-400:#fa988b;--bq-endava-orange-500:#fc7866;--bq-endava-orange-600:#ff5640;--bq-endava-orange-700:#ce4a39;--bq-endava-orange-800:#a03d30;--bq-endava-orange-900:#722e25;--bq-endava-orange-1000:#471e19}*,:after,:before{box-sizing:border-box}*{font:inherit;margin:0}ol[role=list],ul[role=list]{list-style-type:none}html{font-size:var(--bq-font-size--m)}html:focus-within{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bq-background--primary);color:var(--bq-text--primary);font-family:var(--bq-font-family);line-height:var(--bq-font-line-height--regular);min-height:100vh;text-rendering:optimizeSpeed}a:not([class]){text-decoration-skip-ink:auto}canvas,img,picture,svg,video{display:block;max-width:100%}button,input,select,textarea{font:inherit}h1,h2,h3,h4,h5,h6,p{overflow-wrap:break-word}@media (prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto;transition-duration:.01ms!important}}:root{--bq-white:#fff;--bq-black:#060708;--bq-neutral-50:var(--bq-grey-50);--bq-neutral-100:var(--bq-grey-100);--bq-neutral-200:var(--bq-grey-200);--bq-neutral-300:var(--bq-grey-300);--bq-neutral-400:var(--bq-grey-400);--bq-neutral-500:var(--bq-grey-500);--bq-neutral-600:var(--bq-grey-600);--bq-neutral-700:var(--bq-grey-700);--bq-neutral-800:var(--bq-grey-800);--bq-neutral-900:var(--bq-grey-900);--bq-neutral-950:var(--bq-grey-950);--bq-neutral-1000:var(--bq-grey-1000);--bq-brand-light:var(--bq-iris-100);--bq-brand:var(--bq-iris-600);--bq-brand-dark:var(--bq-iris-1000);--bq-accent-light:var(--bq-purple-100);--bq-accent:var(--bq-purple-600);--bq-accent-dark:var(--bq-purple-1000);--bq-success-light:var(--bq-teal-100);--bq-success:var(--bq-teal-600);--bq-success-dark:var(--bq-teal-1000);--bq-danger-light:var(--bq-red-100);--bq-danger:var(--bq-red-600);--bq-danger-dark:var(--bq-red-1000);--bq-warning-light:var(--bq-gold-100);--bq-warning:var(--bq-gold-600);--bq-warning-dark:var(--bq-gold-1000);--bq-info-light:var(--bq-iris-100);--bq-info:var(--bq-iris-600);--bq-info-dark:var(--bq-iris-1000);--bq-focus:var(--bq-iris-600);--bq-data-01:var(--bq-brand);--bq-data-02:var(--bq-purple-600);--bq-data-03:var(--bq-magenta-600);--bq-data-04:var(--bq-cyan-600);--bq-data-05:var(--bq-teal-600);--bq-data-06:var(--bq-orange-600);--bq-data-07:var(--bq-yellow-600);--bq-data-08:var(--bq-red-600);--bq-data-09:var(--bq-blue-600);--bq-data-10:var(--bq-grey-600);--bq-data-11:var(--bq-black);--bq-data-12:var(--bq-white);--bq-radius--none:0;--bq-radius--xs2:0.125rem;--bq-radius--xs:0.25rem;--bq-radius--s:0.5rem;--bq-radius--m:0.75rem;--bq-radius--l:1.5rem;--bq-radius--full:9999px;--bq-box-shadow--xs:0 2px 0 rgba(0,0,0,.016);--bq-box-shadow--s:0 8px 24px rgba(0,0,0,.04);--bq-box-shadow--m:0 10px 48px -16px rgba(0,0,0,.12);--bq-box-shadow--l:0 20px 58px -16px rgba(0,0,0,.16);--bq-font-family:"Outfit",sans-serif;--bq-font-size--xs:0.75rem;--bq-font-size--s:0.875rem;--bq-font-size--m:1rem;--bq-font-size--l:1.125rem;--bq-font-size--xl:1.5rem;--bq-font-size--xxl:2rem;--bq-font-size--xxl2:2.5rem;--bq-font-size--xxl3:3rem;--bq-font-size--xxl4:3.5rem;--bq-font-size--xxl5:4rem;--bq-font-weight--thin:100;--bq-font-weight--light:300;--bq-font-weight--regular:400;--bq-font-weight--medium:500;--bq-font-weight--semibold:600;--bq-font-weight--bold:700;--bq-font-line-height--small:1.2;--bq-font-line-height--regular:1.5;--bq-font-line-height--large:1.5;--bq-spacing-xs3:0.125rem;--bq-spacing-xs2:0.25rem;--bq-spacing-xs:0.5rem;--bq-spacing-s:0.75rem;--bq-spacing-m:1rem;--bq-spacing-l:1.5rem;--bq-spacing-xl:2rem;--bq-spacing-xxl:2.5rem;--bq-spacing-xxl2:3.5rem;--bq-spacing-xxl3:4rem;--bq-spacing-xxl4:4.5rem;--bq-stroke-s:1px;--bq-stroke-m:2px;--bq-stroke-l:3px}.beeq.light,.light,:root,[bq-mode=light]{--bq-background--primary:var(--bq-white);--bq-background--secondary:var(--bq-neutral-100);--bq-background--tertiary:var(--bq-neutral-200);--bq-background--alt:var(--bq-neutral-300);--bq-background--inverse:var(--bq-neutral-900);--bq-background--brand:var(--bq-brand);--bq-background--overlay:var(--bq-neutral-900);--bq-icon--primary:var(--bq-neutral-800);--bq-icon--alt:var(--bq-white);--bq-icon--secondary:var(--bq-neutral-600);--bq-icon--inverse:var(--bq-neutral-50);--bq-icon--brand:var(--bq-brand);--bq-icon--info:var(--bq-brand);--bq-icon--success:var(--bq-success);--bq-icon--warning:var(--bq-warning);--bq-icon--danger:var(--bq-danger);--bq-stroke--primary:var(--bq-neutral-200);--bq-stroke--secondary:var(--bq-neutral-600);--bq-stroke--tertiary:var(--bq-neutral-900);--bq-stroke--inverse:var(--bq-white);--bq-stroke--brand:var(--bq-brand);--bq-stroke--alt:var(--bq-neutral-50);--bq-stroke--success:var(--bq-success);--bq-stroke--warning:var(--bq-warning);--bq-stroke--danger:var(--bq-danger);--bq-stroke--info:var(--bq-brand);--bq-text--primary:var(--bq-neutral-800);--bq-text--secondary:var(--bq-neutral-600);--bq-text--inverse:var(--bq-neutral-50);--bq-text--brand:var(--bq-brand);--bq-text--alt:var(--bq-white);--bq-text--info:var(--bq-brand);--bq-text--success:var(--bq-success);--bq-text--warning:var(--bq-warning);--bq-text--danger:var(--bq-danger);--bq-ui--primary:var(--bq-white);--bq-ui--secondary:var(--bq-neutral-200);--bq-ui--tertiary:var(--bq-neutral-500);--bq-ui--inverse:var(--bq-neutral-900);--bq-ui--brand:var(--bq-brand);--bq-ui--brand-alt:var(--bq-brand-light);--bq-ui--alt:var(--bq-neutral-50);--bq-ui--success:var(--bq-success);--bq-ui--success-alt:var(--bq-success-light);--bq-ui--warning:var(--bq-warning);--bq-ui--warning-alt:var(--bq-warning-light);--bq-ui--danger:var(--bq-danger);--bq-ui--danger-alt:var(--bq-danger-light);--bq-ui--info:var(--bq-brand);--bq-ui--info-alt:var(--bq-brand-light);--bq-hover:#bcbfc5;--bq-active:#444546}.beeq.dark,.dark,[bq-mode=dark]{--bq-background--primary:var(--bq-neutral-1000);--bq-background--secondary:var(--bq-neutral-950);--bq-background--tertiary:var(--bq-neutral-800);--bq-background--alt:var(--bq-neutral-700);--bq-background--inverse:var(--bq-neutral-600);--bq-background--brand:var(--bq-brand);--bq-background--overlay:var(--bq-neutral-900);--bq-icon--primary:var(--bq-neutral-100);--bq-icon--secondary:var(--bq-neutral-400);--bq-icon--inverse:var(--bq-neutral-800);--bq-icon--brand:var(--bq-brand);--bq-icon--alt:var(--bq-white);--bq-icon--info:var(--bq-brand);--bq-icon--success:var(--bq-success);--bq-icon--warning:var(--bq-warning);--bq-icon--danger:var(--bq-danger);--bq-stroke--primary:var(--bq-neutral-900);--bq-stroke--secondary:var(--bq-neutral-700);--bq-stroke--tertiary:var(--bq-neutral-400);--bq-stroke--inverse:var(--bq-neutral-950);--bq-stroke--brand:var(--bq-brand);--bq-stroke--alt:var(--bq-neutral-1000);--bq-stroke--success:var(--bq-success);--bq-stroke--warning:var(--bq-warning);--bq-stroke--danger:var(--bq-danger);--bq-stroke--info:var(--bq-brand);--bq-text--primary:var(--bq-neutral-100);--bq-text--secondary:var(--bq-neutral-400);--bq-text--inverse:var(--bq-neutral-800);--bq-text--brand:var(--bq-brand);--bq-text--alt:var(--bq-white);--bq-text--info:var(--bq-brand);--bq-text--success:var(--bq-success);--bq-text--warning:var(--bq-warning);--bq-text--danger:var(--bq-danger);--bq-ui--primary:var(--bq-neutral-900);--bq-ui--secondary:var(--bq-neutral-800);--bq-ui--tertiary:var(--bq-neutral-700);--bq-ui--inverse:var(--bq-neutral-100);--bq-ui--brand:var(--bq-brand);--bq-ui--brand-alt:var(--bq-brand-dark);--bq-ui--alt:var(--bq-neutral-950);--bq-ui--success:var(--bq-success);--bq-ui--success-alt:var(--bq-success-dark);--bq-ui--warning:var(--bq-warning);--bq-ui--warning-alt:var(--bq-warning-dark);--bq-ui--danger:var(--bq-danger);--bq-ui--danger-alt:var(--bq-danger-dark);--bq-ui--info:var(--bq-brand);--bq-ui--info-alt:var(--bq-brand-dark);--bq-hover:#444546;--bq-active:#1f2026}.endava,[bq-theme=endava]{--bq-font-family:"Poppins",sans-serif;--bq-white:#fafbfb;--bq-black:#030406;--bq-neutral-50:var(--bq-endava-grey-50);--bq-neutral-100:var(--bq-endava-grey-100);--bq-neutral-200:var(--bq-endava-grey-200);--bq-neutral-300:var(--bq-endava-grey-300);--bq-neutral-400:var(--bq-endava-grey-400);--bq-neutral-500:var(--bq-endava-grey-500);--bq-neutral-600:var(--bq-endava-grey-600);--bq-neutral-700:var(--bq-endava-grey-700);--bq-neutral-800:var(--bq-endava-grey-800);--bq-neutral-900:var(--bq-endava-grey-900);--bq-neutral-950:var(--bq-endava-grey-950);--bq-neutral-1000:var(--bq-endava-grey-1000);--bq-brand-light:var(--bq-endava-orange-100);--bq-brand:var(--bq-endava-orange-600);--bq-brand-dark:var(--bq-endava-orange-1000);--bq-accent-light:var(--bq-endava-orange-100);--bq-accent:var(--bq-endava-orange-600);--bq-accent-dark:var(--bq-endava-orange-1000);--bq-success-light:var(--bq-green-100);--bq-success:var(--bq-green-600);--bq-success-dark:var(--bq-green-1000);--bq-danger-light:var(--bq-corai-100);--bq-danger:var(--bq-corai-600);--bq-danger-dark:var(--bq-corai-1000);--bq-warning-light:var(--bq-yellow-100);--bq-warning:var(--bq-yellow-600);--bq-warning-dark:var(--bq-yellow-1000);--bq-info-light:var(--bq-blue-100);--bq-info:var(--bq-blue-600);--bq-info-dark:var(--bq-blue-1000);--bq-focus:var(--bq-endava-orange-600);--bq-data-01:var(--bq-brand);--bq-data-02:#af0cd8;--bq-data-03:#0ca8d8;--bq-data-04:var(--bq-teal-600);--bq-data-05:var(--bq-yellow-600);--bq-data-06:var(--bq-orange-600);--bq-data-07:var(--bq-blue-600);--bq-data-08:var(--bq-red-600);--bq-data-09:var(--bq-purple-600);--bq-data-10:#394b56;--bq-data-11:var(--bq-black);--bq-data-12:var(--bq-white)}.endava.light,[bq-theme=endava][bq-mode=light]{--bq-background--primary:var(--bq-white);--bq-background--secondary:var(--bq-neutral-100);--bq-background--tertiary:var(--bq-neutral-200);--bq-background--alt:var(--bq-neutral-300);--bq-background--inverse:var(--bq-neutral-900);--bq-background--brand:var(--bq-brand);--bq-background--overlay:var(--bq-neutral-900);--bq-icon--primary:var(--bq-neutral-800);--bq-icon--secondary:var(--bq-neutral-600);--bq-icon--inverse:var(--bq-neutral-50);--bq-icon--brand:var(--bq-brand);--bq-icon--alt:var(--bq-white);--bq-icon--info:var(--bq-info);--bq-icon--success:var(--bq-success);--bq-icon--warning:var(--bq-warning);--bq-icon--danger:var(--bq-danger);--bq-stroke--primary:var(--bq-neutral-200);--bq-stroke--secondary:var(--bq-neutral-600);--bq-stroke--tertiary:var(--bq-neutral-900);--bq-stroke--inverse:var(--bq-white);--bq-stroke--brand:var(--bq-brand);--bq-stroke--alt:var(--bq-neutral-50);--bq-stroke--brand-alt:var(--bq-brand-light);--bq-stroke--success:var(--bq-success);--bq-stroke--warning:var(--bq-warning);--bq-stroke--danger:var(--bq-danger);--bq-stroke--info:var(--bq-info);--bq-text--primary:var(--bq-neutral-800);--bq-text--secondary:var(--bq-neutral-600);--bq-text--inverse:var(--bq-neutral-50);--bq-text--brand:var(--bq-brand);--bq-text--alt:var(--bq-white);--bq-text--info:var(--bq-info);--bq-text--success:var(--bq-success);--bq-text--warning:var(--bq-warning);--bq-text--danger:var(--bq-danger);--bq-ui--primary:var(--bq-white);--bq-ui--secondary:var(--bq-neutral-200);--bq-ui--tertiary:var(--bq-neutral-500);--bq-ui--inverse:var(--bq-neutral-900);--bq-ui--alt:var(--bq-neutral-50);--bq-ui--brand-alt:var(--bq-brand-light);--bq-ui--brand:var(--bq-brand);--bq-ui--success:var(--bq-success);--bq-ui--success-alt:var(--bq-success-light);--bq-ui--warning:var(--bq-warning);--bq-ui--warning-alt:var(--bq-warning-light);--bq-ui--danger:var(--bq-danger);--bq-ui--danger-alt:var(--bq-danger-light);--bq-ui--info:var(--bq-info);--bq-ui--info-alt:var(--bq-info-light);--bq-hover:#444546;--bq-active:#1f2026}.endava.dark,[bq-theme=endava][bq-mode=dark]{--bq-background--primary:var(--bq-neutral-1000);--bq-background--secondary:var(--bq-neutral-900);--bq-background--tertiary:var(--bq-neutral-800);--bq-background--alt:var(--bq-neutral-700);--bq-background--inverse:var(--bq-neutral-600);--bq-background--brand:var(--bq-brand);--bq-background--overlay:var(--bq-neutral-900);--bq-icon--primary:var(--bq-neutral-100);--bq-icon--secondary:var(--bq-neutral-400);--bq-icon--inverse:var(--bq-neutral-800);--bq-icon--brand:var(--bq-brand);--bq-icon--alt:var(--bq-white);--bq-icon--info:var(--bq-info);--bq-icon--success:var(--bq-success);--bq-icon--warning:var(--bq-warning);--bq-icon--danger:var(--bq-danger);--bq-stroke--primary:var(--bq-neutral-900);--bq-stroke--secondary:var(--bq-neutral-700);--bq-stroke--tertiary:var(--bq-neutral-400);--bq-stroke--inverse:var(--bq-neutral-950);--bq-stroke--brand:var(--bq-brand);--bq-stroke--brand-alt:var(--bq-brand-dark);--bq-stroke--alt:var(--bq-neutral-1000);--bq-stroke--success:var(--bq-success);--bq-stroke--warning:var(--bq-warning);--bq-stroke--danger:var(--bq-danger);--bq-stroke--info:var(--bq-info);--bq-text--primary:var(--bq-neutral-100);--bq-text--secondary:var(--bq-neutral-400);--bq-text--inverse:var(--bq-neutral-800);--bq-text--brand:var(--bq-brand);--bq-text--alt:var(--bq-neutral-white);--bq-text--info:var(--bq-info);--bq-text--success:var(--bq-success);--bq-text--warning:var(--bq-warning);--bq-text--danger:var(--bq-danger);--bq-ui--primary:var(--bq-neutral-900);--bq-ui--secondary:var(--bq-neutral-800);--bq-ui--tertiary:var(--bq-neutral-700);--bq-ui--inverse:var(--bq-neutral-100);--bq-ui--brand:var(--bq-brand);--bq-ui--brand-alt:var(--bq-brand-dark);--bq-ui--alt:var(--bq-neutral-950);--bq-ui--success:var(--bq-success);--bq-ui--success-alt:var(--bq-success-dark);--bq-ui--warning:var(--bq-warning);--bq-ui--warning-alt:var(--bq-warning-dark);--bq-ui--danger:var(--bq-danger);--bq-ui--danger-alt:var(--bq-danger-dark);--bq-ui--info:var(--bq-info);--bq-ui--info-alt:var(--bq-info-dark);--bq-hover:#444546;--bq-active:#1f2026}.block{display:block}.flex-auto{flex:1 1 auto}.resize-y{resize:vertical}.rounded-\\[--bq-textarea--border-radius\\]{border-radius:var(--bq-textarea--border-radius)}.border-\\[length\\:--bq-textarea--border-width\\]{border-width:var(--bq-textarea--border-width)}.border-\\[color\\:--bq-ring-color-focus\\]{border-color:var(--bq-ring-color-focus)}.border-\\[color\\:--bq-textarea--border-color\\]{border-color:var(--bq-textarea--border-color)}.border-danger{border-color:var(--bq-stroke--danger)}.border-success{border-color:var(--bq-stroke--success)}.border-warning{border-color:var(--bq-stroke--warning)}.bg-\\[--bq-textarea--background-color\\]{background-color:var(--bq-textarea--background-color)}.pe-\\[--bq-textarea--padding-end\\]{padding-inline-end:var(--bq-textarea--padding-end)}.ps-\\[--bq-textarea--padding-start\\]{padding-inline-start:var(--bq-textarea--padding-start)}.text-\\[length\\:--bq-textarea--helper-text-size\\]{font-size:var(--bq-textarea--helper-text-size)}.text-\\[length\\:--bq-textarea--label-text-size\\]{font-size:var(--bq-textarea--label-text-size)}.text-\\[length\\:--bq-textarea--text-size\\]{font-size:var(--bq-textarea--text-size)}.text-\\[color\\:--bq-textarea--helper-text-color\\]{color:var(--bq-textarea--helper-text-color)}.text-\\[color\\:--bq-textarea--label-text-color\\]{color:var(--bq-textarea--label-text-color)}.text-\\[color\\:--bq-textarea--text-color\\]{color:var(--bq-textarea--text-color)}.text-danger{color:var(--bq-text--danger)}.text-success{color:var(--bq-text--success)}.text-warning{color:var(--bq-text--warning)}.opacity-60{opacity:.6}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.border-active-danger{border-color:color-mix(in srgb,var(--bq-stroke--danger),var(--bq-active) 20%)}.border-active-success{border-color:color-mix(in srgb,var(--bq-stroke--success),var(--bq-active) 20%)}.border-active-warning{border-color:color-mix(in srgb,var(--bq-stroke--warning),var(--bq-active) 20%)}.bs-\\[inherit\\]{block-size:inherit}.is-full{inline-size:100%}.p-b-\\[--bq-textarea--paddingY\\]{padding-block:var(--bq-textarea--paddingY)}.m-be-\\[--bq-textarea--label-margin-bottom\\]{margin-block-end:var(--bq-textarea--label-margin-bottom)}.m-bs-\\[--bq-textarea--helper-margin-top\\]{margin-block-start:var(--bq-textarea--helper-margin-top)}.focus{outline:var(--bq-ring-width,2px) solid var(--bq-ring-color-focus,var(--bq-focus));outline-offset:var(--bq-ring-offset-width,1px)}@-webkit-keyframes fade-in{0%{opacity:0}}@keyframes fade-in{0%{opacity:0}}@-webkit-keyframes slide-in{0%{-webkit-transform:translateY(10px);transform:translateY(10px)}}@keyframes slide-in{0%{-webkit-transform:translateY(10px);transform:translateY(10px)}}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}:host{--bq-textarea--background-color:transparent;--bq-textarea--border-color:var(--bq-stroke--tertiary);--bq-textarea--border-color-focus:var(--bq-stroke--brand);--bq-textarea--border-radius:var(--bq-radius--s);--bq-textarea--border-width:var(--bq-stroke-s);--bq-textarea--border-style:solid;--bq-textarea--helper-margin-top:var(--bq-spacing-xs);--bq-textarea--helper-text-size:var(--bq-font-size--s);--bq-textarea--helper-text-color:var(--bq-text--primary);--bq-textarea--label-margin-bottom:var(--bq-spacing-xs);--bq-textarea--label-text-size:var(--bq-font-size--s);--bq-textarea--label-text-color:var(--bq-text--primary);--bq-textarea--paddingY:var(--bq-spacing-s);--bq-textarea--padding-start:var(--bq-spacing-m);--bq-textarea--padding-end:var(--bq-spacing-m);--bq-textarea--text-color:var(--bq-text--primary);--bq-textarea--text-size:var(--bq-font-size--m);--bq-textarea--text-placeholder-color:var(--bq-text--secondary);display:block;inline-size:100%}.bq-textarea__label{color:var(--bq-textarea--label-text-color);font-size:var(--bq-textarea--label-text-size);margin-block-end:var(--bq-textarea--label-margin-bottom)}.bq-textarea__input{background-color:var(--bq-textarea--background-color);block-size:inherit;border-color:var(--bq-textarea--border-color);border-radius:var(--bq-textarea--border-radius);border-width:var(--bq-textarea--border-width);color:var(--bq-textarea--text-color);flex:1 1 auto;font-size:var(--bq-textarea--text-size);padding-block:var(--bq-textarea--paddingY);padding-inline-end:var(--bq-textarea--padding-end);padding-inline-start:var(--bq-textarea--padding-start);resize:vertical;transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.bq-textarea__input::placeholder{color:var(--bq-textarea--text-placeholder-color)}.bq-textarea__input:hover:not([disabled]):not(:focus-within){border-color:color-mix(in srgb,var(--bq-stroke--brand),var(--bq-hover) 20%)}.bq-textarea__input:disabled{cursor:not-allowed;opacity:.6}.bq-textarea__input:not([disabled]):focus-within{--bq-ring-width:1px;--bq-ring-offset-width:0;--bq-ring-color-focus:var(--bq-textarea--border-color-focus);border-color:var(--bq-ring-color-focus);outline:var(--bq-ring-width,2px) solid var(--bq-ring-color-focus,var(--bq-focus));outline-offset:var(--bq-ring-offset-width,1px)}.bq-textarea__input.validation-error{border-color:var(--bq-stroke--danger)}.bq-textarea__input.validation-error:hover:not(.disabled):not(:focus-within){border-color:color-mix(in srgb,var(--bq-stroke--danger),var(--bq-hover) 20%)}.bq-textarea__input.validation-error:not(.disabled):focus-within{--bq-ring-color-focus:var(--bq-stroke--danger);border-color:color-mix(in srgb,var(--bq-stroke--danger),var(--bq-active) 20%)}.bq-textarea__input.validation-success{border-color:var(--bq-stroke--success)}.bq-textarea__input.validation-success:hover:not(.disabled):not(:focus-within){border-color:color-mix(in srgb,var(--bq-stroke--success),var(--bq-hover) 20%)}.bq-textarea__input.validation-success:not(.disabled):focus-within{--bq-ring-color-focus:var(--bq-stroke--success);border-color:color-mix(in srgb,var(--bq-stroke--success),var(--bq-active) 20%)}.bq-textarea__input.validation-warning{border-color:var(--bq-stroke--warning)}.bq-textarea__input.validation-warning:hover:not(.disabled):not(:focus-within){border-color:color-mix(in srgb,var(--bq-stroke--warning),var(--bq-hover) 20%)}.bq-textarea__input.validation-warning:not(.disabled):focus-within{--bq-ring-color-focus:var(--bq-stroke--warning);border-color:color-mix(in srgb,var(--bq-stroke--warning),var(--bq-active) 20%)}.bq-textarea__helper{color:var(--bq-textarea--helper-text-color);font-size:var(--bq-textarea--helper-text-size);margin-block-start:var(--bq-textarea--helper-margin-top)}.bq-textarea__helper.validation-error{color:var(--bq-text--danger)}.bq-textarea__helper.validation-success{color:var(--bq-text--success)}.bq-textarea__helper.validation-warning{color:var(--bq-text--warning)}.bq-textarea__helper[class~=validation-none] .bq-textarea__helper--counter{opacity:.6}.placeholder\\:text-\\[color\\:--bq-textarea--text-placeholder-color\\]::placeholder{color:var(--bq-textarea--text-placeholder-color)}.disabled\\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\\:opacity-60:disabled{opacity:.6}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.flex{display:flex}.contents{display:contents}.\\!hidden{display:none!important}.shrink{flex-shrink:1}.grow{flex-grow:1}.resize-none{resize:none}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--bq-spacing-xs)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.\\[fontVariant\\:tabular-nums\\]{font-variant:tabular-nums}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}';const s=o;const l=class{constructor(e){a(this,e);this.bqBlur=r(this,"bqBlur",7);this.bqChange=r(this,"bqChange",7);this.bqClear=r(this,"bqClear",7);this.bqFocus=r(this,"bqFocus",7);this.bqInput=r(this,"bqInput",7);if(e.$hostElement$["s-ei"]){this.internals=e.$hostElement$["s-ei"]}else{this.internals=e.$hostElement$.attachInternals();e.$hostElement$["s-ei"]=this.internals}}debounceBqInput;fallbackId="textarea";helperTextElem;labelElem;textarea;internals;get el(){return e(this)}hasHelperText=false;hasLabel=false;autocapitalize="off";autocomplete="off";autocorrect="off";autofocus;autoGrow=false;debounceTime=0;disabled=false;disableResize=false;form;formValidationMessage;maxlength;name;placeholder;readonly=false;required=false;rows=5;spellcheck=false;validationStatus="none";value;wrap="soft";handleValueChange(){if(!this.textarea)return;if(!this.maxlength||this.value?.length<this.maxlength)return;this.value=this.value?.substring(0,this.maxlength);this.textarea.value=this.value??""}handleRequiredPropChange(){this.updateFormValidity()}bqBlur;bqChange;bqClear;bqFocus;bqInput;componentDidLoad(){this.handleSlotChange();this.handleValueChange()}formAssociatedCallback(){this.setFormValue(this.value);this.updateFormValidity()}formResetCallback(){this.clearSelection();this.setFormValue();this.updateFormValidity()}get numberOfCharacters(){if(!this.maxlength||!this.textarea)return 0;return this.value?.length}handleBlur=()=>{if(this.disabled)return;this.bqBlur.emit(this.el)};handleFocus=()=>{if(this.disabled)return;this.bqFocus.emit(this.el)};handleChange=a=>{if(this.disabled)return;if(!n(a.target,"textarea"))return;this.value=a.target.value;this.setFormValue(this.value);this.updateFormValidity();this.bqChange.emit({value:this.value,el:this.el})};handleInput=a=>{if(this.disabled)return;this.debounceBqInput?.cancel();if(!n(a.target,"textarea"))return;this.value=a.target.value;this.debounceBqInput=t((()=>{this.bqInput.emit({value:this.value,el:this.el})}),this.debounceTime);this.debounceBqInput();this.autoResize()};autoResize=()=>{if(!this.autoGrow)return;const a=this.textarea;if(!a)return;a.style.height="auto";a.style.height=`${a.scrollHeight}px`};handleSlotChange=()=>{this.hasLabel=q(this.labelElem);this.hasHelperText=q(this.helperTextElem)};setFormValue=a=>{this.internals.setFormValue(!i(a)?`${a}`:undefined)};updateFormValidity=()=>{const{formValidationMessage:a,internals:r,required:e,value:b,textarea:t}=this;r?.states.clear();if(e&&(!b||b.trim()==="")){r?.states.add("invalid");r?.setValidity({valueMissing:true},a,t);return}r?.states.add("valid");r?.setValidity({})};clearSelection=()=>{this.value="";this.textarea.value=this.value};render(){return b("div",{key:"fd8812d313f90ad5161f9cf1adb8342bb1e7b603",class:"bq-textarea flex flex-auto flex-col",part:"base"},b("label",{key:"45d88b4af1fc21e217a7ff4d5e06145e68df5dd5",class:{"bq-textarea__label":true,"!hidden":!this.hasLabel},htmlFor:this.name??this.fallbackId,"aria-label":this.name??this.fallbackId,ref:a=>this.labelElem=a,part:"label"},b("slot",{key:"234682cb6d87b9a039d71703a31ea1e145b9bab3",name:"label",onSlotchange:this.handleSlotChange})),b("textarea",{key:"dc6364b2967bebf1e85a0c1d1deda06437ed83d4",id:this.name??this.fallbackId,class:{"bq-textarea__input":true,"resize-none":this.disableResize,[`validation-${this.validationStatus}`]:true},autocapitalize:this.autocapitalize,autocomplete:this.autocomplete,autocorrect:this.autocorrect,autofocus:this.autofocus,disabled:this.disabled,form:this.form,maxLength:this.maxlength>0?this.maxlength:undefined,name:this.name,placeholder:this.placeholder,readOnly:this.readonly,required:this.required,rows:this.rows,spellcheck:this.spellcheck,wrap:this.wrap,ref:a=>this.textarea=a,onBlur:this.handleBlur,onChange:this.handleChange,onFocus:this.handleFocus,onInput:this.handleInput,part:"input"},this.value),b("div",{key:"031e79972e5764bffaa71d0151e697b3eed2d9c8",class:{"bq-textarea__helper flex items-center justify-between":true,[`validation-${this.validationStatus}`]:true,"!hidden":!this.hasHelperText&&!this.maxlength},part:"helper-info"},b("span",{key:"6d2ca0ed1579c9de4cac9367b5e9daacea104a6d",class:"bq-textarea__helper--text",ref:a=>this.helperTextElem=a,part:"helper-text"},b("slot",{key:"7b54ec8280a1c796aa5279b9ae119b93cdf0d0e2",name:"helper-text",onSlotchange:this.handleSlotChange})),b("span",{key:"963e2adbc0a9a8c7e701b8d4d6b4b82a64d0ffc8",class:{"bq-textarea__helper--counter [fontVariant:tabular-nums]":true,"!hidden":!this.maxlength},part:"helper-counter"},this.numberOfCharacters??0,"/",this.maxlength)))}static get delegatesFocus(){return true}static get formAssociated(){return true}static get watchers(){return{value:["handleValueChange"],required:["handleRequiredPropChange"]}}};l.style=s;export{l as bq_textarea};
6
- //# sourceMappingURL=p-8d9f797d.entry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["bqTextareaCss","BqTextareaStyle0","BqTextarea","debounceBqInput","fallbackId","helperTextElem","labelElem","textarea","internals","hasHelperText","hasLabel","autocapitalize","autocomplete","autocorrect","autofocus","autoGrow","debounceTime","disabled","disableResize","form","formValidationMessage","maxlength","name","placeholder","readonly","required","rows","spellcheck","validationStatus","value","wrap","handleValueChange","this","length","substring","handleRequiredPropChange","updateFormValidity","bqBlur","bqChange","bqClear","bqFocus","bqInput","componentDidLoad","handleSlotChange","formAssociatedCallback","setFormValue","formResetCallback","clearSelection","numberOfCharacters","handleBlur","emit","el","handleFocus","handleChange","ev","isHTMLElement","target","handleInput","cancel","debounce","autoResize","inputElem","style","height","scrollHeight","hasSlotContent","isNil","undefined","states","clear","trim","add","setValidity","valueMissing","render","h","key","class","part","htmlFor","ref","label","onSlotchange","id","maxLength","readOnly","elem","onBlur","onChange","onFocus","onInput","span"],"sources":["../../packages/beeq/src/components/textarea/scss/bq-textarea.scss?tag=bq-textarea&encapsulation=shadow","../../packages/beeq/src/components/textarea/bq-textarea.tsx"],"sourcesContent":["/* -------------------------------------------------------------------------- */\n/* Textarea styles */\n/* -------------------------------------------------------------------------- */\n\n@import './bq-textarea.variables';\n\n:host {\n @apply block is-full;\n}\n\n/* -------------------------------------------------------------------------- */\n/* Label */\n/* -------------------------------------------------------------------------- */\n\n.bq-textarea__label {\n @apply text-[length:--bq-textarea--label-text-size] text-[color:--bq-textarea--label-text-color] m-be-[--bq-textarea--label-margin-bottom];\n}\n\n/* -------------------------------------------------------------------------- */\n/* Native HTML Textarea control */\n/* -------------------------------------------------------------------------- */\n\n.bq-textarea__input {\n @apply flex-auto resize-y bg-[--bq-textarea--background-color] bs-[inherit];\n // Border\n @apply rounded-[--bq-textarea--border-radius] border-[length:--bq-textarea--border-width] border-[color:--bq-textarea--border-color];\n // Padding\n @apply pe-[--bq-textarea--padding-end] ps-[--bq-textarea--padding-start] p-b-[--bq-textarea--paddingY];\n // Text\n @apply text-[length:--bq-textarea--text-size] text-[color:--bq-textarea--text-color] placeholder:text-[color:--bq-textarea--text-placeholder-color];\n // Transition\n @apply transition-colors ease-in-out;\n // Hover\n @apply [&:not([disabled]):not(:focus-within)]:hover:border-hover-brand;\n // Disabled\n @apply disabled:cursor-not-allowed disabled:opacity-60;\n // Focus\n &:not([disabled]):focus-within {\n --bq-ring-width: 1px;\n --bq-ring-offset-width: 0;\n --bq-ring-color-focus: var(--bq-textarea--border-color-focus);\n\n @apply focus border-[color:--bq-ring-color-focus];\n }\n}\n\n/* ------------------------------- Validations ------------------------------- */\n\n.bq-textarea__input.validation-error {\n @apply border-danger [&:not(.disabled):not(:focus-within)]:hover:border-hover-danger;\n\n &:not(.disabled):focus-within {\n --bq-ring-color-focus: theme(stroke.danger);\n\n @apply border-active-danger;\n }\n}\n\n.bq-textarea__input.validation-success {\n @apply border-success [&:not(.disabled):not(:focus-within)]:hover:border-hover-success;\n\n &:not(.disabled):focus-within {\n --bq-ring-color-focus: theme(stroke.success);\n\n @apply border-active-success;\n }\n}\n\n.bq-textarea__input.validation-warning {\n @apply border-warning [&:not(.disabled):not(:focus-within)]:hover:border-hover-warning;\n\n &:not(.disabled):focus-within {\n --bq-ring-color-focus: theme(stroke.warning);\n\n @apply border-active-warning;\n }\n}\n\n/* -------------------------------------------------------------------------- */\n/* Helper text */\n/* -------------------------------------------------------------------------- */\n\n.bq-textarea__helper {\n @apply text-[length:--bq-textarea--helper-text-size] text-[color:--bq-textarea--helper-text-color] m-bs-[--bq-textarea--helper-margin-top];\n}\n\n/* ------------------------------- Validations ------------------------------ */\n\n.bq-textarea__helper.validation-error {\n @apply text-danger;\n}\n\n.bq-textarea__helper.validation-success {\n @apply text-success;\n}\n\n.bq-textarea__helper.validation-warning {\n @apply text-warning;\n}\n\n/* ----------------------------- Helper counter ----------------------------- */\n\n/** Apply a disabled text color style to the textarea counter when the validation is none. */\n.bq-textarea__helper[class~='validation-none'] {\n .bq-textarea__helper--counter {\n @apply opacity-60;\n }\n}\n","import { AttachInternals, Component, Element, Event, EventEmitter, h, Prop, State, Watch } from '@stencil/core';\n\nimport { TTextareaAutoCapitalize, TTextareaWrap } from './bq-textarea.types';\nimport { debounce, hasSlotContent, isHTMLElement, isNil, TDebounce } from '../../shared/utils';\nimport { TInputValidation } from '../input/bq-input.types';\n\n/**\n * The Textarea component is a multi-line text input control that is often used in a form to collect user inputs like comments or reviews.\n *\n * @example How to use it\n * ```html\n * <bq-textarea maxlength=\"0\" name=\"textarea\" placeholder=\"Placeholder...\" rows=\"5\">\n * <label slot=\"label\">Label</label>\n * <span class=\"flex items-center gap-xs\" slot=\"helper-text\">\n * <bq-icon name=\"star\"></bq-icon>\n * Helper text\n * </span>\n * </bq-textarea>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/16792c-textarea\n * @status stable\n *\n * @attr {string} autocapitalize - Controls whether or not the textarea field should be capitalized and how.\n * @attr {string} autocomplete - Specifies whether or not the textarea field should have autocomplete enabled.\n * @attr {string} autocorrect - Controls whether or not the textarea field should have autocorrect enabled.\n * @attr {boolean} autofocus - If `true`, the textarea will be focused on component render.\n * @attr {boolean} auto-grow - If `true`, the textarea will automatically grow and shrink to fit its contents.\n * @attr {number} debounce-time - The amount of time, in milliseconds, to wait before emitting the `bqInput` event after the textarea value changes.\n * @attr {boolean} disabled - If `true`, the user cannot interact with the textarea.\n * @attr {boolean} disable-resize - If `true`, it will block the user's ability to resize the textarea.\n * @attr {string} form - The ID of the form that the textarea field belongs to.\n * @attr {string} form-validation-message - The native form validation message.\n * @attr {number} maxlength - The maximum number of characters that can be entered into the textarea (`0`: no limit).\n * @attr {string} name - The name of the textarea element.\n * @attr {string} placeholder - The placeholder text to show when there is no value.\n * @attr {boolean} readonly - If `true`, the textarea field cannot be modified.\n * @attr {boolean} required - Indicates whether or not the textarea field is required to be filled out before submitting the form.\n * @attr {number} rows - The number of visible text lines for the control. It must be a positive integer.\n * @attr {boolean} spellcheck - If `true`, the textarea content may be checked for spelling errors.\n * @attr {\"error\" | \"none\" | \"success\" | \"warning\"} validation-status - The validation status of the textarea.\n * @attr {string} value - The value of the textarea. It can be used to reset the textarea to a previous value.\n * @attr {\"soft\" | \"hard\"} wrap - Specifies how the text in a text area is to be wrapped when submitted in a form.\n *\n * @event bqBlur - Handler to be called when the textarea loses focus.\n * @event bqChange - Handler to be called when the textarea value has changed and the textarea loses focus.\n * @event bqClear - Handler to be called when the textarea value has been cleared.\n * @event bqFocus - Handler to be called when the textarea has received focus.\n * @event bqInput - Handler to be called when the textarea value changes.\n *\n * @slot label - The textarea label.\n * @slot helper-text - The helper text.\n *\n * @part base - The component's base wrapper.\n * @part input - The textarea element.\n * @part label - The textarea label.\n * @part helper-info - The helper info container.\n * @part helper-text - The helper text.\n * @part helper-counter - The helper counter.\n *\n * @cssprop --bq-textarea--background-color - Textarea background color\n * @cssprop --bq-textarea--border-color - Textarea border color\n * @cssprop --bq-textarea--border-color-focus - Textarea border color on focus\n * @cssprop --bq-textarea--border-radius - Textarea border radius\n * @cssprop --bq-textarea--border-width - Textarea border width\n * @cssprop --bq-textarea--border-style - Textarea border style\n * @cssprop --bq-textarea--helper-margin-top - Textarea helper text margin top\n * @cssprop --bq-textarea--helper-text-color - Textarea helper text color\n * @cssprop --bq-textarea--helper-text-size - Textarea helper text size\n * @cssprop --bq-textarea--label-margin-bottom - Textarea label margin bottom\n * @cssprop --bq-textarea--label-text-color - Textarea label text color\n * @cssprop --bq-textarea--label-text-size - Textarea label text size\n * @cssprop --bq-textarea--paddingY - Textarea padding top and bottom\n * @cssprop --bq-textarea--padding-start - Textarea padding start\n * @cssprop --bq-textarea--padding-end - Textarea padding end\n * @cssprop --bq-textarea--text-color - Textarea text color\n * @cssprop --bq-textarea--text-size - Textarea text size\n * @cssprop --bq-textarea--text-placeholder-color - Textarea placeholder text color\n */\n@Component({\n tag: 'bq-textarea',\n styleUrl: './scss/bq-textarea.scss',\n formAssociated: true,\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class BqTextarea {\n // Own Properties\n // ====================\n\n private debounceBqInput: TDebounce<void>;\n private fallbackId = 'textarea';\n\n private helperTextElem?: HTMLElement;\n private labelElem?: HTMLLabelElement;\n private textarea: HTMLTextAreaElement;\n\n // Reference to host HTML element\n // ===================================\n\n @AttachInternals() internals!: ElementInternals;\n @Element() el!: HTMLBqTextareaElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n @State() private hasHelperText = false;\n @State() private hasLabel = false;\n\n // Public Property API\n // ========================\n\n /**\n * Controls whether or not the textarea field should be capitalized and how.\n * Possible values are 'off', 'none', 'on', 'sentences', 'words', and 'characters'.\n * See: https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/autocapitalize\n */\n @Prop({ reflect: true }) autocapitalize: TTextareaAutoCapitalize = 'off';\n\n /**\n * Specifies whether or not the textarea field should have autocomplete enabled.\n * See: https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete#values\n */\n @Prop({ reflect: true }) autocomplete: string = 'off';\n\n /**\n * Controls whether or not the textarea field should have autocorrect enabled.\n * Possible values are 'on' and 'off'.\n */\n @Prop({ reflect: true }) autocorrect: 'on' | 'off' = 'off';\n\n /** If true, the textarea will be focused on component render */\n @Prop({ reflect: true }) autofocus: boolean;\n\n /**\n * If `true`, the textarea will automatically grow and shrink to fit its contents.\n * If `false`, the textarea will have a fixed height specified by the `rows` property.\n */\n @Prop({ reflect: true }) autoGrow: boolean = false;\n\n /**\n * The amount of time, in milliseconds, to wait before emitting the `bqInput` event after the textarea value changes.\n * A value of 0 means no debouncing will occur.\n */\n @Prop({ reflect: true, mutable: true }) debounceTime? = 0;\n\n /** If `true`, the user cannot interact with the textarea. */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /** If `true`, it will block the user's ability to resize the textarea. */\n @Prop({ reflect: true }) disableResize?: boolean = false;\n\n /** The ID of the form that the textarea field belongs to. */\n @Prop({ reflect: true }) form?: string;\n\n /** The native form validation message */\n @Prop({ mutable: true }) formValidationMessage?: string;\n\n /**\n * The maximum number of characters that can be entered into the textarea (`0`: no limit).\n * When enabled, a character counter will be shown underneath the textarea.\n */\n @Prop({ reflect: true }) maxlength: number;\n\n /** The name of the textarea element. */\n @Prop({ reflect: true }) name!: string;\n\n /** The placeholder text to show when there is no value. */\n @Prop({ reflect: true }) placeholder!: string;\n\n /** If true, the textarea field cannot be modified. */\n @Prop({ reflect: true }) readonly?: boolean = false;\n\n /** Indicates whether or not the textarea field is required to be filled out before submitting the form. */\n @Prop({ reflect: true }) required?: boolean = false;\n\n /** The number of visible text lines for the control. It must be a positive integer. */\n @Prop({ reflect: true }) rows: number = 5;\n\n /** If true, the textarea content may be checked for spelling errors. */\n @Prop({ reflect: true }) spellcheck: boolean = false;\n /**\n * The validation status of the textarea.\n *\n * @remarks\n * This property is used to indicate the validation status of the textarea. It can be set to one of the following values:\n * - `'none'`: No validation status is set.\n * - `'error'`: The textarea has a validation error.\n * - `'warning'`: The textarea has a validation warning.\n * - `'success'`: The textarea has passed validation.\n */\n @Prop({ reflect: true, mutable: true }) validationStatus: TInputValidation = 'none';\n\n /** The value of the textarea. It can be used to reset the textarea to a previous value. */\n @Prop({ mutable: true }) value: string;\n\n /** Specifies how the text in a text area is to be wrapped when submitted in a form */\n @Prop({ reflect: true }) wrap: TTextareaWrap = 'soft';\n\n // Prop lifecycle events\n // =======================\n\n @Watch('value')\n handleValueChange() {\n if (!this.textarea) return;\n if (!this.maxlength || this.value?.length < this.maxlength) return;\n // If the value is longer than the maxlength, we need to truncate it\n this.value = this.value?.substring(0, this.maxlength);\n this.textarea.value = this.value ?? '';\n }\n\n @Watch('required')\n handleRequiredPropChange() {\n this.updateFormValidity();\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n /** Callback handler emitted when the textarea loses focus */\n @Event() bqBlur!: EventEmitter<HTMLBqTextareaElement>;\n\n /**\n * Callback handler emitted when the textarea value has changed and the textarea loses focus.\n * This handler is called whenever the user finishes typing or pasting text into the textarea field and then clicks outside of the textarea field.\n */\n @Event() bqChange!: EventEmitter<{ value: string; el: HTMLBqTextareaElement }>;\n\n /** Callback handler emitted when the textarea value has been cleared */\n @Event() bqClear!: EventEmitter<HTMLBqTextareaElement>;\n\n /** Callback handler emitted when the textarea has received focus */\n @Event() bqFocus!: EventEmitter<HTMLBqTextareaElement>;\n\n /**\n * Callback handler emitted when the textarea value changes.\n * This handler is called whenever the user types or pastes text into the textarea field.\n */\n @Event() bqInput!: EventEmitter<{ value: string; el: HTMLBqTextareaElement }>;\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n componentDidLoad() {\n this.handleSlotChange();\n this.handleValueChange();\n }\n\n formAssociatedCallback() {\n this.setFormValue(this.value);\n this.updateFormValidity();\n }\n\n formResetCallback() {\n this.clearSelection();\n // Reset the form validity state\n this.setFormValue();\n this.updateFormValidity();\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 get numberOfCharacters() {\n if (!this.maxlength || !this.textarea) return 0;\n\n return this.value?.length;\n }\n\n private handleBlur = () => {\n if (this.disabled) return;\n\n this.bqBlur.emit(this.el);\n };\n\n private handleFocus = () => {\n if (this.disabled) return;\n\n this.bqFocus.emit(this.el);\n };\n\n private handleChange = (ev: Event) => {\n if (this.disabled) return;\n\n if (!isHTMLElement(ev.target, 'textarea')) return;\n this.value = ev.target.value;\n this.setFormValue(this.value);\n this.updateFormValidity();\n\n this.bqChange.emit({ value: this.value, el: this.el });\n };\n\n private handleInput = (ev: Event) => {\n if (this.disabled) return;\n\n this.debounceBqInput?.cancel();\n\n if (!isHTMLElement(ev.target, 'textarea')) return;\n this.value = ev.target.value;\n\n this.debounceBqInput = debounce(() => {\n this.bqInput.emit({ value: this.value, el: this.el });\n }, this.debounceTime);\n this.debounceBqInput();\n\n this.autoResize();\n };\n\n private autoResize = () => {\n if (!this.autoGrow) return;\n\n const inputElem = this.textarea;\n if (!inputElem) return;\n\n inputElem.style.height = 'auto';\n inputElem.style.height = `${inputElem.scrollHeight}px`;\n };\n\n private handleSlotChange = () => {\n this.hasLabel = hasSlotContent(this.labelElem);\n this.hasHelperText = hasSlotContent(this.helperTextElem);\n };\n\n private setFormValue = (value?: string) => {\n this.internals.setFormValue(!isNil(value) ? `${value}` : undefined);\n };\n\n private updateFormValidity = () => {\n const { formValidationMessage, internals, required, value, textarea } = this;\n\n // Clear the validity state\n internals?.states.clear();\n\n if (required && (!value || value.trim() === '')) {\n // Set validity state to invalid\n internals?.states.add('invalid');\n internals?.setValidity({ valueMissing: true }, formValidationMessage, textarea);\n return;\n }\n\n // Set validity state to valid if textarea has value or is not required\n internals?.states.add('valid');\n internals?.setValidity({});\n };\n\n private clearSelection = () => {\n this.value = '';\n this.textarea.value = this.value;\n };\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <div class=\"bq-textarea flex flex-auto flex-col\" part=\"base\">\n <label\n class={{ 'bq-textarea__label': true, '!hidden': !this.hasLabel }}\n htmlFor={this.name ?? this.fallbackId}\n aria-label={this.name ?? this.fallbackId}\n ref={(label: HTMLLabelElement) => (this.labelElem = label)}\n part=\"label\"\n >\n <slot name=\"label\" onSlotchange={this.handleSlotChange} />\n </label>\n <textarea\n id={this.name ?? this.fallbackId}\n class={{\n 'bq-textarea__input': true,\n 'resize-none': this.disableResize,\n [`validation-${this.validationStatus}`]: true,\n }}\n autocapitalize={this.autocapitalize}\n autocomplete={this.autocomplete}\n autocorrect={this.autocorrect}\n autofocus={this.autofocus}\n disabled={this.disabled}\n form={this.form}\n maxLength={this.maxlength > 0 ? this.maxlength : undefined}\n name={this.name}\n placeholder={this.placeholder}\n readOnly={this.readonly}\n required={this.required}\n rows={this.rows}\n spellcheck={this.spellcheck}\n wrap={this.wrap}\n ref={(elem: HTMLTextAreaElement) => (this.textarea = elem)}\n onBlur={this.handleBlur}\n onChange={this.handleChange}\n onFocus={this.handleFocus}\n onInput={this.handleInput}\n part=\"input\"\n >\n {this.value}\n </textarea>\n <div\n class={{\n 'bq-textarea__helper flex items-center justify-between': true,\n [`validation-${this.validationStatus}`]: true,\n '!hidden': !this.hasHelperText && !this.maxlength,\n }}\n part=\"helper-info\"\n >\n <span\n class=\"bq-textarea__helper--text\"\n ref={(span: HTMLElement) => (this.helperTextElem = span)}\n part=\"helper-text\"\n >\n <slot name=\"helper-text\" onSlotchange={this.handleSlotChange} />\n </span>\n <span\n class={{ 'bq-textarea__helper--counter [fontVariant:tabular-nums]': true, '!hidden': !this.maxlength }}\n part=\"helper-counter\"\n >\n {this.numberOfCharacters ?? 0}/{this.maxlength}\n </span>\n </div>\n </div>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["AVATAR_SIZE","AVATAR_SHAPE","bqAvatarCss","BqAvatarStyle0","BqAvatar","trimmedInitials","hasError","altText","image","label","initials","shape","size","handleImagePropChange","this","checkPropValues","validatePropValue","el","onInitialsChange","trimInitialsBasedOnSize","componentWillLoad","onImageError","forEach","substring","getIndex","sizeIndexMap","xsmall","small","medium","large","render","h","Host","key","class","role","part","alt","undefined","src","onError","name"],"sources":["../../packages/beeq/src/components/avatar/bq-avatar.types.ts","../../packages/beeq/src/components/avatar/scss/bq-avatar.scss?tag=bq-avatar&encapsulation=shadow","../../packages/beeq/src/components/avatar/bq-avatar.tsx"],"sourcesContent":["export const AVATAR_SIZE = ['xsmall', 'small', 'medium', 'large'] as const;\nexport type TAvatarSize = (typeof AVATAR_SIZE)[number];\n\nexport const AVATAR_SHAPE = ['circle', 'square'] as const;\nexport type TAvatarShape = (typeof AVATAR_SHAPE)[number];\n","/* -------------------------------------------------------------------------- */\n/* Avatar styles */\n/* -------------------------------------------------------------------------- */\n\n@import './bq-avatar.variables';\n\n:host {\n @apply relative inline-block;\n}\n\n.bq-avatar {\n @apply relative overflow-hidden bg-[var(--bq-avatar-background)];\n @apply border-[length:var(--bq-avatar--border-width)] border-[color:var(--bq-avatar--border-color)];\n\n border-style: var(--bq-avatar--border-style);\n}\n\n.size {\n &--xsmall {\n @apply text-[length:var(--bq-avatar--font-size-xsmall)] bs-[--bq-avatar--size-xsmall] is-[--bq-avatar--size-xsmall];\n }\n\n &--small {\n @apply text-[length:var(--bq-avatar--font-size-small)] bs-[--bq-avatar--size-small] is-[--bq-avatar--size-small];\n }\n\n &--medium {\n @apply text-[length:var(--bq-avatar--font-size-medium)] bs-[--bq-avatar--size-medium] is-[--bq-avatar--size-medium];\n }\n\n &--large {\n @apply text-[length:var(--bq-avatar--font-size-large)] bs-[--bq-avatar--size-large] is-[--bq-avatar--size-large];\n }\n}\n","import { Component, Element, h, Host, Prop, State, Watch } from '@stencil/core';\n\nimport { AVATAR_SHAPE, AVATAR_SIZE, TAvatarShape, TAvatarSize } from './bq-avatar.types';\nimport { validatePropValue } from '../../shared/utils';\n\n/**\n * The Avatar component is a simple and customizable element that displays an image or initials in a circular or square shape.\n * This component is useful for displaying user profile pictures or any other image that represents a person or an entity.\n *\n * @example How to use it\n * ```html\n * <bq-avatar\n * alt-text=\"John Doe profile picture\"\n * image=\"/image/url/photo-1524593689594.jpeg\"\n * label=\"John Doe profile picture\"\n * shape=\"circle\"\n * size=\"medium\"\n * >\n * <bq-badge slot=\"badge\" text-color=\"#fff\">9</bq-badge>\n * </bq-avatar>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/148da7-avatar\n * @status stable\n *\n * @attr {string} alt-text - Alternate text for the avatar image if the image cannot be displayed.\n * @attr {string} image - The image source to load on the avatar (this can be also a base64 encoded image).\n * @attr {string} label - A text to use for describing the avatar on assistive devices.\n * @attr {string} initials - The text to display on avatar.\n * @attr {\"circle\" | \"square\"} shape - The shape of the avatar.\n * @attr {\"xsmall\" | \"small\" | \"medium\" | \"large\"} size - The size of the avatar.\n *\n * @slot badge - The badge slot is used to add a badge to the avatar. The badge is a small circle or square that can be used to display a number or a status.\n *\n * @part base - The component's internal wrapper.\n * @part img - The `<image>` tag element that load the image source.\n * @part text - The `<span>` tag element that rendered the `Initials` text string.\n * @part badge - The container that wraps the badge slot element.\n *\n * @cssprop --bq-avatar--background - Avatar background color\n *\n * @cssprop --bq-avatar--border-color - Avatar border color\n * @cssprop --bq-avatar--border-style - Avatar border style\n * @cssprop --bq-avatar--border-width - Avatar border width\n *\n * @cssprop --bq-avatar--border-radius-circle - Avatar border radius for circle & any size\n * @cssprop --bq-avatar--border-radius-squareXs - Avatar border radius for square & size xsmall\n * @cssprop --bq-avatar--border-radius-squareS - Avatar border radius for square & size small\n * @cssprop --bq-avatar--border-radius-squareM - Avatar border radius for square & size medium/large\n *\n * @cssprop --bq-avatar--size-xsmall - Avatar xsmall size\n * @cssprop --bq-avatar--size-small - Avatar small size\n * @cssprop --bq-avatar--size-medium - Avatar medium size\n * @cssprop --bq-avatar--size-large - Avatar large size\n *\n * @cssprop --bq-avatar--badge-top-square - Badge top position shape square\n * @cssprop --bq-avatar--badge-left-square - Badge left position shape square\n * @cssprop --bq-avatar--badge-top-circle - Badge top position shape circle\n * @cssprop --bq-avatar--badge-left-circle - Badge left position shape circle\n */\n@Component({\n tag: 'bq-avatar',\n styleUrl: './scss/bq-avatar.scss',\n shadow: true,\n})\nexport class BqAvatar {\n // Own Properties\n // ====================\n\n trimmedInitials: string;\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqAvatarElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n @State() hasError: boolean;\n\n // Public Property API\n // ========================\n\n /** Alternate text for the avatar image if the image cannot be displayed */\n @Prop({ reflect: true }) altText: string;\n\n /** The image source to load on the avatar (this can be also a base64 encoded image) */\n @Prop({ reflect: true }) image: string;\n\n /** A text to use for describing the avatar on assistive devices */\n @Prop({ reflect: true }) label: string;\n\n /** The text to display on avatar */\n @Prop({ reflect: true }) initials: string;\n\n /** The shape of the avatar */\n @Prop({ reflect: true }) shape: TAvatarShape = 'circle';\n\n /** The size of the avatar */\n @Prop({ reflect: true, mutable: true }) size: TAvatarSize = 'medium';\n\n // Prop lifecycle events\n // =======================\n\n @Watch('image')\n handleImagePropChange() {\n // Reset the error when a new image source is provided\n this.hasError = false;\n }\n\n @Watch('shape')\n @Watch('size')\n checkPropValues() {\n validatePropValue(AVATAR_SHAPE, 'circle', this.el, 'shape');\n validatePropValue(AVATAR_SIZE, 'medium', this.el, 'size');\n }\n\n @Watch('initials')\n @Watch('size')\n onInitialsChange() {\n this.trimInitialsBasedOnSize();\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.trimInitialsBasedOnSize();\n this.checkPropValues();\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 onImageError = () => {\n this.hasError = true;\n };\n\n private trimInitialsBasedOnSize = (): void => {\n if (!this.initials) return;\n\n AVATAR_SIZE.forEach((size: TAvatarSize) => {\n if (this.size === size) {\n this.trimmedInitials = this.initials.substring(0, this.getIndex(size));\n }\n });\n };\n\n private getIndex = (size: TAvatarSize): number => {\n const sizeIndexMap = {\n xsmall: 1,\n small: 2,\n medium: 3,\n large: 4,\n };\n return sizeIndexMap[size] ?? sizeIndexMap.xsmall;\n };\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <Host>\n <div\n class={{\n 'bq-avatar': true,\n [`size--${this.size}`]: true,\n 'rounded-[--bq-avatar--border-radius-circle]': this.shape === 'circle',\n 'rounded-[--bq-avatar--border-radius-squareXs]': this.shape === 'square' && this.size === 'xsmall',\n 'rounded-[--bq-avatar--border-radius-squareS]': this.shape === 'square' && this.size === 'small',\n 'rounded-[--bq-avatar--border-radius-squareM]':\n this.shape === 'square' && (this.size === 'medium' || this.size === 'large'),\n }}\n aria-label={this.label}\n role=\"img\"\n part=\"base\"\n >\n {this.initials && (\n <span\n class=\"absolute start-0 inline-flex items-center justify-center font-bold bs-full is-full inset-bs-0\"\n part=\"text\"\n >\n {this.trimmedInitials}\n </span>\n )}\n {this.image && !this.hasError && (\n <img\n class=\"absolute start-0 object-cover bs-full is-full inset-bs-0\"\n alt={this.altText ?? undefined}\n src={this.image}\n onError={this.onImageError}\n part=\"img\"\n />\n )}\n </div>\n <div\n class={{\n 'absolute flex items-center justify-center': true,\n 'start-[--bq-avatar--badge-left-square] inset-bs-[--bq-avatar--badge-top-square]': this.shape === 'square',\n 'start-[--bq-avatar--badge-left-circle] inset-bs-[--bq-avatar--badge-top-circle]': this.shape === 'circle',\n }}\n part=\"badge\"\n >\n <slot name=\"badge\"></slot>\n </div>\n </Host>\n );\n }\n}\n"],"mappings":";;;;6FAAO,MAAMA,EAAc,CAAC,SAAU,QAAS,SAAU,SAGlD,MAAMC,EAAe,CAAC,SAAU,UCHvC,MAAMC,EAAc,mmuBACpB,MAAAC,EAAeD,E,MCgEFE,EAAQ,M,yBAInBC,gB,wBAWSC,SAMgBC,QAGAC,MAGAC,MAGAC,SAGAC,MAAsB,SAGPC,KAAoB,SAM5D,qBAAAC,GAEEC,KAAKR,SAAW,K,CAKlB,eAAAS,GACEC,EAAkBf,EAAc,SAAUa,KAAKG,GAAI,SACnDD,EAAkBhB,EAAa,SAAUc,KAAKG,GAAI,O,CAKpD,gBAAAC,GACEJ,KAAKK,yB,CAWP,iBAAAC,GACEN,KAAKK,0BACLL,KAAKC,iB,CAkBCM,aAAe,KACrBP,KAAKR,SAAW,IAAI,EAGda,wBAA0B,KAChC,IAAKL,KAAKJ,SAAU,OAEpBV,EAAYsB,SAASV,IACnB,GAAIE,KAAKF,OAASA,EAAM,CACtBE,KAAKT,gBAAkBS,KAAKJ,SAASa,UAAU,EAAGT,KAAKU,SAASZ,G,IAElE,EAGIY,SAAYZ,IAClB,MAAMa,EAAe,CACnBC,OAAQ,EACRC,MAAO,EACPC,OAAQ,EACRC,MAAO,GAET,OAAOJ,EAAab,IAASa,EAAaC,MAAM,EAOlD,MAAAI,GACE,OACEC,EAACC,EAAI,CAAAC,IAAA,4CACHF,EAAA,OAAAE,IAAA,2CACEC,MAAO,CACL,YAAa,KACb,CAAC,SAASpB,KAAKF,QAAS,KACxB,8CAA+CE,KAAKH,QAAU,SAC9D,gDAAiDG,KAAKH,QAAU,UAAYG,KAAKF,OAAS,SAC1F,+CAAgDE,KAAKH,QAAU,UAAYG,KAAKF,OAAS,QACzF,+CACEE,KAAKH,QAAU,WAAaG,KAAKF,OAAS,UAAYE,KAAKF,OAAS,UACvE,aACWE,KAAKL,MACjB0B,KAAK,MACLC,KAAK,QAEJtB,KAAKJ,UACJqB,EAAA,QAAAE,IAAA,2CACEC,MAAM,gGACNE,KAAK,QAEJtB,KAAKT,iBAGTS,KAAKN,QAAUM,KAAKR,UACnByB,EAAA,OAAAE,IAAA,2CACEC,MAAM,2DACNG,IAAKvB,KAAKP,SAAW+B,UACrBC,IAAKzB,KAAKN,MACVgC,QAAS1B,KAAKO,aACde,KAAK,SAIXL,EAAA,OAAAE,IAAA,2CACEC,MAAO,CACL,4CAA6C,KAC7C,kFAAmFpB,KAAKH,QAAU,SAClG,kFAAmFG,KAAKH,QAAU,UAEpGyB,KAAK,SAELL,EAAA,QAAAE,IAAA,2CAAMQ,KAAK,W","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["bqSwitchCss","BqSwitchStyle0","BqSwitch","labelElem","inputElem","prevCheckedValue","internals","hasLabel","backgroundOnHover","checked","disabled","formValidationMessage","fullWidth","innerLabel","justifyContent","name","required","reverseOrder","value","handleRequiredChange","this","updateFormValidity","bqChange","bqFocus","bqBlur","componentWillLoad","componentDidLoad","handleSlotChange","componentDidUpdate","emit","formAssociatedCallback","setFormValue","formResetCallback","removeAttribute","undefined","vClick","click","vFocus","focus","vBlur","blur","handleChange","setAttribute","handleOnFocus","el","handleOnBlur","slot","querySelector","isNil","getTextContent","recurse","length","states","clear","add","setValidity","valueMissing","render","hostStyle","labelCssClasses","h","Host","key","class","style","part","type","onBlur","onChange","onFocus","ref","input","role","color","title","span","onSlotchange"],"sources":["../../packages/beeq/src/components/switch/scss/bq-switch.scss?tag=bq-switch&encapsulation=shadow","../../packages/beeq/src/components/switch/bq-switch.tsx"],"sourcesContent":["/* -------------------------------------------------------------------------- */\n/* Switch styles */\n/* -------------------------------------------------------------------------- */\n\n@import './bq-switch.variables';\n\n:host {\n @apply inline-block;\n}\n\n:host(.full-width) {\n @apply is-full;\n}\n\n.bq-switch {\n @apply flex cursor-pointer select-none items-center rounded-s transition-colors duration-300 p-b-2 p-i-2;\n\n justify-content: var(--bq-switch--justify-content);\n\n // Display background on hover (if enabled)\n &.has-background:not(.is-disabled):hover {\n @apply bg-hover-ui-primary;\n }\n\n &.is-disabled {\n @apply cursor-not-allowed opacity-60;\n }\n}\n\n.bq-switch--input:not(:disabled):focus,\n.bq-switch--input:not(:disabled):focus-visible {\n ~ .bq-switch--control {\n @apply focus;\n }\n}\n\n.bq-switch--control__dot {\n @apply absolute start-xs2 rounded-full bg-ui-primary bs-[--bq-switch--dot-size] is-[--bq-switch--dot-size];\n @apply group-[&.is-checked]:start-[calc(100%_-_var(--bq-switch--dot-size)_-_var(--bq-spacing-xs2))] group-[&.is-checked]:bg-[--bq-icon--alt];\n @apply transition-all duration-300;\n}\n\n.bq-switch--control__icon {\n --bq-icon--size: var(--bq-switch--dot-size) !important;\n\n &::part(base) {\n @apply flex;\n }\n}\n","import {\n AttachInternals,\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Method,\n Prop,\n State,\n Watch,\n} from '@stencil/core';\n\nimport { TSwitchInnerLabel, TSwitchJustifyContent } from './bq-switch.types';\nimport { getTextContent, isNil } from '../../shared/utils';\n\n/**\n * Toggle switches are digital on/off switches.\n * They should provide immediate results, giving users the freedom to control their preferences as needed.\n *\n * @example How to use it\n * ```html\n * <bq-switch inner-label=\"default\" justify-content=\"start\" name=\"bq-switch\" value=\"Switch value\">\n * Toggle me!\n * </bq-switch>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/49d9c9-switch\n * @status stable\n *\n * @dependency bq-icon\n *\n * @attr {boolean} background-on-hover - If `true`, a background will be displayed on hover\n * @attr {boolean} checked - It indicates whether if the switch is `ON` by default (when the page loads)\n * @attr {boolean} disabled - If `true`, the switch control will be disabled and no interaction will be allowed\n * @attr {string} form-validation-message - The native form validation message\n * @attr {boolean} full-width - If `true`, the component will take the full width space available on the parent container\n * @attr {\"default\" | \"icon\"} inner-label - It indicates how to to display the on/off marks inside the control, with icons or none (default)\n * @attr {\"start\" | \"end\" | \"center\" | \"space-between\" | \"space-around\" | \"space-evenly\"} justify-content - It defines how to distribute the space between and around the control and the label text\n * @attr {string} name - Name of the 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 switch `ON` the element before the owning form can be submitted\n * @attr {boolean} reverse-order - If `true`, the order of the control and the label text will be changed\n * @attr {string} value - The input control's value, submitted as a name/value pair with form data\n *\n * @event bqChange - Handler to be called when the switch state changes\n * @event bqFocus - Handler to be called when the switch gets focus\n * @event bqBlur - Handler to be called when the switch loses focus\n *\n * @slot - The switch label text\n *\n * @part base - HTML `<label>` root container\n * @part control - HTML `<div>` element for the custom control\n * @part dot - HTML `<div>` element that acts as changing dot\n * @part icon-off - HTMLBqIcon `<pk-icon>` element used as the `OFF` mark inner label\n * @part icon-on - HTMLBqIcon `<pk-icon>` element used as the `ON` mark inner label\n * @part label - HTML `<span>` element that holds the label text\n *\n * @cssprop --bq-switch--height - Switch height\n * @cssprop --bq-switch--justify-content - Switch justify content\n * @cssprop --bq-switch--width - Switch width\n * @cssprop --bq-switch--dot-size - Switch dot size\n */\n@Component({\n tag: 'bq-switch',\n styleUrl: './scss/bq-switch.scss',\n formAssociated: true,\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class BqSwitch {\n // Own Properties\n // ====================\n\n private labelElem: HTMLSpanElement;\n private inputElem: HTMLInputElement;\n private prevCheckedValue: boolean;\n\n // Reference to host HTML element\n // ===================================\n\n @AttachInternals() internals!: ElementInternals;\n @Element() el!: HTMLBqSwitchElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n @State() hasLabel = false;\n\n // Public Property API\n // ========================\n\n /** If true, a background will be displayed on hover */\n @Prop({ reflect: true }) backgroundOnHover?: boolean = false;\n\n /** It indicates whether if the switch is `ON` by default (when the page loads) */\n @Prop({ reflect: true, mutable: true }) checked?: boolean = false;\n\n /** If true, the switch control will be disabled and no interaction will be allowed */\n @Prop({ reflect: true }) disabled?: boolean = false;\n\n /** The native form validation message */\n @Prop({ mutable: true }) formValidationMessage?: string;\n\n /** If true, the component will take the full width space available on the parent container */\n @Prop({ reflect: true }) fullWidth?: boolean = false;\n\n /** It indicates how to to display the on/off marks inside the control, with icons or none (default) */\n @Prop({ reflect: true }) innerLabel?: TSwitchInnerLabel = 'default';\n\n /**\n * It defines how to distribute the space between and around the control and the label text\n * (https://developer.mozilla.org/en-US/docs/Web/CSS/justify-content)\n */\n @Prop({ reflect: true }) justifyContent?: TSwitchJustifyContent = 'start';\n\n /** Name of the 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 switch `ON` the element before the owning form can be submitted */\n @Prop({ reflect: true }) required?: boolean = false;\n\n /** If true, the order of the control and the label text will be changed */\n @Prop({ reflect: true }) reverseOrder?: boolean = false;\n\n /** The input control's value, submitted as a name/value pair with form data. */\n @Prop({ reflect: true }) value?: string;\n\n // Prop lifecycle events\n // =======================\n\n @Watch('required')\n handleRequiredChange() {\n this.updateFormValidity();\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n /** Handler to be called when the switch state changes */\n @Event() bqChange: EventEmitter<{ checked: boolean }>;\n\n /** Handler to be called when the switch gets focus */\n @Event() bqFocus: EventEmitter<HTMLBqSwitchElement>;\n\n /** Handler to be called when the switch loses focus */\n @Event() bqBlur: EventEmitter<HTMLBqSwitchElement>;\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n componentWillLoad() {\n this.prevCheckedValue = this.checked;\n }\n\n componentDidLoad() {\n this.handleSlotChange();\n }\n\n componentDidUpdate() {\n /**\n * We need to trigger the `bqChange` immediately after the first update happens\n * so the checked attribute get applied, otherwise, a delay will happen\n * between the event emits and when the checked attribute value gets reflected in the element host.\n */\n if (this.checked !== this.prevCheckedValue) {\n this.bqChange.emit({ checked: this.checked });\n this.prevCheckedValue = this.checked;\n }\n }\n\n formAssociatedCallback() {\n this.setFormValue(this.checked);\n this.updateFormValidity();\n }\n\n formResetCallback() {\n // Reset the form value and validity state\n this.checked = false;\n this.inputElem.removeAttribute('checked');\n this.internals?.setFormValue(undefined);\n this.updateFormValidity();\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.inputElem?.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.inputElem?.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.inputElem?.blur();\n }\n\n // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n private handleChange = () => {\n this.checked = !this.checked;\n this.inputElem.setAttribute('checked', `${this.checked}`);\n this.setFormValue(this.checked);\n this.updateFormValidity();\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 handleSlotChange = () => {\n const slot = this.labelElem?.querySelector('slot') ?? null;\n if (isNil(slot)) return;\n\n this.hasLabel = !!getTextContent(slot, { recurse: true }).length;\n };\n\n private setFormValue = (checked: boolean) => {\n const value = checked ? 'on' : undefined;\n // Set form value based on the checked state\n // Here we also pass the state of the component (2nd argument) as the state of the form control\n // Details: https://developer.mozilla.org/en-US/docs/Web/API/ElementInternals/setFormValue\n this.internals?.setFormValue(value, `${this.checked}`);\n };\n\n private updateFormValidity = () => {\n const { formValidationMessage, internals, required, checked, inputElem } = this;\n // Clear the validity state\n internals?.states.clear();\n\n if (!(required && !checked)) {\n // If the switch component is not required or is checked, set the validity state to valid\n internals?.states.add('valid');\n internals?.setValidity({});\n return;\n }\n\n // Set validity state based on the required property and checked state\n internals?.states.add('invalid');\n internals?.setValidity({ valueMissing: true }, formValidationMessage, inputElem);\n };\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n const hostStyle = {\n ...(this.justifyContent && { '--bq-switch--justify-content': this.justifyContent }),\n };\n\n const labelCssClasses = {\n 'has-background': this.backgroundOnHover,\n 'is-checked': this.checked,\n 'is-disabled': this.disabled,\n 'flex-row-reverse': this.reverseOrder,\n };\n\n return (\n <Host class={{ 'full-width': this.fullWidth }} style={hostStyle}>\n <label class={{ 'bq-switch group': true, ...labelCssClasses }} part=\"base\">\n {/* Hidden native HTML input */}\n <input\n class=\"bq-switch--input peer sr-only !bs-[--bq-switch--dot-size] !is-[--bq-switch--width] peer-checked:invisible\"\n type=\"checkbox\"\n checked={this.checked}\n disabled={this.disabled}\n required={this.required}\n name={!isNil(this.name) ? this.name : undefined}\n aria-label={this.name}\n aria-checked={this.checked ? 'true' : 'false'}\n aria-disabled={this.disabled ? 'true' : 'false'}\n onBlur={this.handleOnBlur}\n onChange={this.handleChange}\n onFocus={this.handleOnFocus}\n ref={(input) => (this.inputElem = input)}\n role=\"switch\"\n value={this.value}\n />\n {/* Control */}\n <div\n class=\"bq-switch--control relative box-border flex justify-between rounded-full bg-ui-tertiary transition duration-300 bs-[--bq-switch--height] is-[--bq-switch--width] p-b-xs2 p-i-xs2 group-[&.is-checked]:bg-ui-brand\"\n part=\"control\"\n >\n {this.innerLabel === 'icon' && (\n <bq-icon\n class=\"bq-switch--control__icon on\"\n name=\"check\"\n color=\"icon--alt\"\n role=\"img\"\n title=\"On\"\n part=\"icon-on\"\n />\n )}\n {this.innerLabel === 'icon' && (\n <bq-icon\n class=\"bq-switch--control__icon off\"\n name=\"x\"\n color=\"icon--inverse\"\n role=\"img\"\n title=\"Off\"\n part=\"icon-off\"\n />\n )}\n {/* Dot */}\n <div class=\"bq-switch--control__dot\" part=\"dot\" />\n </div>\n {/* Label */}\n <span\n class={{\n 'bq-switch--label text-m font-medium leading-regular text-primary transition-colors duration-300': true,\n 'ms-s': this.hasLabel && !this.reverseOrder,\n 'me-s': this.hasLabel && this.reverseOrder,\n }}\n ref={(span) => (this.labelElem = span)}\n part=\"label\"\n >\n <slot onSlotchange={this.handleSlotChange} />\n </span>\n </label>\n </Host>\n );\n }\n}\n"],"mappings":";;;;wIAAA,MAAMA,EAAc,+6vBACpB,MAAAC,EAAeD,E,MCsEFE,EAAQ,M,6RAIXC,UACAC,UACAC,iBAKWC,U,wBAOVC,SAAW,MAMKC,kBAA8B,MAGfC,QAAoB,MAGnCC,SAAqB,MAGrBC,sBAGAC,UAAsB,MAGtBC,WAAiC,UAMjCC,eAAyC,QAGzCC,KAGAC,SAAqB,MAGrBC,aAAyB,MAGzBC,MAMzB,oBAAAC,GACEC,KAAKC,oB,CAQEC,SAGAC,QAGAC,OAMT,iBAAAC,GACEL,KAAKf,iBAAmBe,KAAKX,O,CAG/B,gBAAAiB,GACEN,KAAKO,kB,CAGP,kBAAAC,GAME,GAAIR,KAAKX,UAAYW,KAAKf,iBAAkB,CAC1Ce,KAAKE,SAASO,KAAK,CAAEpB,QAASW,KAAKX,UACnCW,KAAKf,iBAAmBe,KAAKX,O,EAIjC,sBAAAqB,GACEV,KAAKW,aAAaX,KAAKX,SACvBW,KAAKC,oB,CAGP,iBAAAW,GAEEZ,KAAKX,QAAU,MACfW,KAAKhB,UAAU6B,gBAAgB,WAC/Bb,KAAKd,WAAWyB,aAAaG,WAC7Bd,KAAKC,oB,CAkBP,YAAMc,GACJf,KAAKhB,WAAWgC,O,CAQlB,YAAMC,GACJjB,KAAKhB,WAAWkC,O,CAQlB,WAAMC,GACJnB,KAAKhB,WAAWoC,M,CAQVC,aAAe,KACrBrB,KAAKX,SAAWW,KAAKX,QACrBW,KAAKhB,UAAUsC,aAAa,UAAW,GAAGtB,KAAKX,WAC/CW,KAAKW,aAAaX,KAAKX,SACvBW,KAAKC,oBAAoB,EAGnBsB,cAAgB,KACtBvB,KAAKG,QAAQM,KAAKT,KAAKwB,GAAG,EAGpBC,aAAe,KACrBzB,KAAKI,OAAOK,KAAKT,KAAKwB,GAAG,EAGnBjB,iBAAmB,KACzB,MAAMmB,EAAO1B,KAAKjB,WAAW4C,cAAc,SAAW,KACtD,GAAIC,EAAMF,GAAO,OAEjB1B,KAAKb,WAAa0C,EAAeH,EAAM,CAAEI,QAAS,OAAQC,MAAM,EAG1DpB,aAAgBtB,IACtB,MAAMS,EAAQT,EAAU,KAAOyB,UAI/Bd,KAAKd,WAAWyB,aAAab,EAAO,GAAGE,KAAKX,UAAU,EAGhDY,mBAAqB,KAC3B,MAAMV,sBAAEA,EAAqBL,UAAEA,EAASU,SAAEA,EAAQP,QAAEA,EAAOL,UAAEA,GAAcgB,KAE3Ed,GAAW8C,OAAOC,QAElB,KAAMrC,IAAaP,GAAU,CAE3BH,GAAW8C,OAAOE,IAAI,SACtBhD,GAAWiD,YAAY,IACvB,M,CAIFjD,GAAW8C,OAAOE,IAAI,WACtBhD,GAAWiD,YAAY,CAAEC,aAAc,MAAQ7C,EAAuBP,EAAU,EAOlF,MAAAqD,GACE,MAAMC,EAAY,IACZtC,KAAKN,gBAAkB,CAAE,+BAAgCM,KAAKN,iBAGpE,MAAM6C,EAAkB,CACtB,iBAAkBvC,KAAKZ,kBACvB,aAAcY,KAAKX,QACnB,cAAeW,KAAKV,SACpB,mBAAoBU,KAAKH,cAG3B,OACE2C,EAACC,EAAI,CAAAC,IAAA,2CAACC,MAAO,CAAE,aAAc3C,KAAKR,WAAaoD,MAAON,GACpDE,EAAA,SAAAE,IAAA,2CAAOC,MAAO,CAAE,kBAAmB,QAASJ,GAAmBM,KAAK,QAElEL,EAAA,SAAAE,IAAA,2CACEC,MAAM,4GACNG,KAAK,WACLzD,QAASW,KAAKX,QACdC,SAAUU,KAAKV,SACfM,SAAUI,KAAKJ,SACfD,MAAOiC,EAAM5B,KAAKL,MAAQK,KAAKL,KAAOmB,UAAS,aACnCd,KAAKL,KAAI,eACPK,KAAKX,QAAU,OAAS,QAAO,gBAC9BW,KAAKV,SAAW,OAAS,QACxCyD,OAAQ/C,KAAKyB,aACbuB,SAAUhD,KAAKqB,aACf4B,QAASjD,KAAKuB,cACd2B,IAAMC,GAAWnD,KAAKhB,UAAYmE,EAClCC,KAAK,SACLtD,MAAOE,KAAKF,QAGd0C,EAAA,OAAAE,IAAA,2CACEC,MAAM,oNACNE,KAAK,WAEJ7C,KAAKP,aAAe,QACnB+C,EAAA,WAAAE,IAAA,2CACEC,MAAM,8BACNhD,KAAK,QACL0D,MAAM,YACND,KAAK,MACLE,MAAM,KACNT,KAAK,YAGR7C,KAAKP,aAAe,QACnB+C,EAAA,WAAAE,IAAA,2CACEC,MAAM,+BACNhD,KAAK,IACL0D,MAAM,gBACND,KAAK,MACLE,MAAM,MACNT,KAAK,aAITL,EAAA,OAAAE,IAAA,2CAAKC,MAAM,0BAA0BE,KAAK,SAG5CL,EAAA,QAAAE,IAAA,2CACEC,MAAO,CACL,kGAAmG,KACnG,OAAQ3C,KAAKb,WAAaa,KAAKH,aAC/B,OAAQG,KAAKb,UAAYa,KAAKH,cAEhCqD,IAAMK,GAAUvD,KAAKjB,UAAYwE,EACjCV,KAAK,SAELL,EAAA,QAAAE,IAAA,2CAAMc,aAAcxD,KAAKO,qB","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["PROGRESS_BORDER_SHAPE","PROGRESS_THICKNESS","PROGRESS_TYPE","bqProgressCss","BqProgressStyle0","BqProgress","borderShape","enableTooltip","indeterminate","label","thickness","type","value","handleTypePropChange","validatePropValue","this","el","handleValuePropChange","newValue","validateValue","componentWillLoad","clampedValue","Math","max","min","render","style","h","Host","key","class","part","undefined","exportparts","alwaysVisible","distance","insetInlineStart","fontVariant","slot"],"sources":["../../packages/beeq/src/components/progress/bq-progress.types.ts","../../packages/beeq/src/components/progress/scss/bq-progress.scss?tag=bq-progress&encapsulation=shadow","../../packages/beeq/src/components/progress/bq-progress.tsx"],"sourcesContent":["export const PROGRESS_BORDER_SHAPE = ['square', 'rounded'] as const;\nexport type TProgressBorderShape = (typeof PROGRESS_BORDER_SHAPE)[number];\n\nexport const PROGRESS_THICKNESS = ['medium', 'large'] as const;\nexport type TProgressThickness = (typeof PROGRESS_THICKNESS)[number];\n\nexport const PROGRESS_TYPE = ['default', 'error'] as const;\nexport type TProgressType = (typeof PROGRESS_TYPE)[number];\n","/* -------------------------------------------------------------------------- */\n/* Progress styles */\n/* -------------------------------------------------------------------------- */\n\n@import './bq-progress.variables';\n\n@layer component {\n @keyframes move-indeterminate {\n 0% {\n inset-inline-start: 0;\n }\n\n 100% {\n inset-inline-start: calc(100% - var(--bq-progress-bar--indeterminateWidth));\n }\n }\n\n .animate-indeterminate {\n animation: move-indeterminate 1s linear 0s infinite alternate-reverse;\n }\n}\n\n.progress-bar {\n @apply relative appearance-none bs-[--bq-progress-bar--height] is-full;\n}\n\n.progress-bar::-webkit-progress-bar {\n @apply bg-[--bq-progress-bar--trackColor];\n}\n\n.progress-bar::-webkit-progress-value {\n @apply bg-[--bq-progress-bar--indicatorColor];\n}\n\n.progress-bar::-moz-progress-bar {\n @apply animate-indeterminate bg-[--bq-progress-bar--indicatorColor];\n}\n\n.progress-bar:indeterminate::-moz-progress-bar {\n @apply bg-[--bq-progress-bar--trackColor];\n}\n\n.progress-bar.progress-bar__border-shape::-webkit-progress-value,\n.progress-bar.progress-bar__border-shape::-webkit-progress-bar {\n @apply rounded-full;\n}\n\n.progress-bar__indeterminate {\n @apply animate-indeterminate;\n}\n\n.progress-bar.progress-bar__border-shape::-moz-progress-bar {\n @apply animate-indeterminate rounded-full;\n}\n","import { Component, Element, h, Host, Prop, Watch } from '@stencil/core';\n\nimport {\n PROGRESS_BORDER_SHAPE,\n PROGRESS_THICKNESS,\n PROGRESS_TYPE,\n TProgressBorderShape,\n TProgressThickness,\n TProgressType,\n} from './bq-progress.types';\nimport { validatePropValue } from '../../shared/utils';\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=\"relative flex items-center is-full\" 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 value={this.indeterminate ? undefined : this.value}\n max=\"100\"\n part=\"progress-bar\"\n />\n {this.enableTooltip && !this.indeterminate && (\n <bq-tooltip\n class=\"absolute [&::part(panel)]:absolute\"\n exportparts=\"base,trigger,panel\"\n alwaysVisible={true}\n distance={16}\n style={{ insetInlineStart: `${this.value}%`, fontVariant: 'tabular-nums' }}\n >\n <div class=\"absolute bs-1 is-1\" slot=\"trigger\"></div>\n {this.value}\n </bq-tooltip>\n )}\n {this.indeterminate && (\n <div\n class={{\n 'progress-bar__indeterminate absolute bg-[--bq-progress-bar--indicatorColor] bs-[--bq-progress-bar--height] is-[--bq-progress-bar--indeterminateWidth]':\n 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 'invisible ms-0 is-0': !this.label || this.indeterminate,\n }}\n style={{ fontVariant: 'tabular-nums' }}\n part=\"label\"\n >\n <span>{this.value}%</span>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"mappings":";;;;6FAAO,MAAMA,EAAwB,CAAC,SAAU,WAGzC,MAAMC,EAAqB,CAAC,SAAU,SAGtC,MAAMC,EAAgB,CAAC,UAAW,SCNzC,MAAMC,EAAgB,q+rBACtB,MAAAC,EAAeD,E,MCmDFE,EAAU,M,iDAiBIC,YAAoC,UAGpCC,cAAyB,MAGzBC,cAAyB,MAGzBC,MAAiB,MAGjBC,UAAgC,SAGhCC,KAAsB,UAGPC,MAAQ,EAQhD,oBAAAC,GACEC,EAAkBd,EAAuB,UAAWe,KAAKC,GAAI,eAC7DF,EAAkBb,EAAoB,SAAUc,KAAKC,GAAI,aACzDF,EAAkBZ,EAAe,UAAWa,KAAKC,GAAI,O,CAIvD,qBAAAC,CAAsBC,GACpBH,KAAKI,cAAcD,E,CAWrB,iBAAAE,GACEL,KAAKF,uBACLE,KAAKE,sBAAsBF,KAAKH,M,CAkB1B,aAAAO,CAAcD,GACpB,MAAMG,EAAeC,KAAKC,IAAI,EAAGD,KAAKE,IAAI,IAAKN,IAC/C,GAAIA,IAAaG,EAAc,CAC7BN,KAAKH,MAAQS,C,CAEf,OAAON,KAAKH,K,CAOd,MAAAa,GACE,MAAMC,EAAQ,IACRX,KAAKL,YAAc,SAAW,CAAE,4BAA6B,2BAC7DK,KAAKJ,OAAS,SAAW,CAAE,oCAAqC,yBAGtE,OACEgB,EAACC,EAAI,CAAAC,IAAA,2CAACH,MAAOA,GACXC,EAAA,OAAAE,IAAA,2CAAKC,MAAM,oBAAoBC,KAAK,WAClCJ,EAAA,OAAAE,IAAA,2CAAKC,MAAM,qCAAqCC,KAAK,YACnDJ,EAAA,YAAAE,IAAA,2CACEC,MAAO,CACL,CAAC,8BAA8Bf,KAAKJ,QAAQI,KAAKL,aAAc,KAC/D,0CAA2CK,KAAKT,cAAgB,WAElEM,MAAOG,KAAKP,cAAgBwB,UAAYjB,KAAKH,MAC7CW,IAAI,MACJQ,KAAK,iBAENhB,KAAKR,gBAAkBQ,KAAKP,eAC3BmB,EAAA,cAAAE,IAAA,2CACEC,MAAM,qCACNG,YAAY,qBACZC,cAAe,KACfC,SAAU,GACVT,MAAO,CAAEU,iBAAkB,GAAGrB,KAAKH,SAAUyB,YAAa,iBAE1DV,EAAA,OAAAE,IAAA,2CAAKC,MAAM,qBAAqBQ,KAAK,YACpCvB,KAAKH,OAGTG,KAAKP,eACJmB,EAAA,OAAAE,IAAA,2CACEC,MAAO,CACL,wJACE,KACF,eAAgBf,KAAKT,cAAgB,WAEvCyB,KAAK,mBAIXJ,EAAA,OAAAE,IAAA,0DACgBd,KAAKN,OAASM,KAAKP,cAAgB,OAAS,QAC1DsB,MAAO,CACL,oCAAqC,KACrC,eAAgBf,KAAKJ,OAAS,QAC9B,cAAeI,KAAKJ,OAAS,QAC7B,uBAAwBI,KAAKN,OAASM,KAAKP,eAE7CkB,MAAO,CAAEW,YAAa,gBACtBN,KAAK,SAELJ,EAAA,QAAAE,IAAA,4CAAOd,KAAKH,MAAK,O","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["CARD_TYPE","bqCardCss","BqCardStyle0","BqCard","type","border","checkPropValue","validatePropValue","this","el","componentWillLoad","render","style","h","Host","key","class","part"],"sources":["../../packages/beeq/src/components/card/bq-card.types.ts","../../packages/beeq/src/components/card/scss/bq-card.scss?tag=bq-card&encapsulation=shadow","../../packages/beeq/src/components/card/bq-card.tsx"],"sourcesContent":["export const CARD_TYPE = ['default', 'minimal'] as const;\nexport type TCardType = (typeof CARD_TYPE)[number];\n\nexport const CARD_BORDER_RADIUS = ['none', 'xs2', 'xs', 's', 'm', 'l', 'full'] as const;\nexport type TCardBorderRadius = (typeof CARD_BORDER_RADIUS)[number];\n","/* -------------------------------------------------------------------------- */\n/* Card styles */\n/* -------------------------------------------------------------------------- */\n\n@import './bq-card.variables';\n\n:host {\n @apply block;\n}\n\n.bq-card {\n border-style: var(--bq-card--borderStyle);\n}\n","import { Component, Element, h, Host, Prop, Watch } from '@stencil/core';\n\nimport { CARD_TYPE, TCardBorderRadius, TCardType } from './bq-card.types';\nimport { validatePropValue } from '../../shared/utils';\n\n/**\n * The Card component serves as a versatile container designed for flexible content presentation within user interfaces.\n * Its structure accommodates various styles, allowing users to customize and adapt it according to their design preferences.\n *\n * @example How to use it\n * ```html\n * <bq-card type=\"default\" border=\"m\">\n * <div class=\"p-m\">\n * <h3 class=\"text-xl font-bold\">Card Title</h3>\n * <p class=\"text-m\">Card content goes here</p>\n * </div>\n * </bq-card>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/522abb-card\n * @status stable\n *\n * @attr {\"default\" | \"minimal\"} type - Type of card component\n * @attr {\"none\" | \"xs2\" | \"xs\" | \"s\" | \"m\" | \"l\" | \"full\"} border - The corner radius of the card component\n *\n * @slot - The content of the card component\n *\n * @part wrapper - The wrapper container `<div>` of the element inside the shadow DOM\n *\n * @cssprop --bq-card--borderColor - Card border color\n * @cssprop --bq-card--borderRadius - Card border radius\n * @cssprop --bq-card--borderStyle - Card border style\n * @cssprop --bq-card--borderWidth - Card border width\n *\n * @cssprop --bq-card--padding - Card padding\n * @cssprop --bq-card--paddingMinimal - Minimal card padding\n * @cssprop --bq-card--background - Card background color\n */\n@Component({\n tag: 'bq-card',\n styleUrl: './scss/bq-card.scss',\n shadow: true,\n})\nexport class BqCard {\n // Own Properties\n // ====================\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqCardElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n // Public Property API\n // ========================\n\n /** Type of card component */\n @Prop({ reflect: true }) type: TCardType = 'default';\n\n /** The corner radius of the card component */\n @Prop({ reflect: true }) border: TCardBorderRadius = 'm';\n\n // Prop lifecycle events\n // =======================\n\n @Watch('type')\n checkPropValue() {\n validatePropValue(CARD_TYPE, 'default', this.el, 'type');\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.checkPropValue();\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 // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n const style = {\n ...(this.border && { '--bq-card--borderRadius': `var(--bq-radius--${this.border})` }),\n };\n return (\n <Host style={style}>\n <div\n class={{\n 'bq-card rounded-[--bq-card--borderRadius] border-[length:--bq-card--borderWidth] border-[color:--bq-card--borderColor] bg-[--bq-card--background]':\n true,\n 'p-b-[--bq-card--padding] p-i-[--bq-card--padding]': this.type === 'default',\n // Remove padding for minimal card type\n 'p-b-0 p-i-0': this.type === 'minimal',\n }}\n part=\"wrapper\"\n >\n <slot />\n </div>\n </Host>\n );\n }\n}\n"],"mappings":";;;;6FAAO,MAAMA,EAAY,CAAC,UAAW,WCArC,MAAMC,EAAY,49nBAClB,MAAAC,EAAeD,E,MC0CFE,EAAM,M,iDAiBQC,KAAkB,UAGlBC,OAA4B,IAMrD,cAAAC,GACEC,EAAkBP,EAAW,UAAWQ,KAAKC,GAAI,O,CAWnD,iBAAAC,GACEF,KAAKF,gB,CAsBP,MAAAK,GACE,MAAMC,EAAQ,IACRJ,KAAKH,QAAU,CAAE,0BAA2B,oBAAoBG,KAAKH,YAE3E,OACEQ,EAACC,EAAI,CAAAC,IAAA,2CAACH,MAAOA,GACXC,EAAA,OAAAE,IAAA,2CACEC,MAAO,CACL,oJACE,KACF,oDAAqDR,KAAKJ,OAAS,UAEnE,cAAeI,KAAKJ,OAAS,WAE/Ba,KAAK,WAELJ,EAAA,QAAAE,IAAA,8C","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["bqAccordionGroupCss","BqAccordionGroupStyle0","BqAccordionGroup","appearance","expandAll","noAnimation","multiple","size","checkPropValues","this","bqAccordionElements","forEach","bqAccordionElement","isNil","expanded","onBqClick","event","detail","bqElem","isHTMLElement","el","contains","componentWillLoad","Array","from","querySelectorAll","render","h","key","class","part"],"sources":["../../packages/beeq/src/components/accordion-group/scss/bq-accordion-group.scss?tag=bq-accordion-group&encapsulation=shadow","../../packages/beeq/src/components/accordion-group/bq-accordion-group.tsx"],"sourcesContent":["/* -------------------------------------------------------------------------- */\n/* Accordion group styles */\n/* -------------------------------------------------------------------------- */\n\n@import './bq-accordion-group.variables';\n\n:host {\n @apply block;\n}\n","import { Component, Element, h, Listen, Prop, Watch } from '@stencil/core';\n\nimport { isHTMLElement, isNil } from '../../shared/utils';\nimport { TAccordionAppearance, TAccordionSize } from '../accordion/bq-accordion.types';\n\n/**\n * The accordion group component is a container for multiple accordion elements.\n * It allows to manage the appearance and size of all accordions at once.\n *\n * @example How to use it\n * ```html\n * <bq-accordion-group appearance=\"filled\" size=\"medium\">\n * <bq-accordion> ... </bq-accordion>\n * <bq-accordion> ... </bq-accordion>\n * <bq-accordion> ... </bq-accordion>\n * </bq-accordion-group>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/713eae-accordion\n * @status stable\n *\n * @attr {\"filled\" | \"ghost\"} [appearance=\"filled\"] - The appearance style of accordion to be applied to all accordions\n * @attr {boolean} [expandAll=false] - If true all accordions are expanded\n * @attr {boolean} [no-animation=false] - Animation is set through JS when the browser does not support CSS calc-size() If true, the accordion animation, will be disabled. No animation will be applied.\n * @attr {boolean} [multiple=false] - If true multiple accordions can be expanded at the same time\n * @attr {\"small\" | \"medium\"} [size=\"medium\"] - The size of accordion to be applied to all accordions\n *\n * @slot - The default slot where the bq-accordion elements are placed.\n *\n * @part base - The component's base wrapper.\n *\n * @cssprop --bq-accordion-group--gap - Accordion group distance between elements\n */\n@Component({\n tag: 'bq-accordion-group',\n styleUrl: './scss/bq-accordion-group.scss',\n shadow: true,\n})\nexport class BqAccordionGroup {\n // Own Properties\n // ====================\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqAccordionGroupElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n // Public Property API\n // ========================\n\n /** The appearance style of accordion to be applied to all accordions */\n @Prop({ reflect: true, mutable: true }) appearance: TAccordionAppearance = 'filled';\n\n /** If true all accordions are expanded */\n @Prop({ reflect: true }) expandAll: boolean;\n\n /**\n * Animation is set through JS when the browser does not support CSS calc-size()\n * If true, the accordion animation, will be disabled. No animation will be applied.\n */\n @Prop({ reflect: true }) noAnimation: boolean = false;\n\n /** If true multiple accordions can be expanded at the same time */\n @Prop({ reflect: true }) multiple: boolean = false;\n\n /** The size of accordion to be applied to all accordions */\n @Prop({ reflect: true, mutable: true }) size: TAccordionSize = 'medium';\n\n // Prop lifecycle events\n // =======================\n\n @Watch('appearance')\n @Watch('expandAll')\n @Watch('noAnimation')\n @Watch('size')\n checkPropValues() {\n this.bqAccordionElements.forEach((bqAccordionElement) => {\n // NOTE: if expandAll is nil we will keep accordion default state\n if (!isNil(this.expandAll)) {\n bqAccordionElement.expanded = this.expandAll;\n }\n bqAccordionElement.appearance = this.appearance;\n bqAccordionElement.noAnimation = this.noAnimation;\n bqAccordionElement.size = this.size;\n });\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n @Listen('bqClick', { passive: true })\n onBqClick(event: CustomEvent<HTMLBqAccordionElement>) {\n const { detail: bqElem } = event;\n // Make sure the event is coming from a bq-accordion element and its a child of the bq-accordion-group\n if (!isHTMLElement(bqElem, 'bq-accordion') || !this.el.contains(bqElem)) return;\n // We keep default behavior if multiple accordion can be expanded\n if (this.multiple) return;\n\n this.bqAccordionElements.forEach((bqAccordionElement) => {\n if (bqAccordionElement === event.detail) return;\n\n bqAccordionElement.expanded = false;\n });\n }\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n componentWillLoad() {\n this.checkPropValues();\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 get bqAccordionElements(): HTMLBqAccordionElement[] {\n return Array.from(this.el.querySelectorAll('bq-accordion'));\n }\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <div class=\"flex flex-col gap-[--bq-accordion-group--gap]\" part=\"base\">\n <slot />\n </div>\n );\n }\n}\n"],"mappings":";;;;0HAAA,MAAMA,EAAsB,wpmBAC5B,MAAAC,EAAeD,E,MCqCFE,EAAgB,M,iDAiBaC,WAAmC,SAGlDC,UAMAC,YAAuB,MAGvBC,SAAoB,MAGLC,KAAuB,SAS/D,eAAAC,GACEC,KAAKC,oBAAoBC,SAASC,IAEhC,IAAKC,EAAMJ,KAAKL,WAAY,CAC1BQ,EAAmBE,SAAWL,KAAKL,S,CAErCQ,EAAmBT,WAAaM,KAAKN,WACrCS,EAAmBP,YAAcI,KAAKJ,YACtCO,EAAmBL,KAAOE,KAAKF,IAAI,G,CASvC,SAAAQ,CAAUC,GACR,MAAQC,OAAQC,GAAWF,EAE3B,IAAKG,EAAcD,EAAQ,kBAAoBT,KAAKW,GAAGC,SAASH,GAAS,OAEzE,GAAIT,KAAKH,SAAU,OAEnBG,KAAKC,oBAAoBC,SAASC,IAChC,GAAIA,IAAuBI,EAAMC,OAAQ,OAEzCL,EAAmBE,SAAW,KAAK,G,CAQvC,iBAAAQ,GACEb,KAAKD,iB,CAkBP,uBAAYE,GACV,OAAOa,MAAMC,KAAKf,KAAKW,GAAGK,iBAAiB,gB,CAM7C,MAAAC,GACE,OACEC,EAAA,OAAAC,IAAA,2CAAKC,MAAM,gDAAgDC,KAAK,QAC9DH,EAAA,QAAAC,IAAA,6C","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["DATE_PICKER_TYPE","CALLY_SCRIPT_ATTRIBUTE","CALLY_LIB_VERSION","CALLY_LIB_HASH","isLibraryLoaded","isCallyLibraryLoaded","document","querySelector","loadCallyLibrary","async","loadScript","type","src","attributes","crossOrigin","integrity","error","Error","message","Promise","resolve","reject","script","createElement","onload","onerror","Object","entries","forEach","key","value","setAttribute","head","appendChild","bqDatePickerCss","BqDatePickerStyle0","BqDatePicker","callyElem","inputElem","labelElem","prefixElem","suffixElem","fallbackInputId","COMMON_EXPORT_PARTS","BUTTON_EXPORT_PARTS","internals","isCallyLoaded","focusedDate","displayDate","hasLabel","hasPrefix","hasRangeEnd","hasSuffix","hasValue","autofocus","clearButtonLabel","disableClear","disabled","distance","firstDayOfWeek","formatOptions","day","month","year","form","formValidationMessage","isDateDisallowed","locale","max","min","months","monthsPerView","name","open","panelHeight","placeholder","placement","required","skidding","showOutsideDays","strategy","tentative","validationStatus","handleValueChange","formatDisplayValue","this","setFormValue","isNil","undefined","updateFormValidity","Array","isArray","some","val","length","isDefined","setFocusedDate","checkPropValues","validatePropValue","el","bqBlur","bqChange","bqClear","bqFocus","connectedCallback","isClient","console","componentDidLoad","handleSlotChange","formAssociatedCallback","formResetCallback","clear","handleOpenChange","ev","composedPath","includes","detail","handleClickOutside","button","isEventTargetChildOfElement","emit","handleBlur","handleFocus","formatFocusedDate","Date","toLocaleDateString","handleChange","isHTMLElement","target","dateValue","isNaN","getTime","handleCalendarChange","focus","handleCalendarRangeStart","handleCalendarRangeEnd","handleClearClick","stopPropagation","hasSlotContent","generateCalendarMonth","offset","className","h","class","exportparts","generateCalendarMonths","from","_","i","dateRegex","match","exec","dateFormatter","Intl","DateTimeFormat","start","end","split","map","dateStr","formatRange","dates","date","format","join","states","toString","trim","add","setValidity","valueMissing","CalendarType","componentTypes","single","multi","range","render","CallyCalendar","labelId","part","id","htmlFor","ref","onSlotchange","slot","spanElem","autoComplete","autoCapitalize","readonly","spellcheck","onBlur","onFocus","onChange","appearance","size","onBqClick","pageBy","onRangestart","onRangeend","elem","color","label"],"sources":["../../packages/beeq/src/components/date-picker/bq-date-picker.types.ts","../../packages/beeq/src/components/date-picker/helper/callyLibrary.ts","../../packages/beeq/src/components/date-picker/scss/bq-date-picker.scss?tag=bq-date-picker&encapsulation=shadow","../../packages/beeq/src/components/date-picker/bq-date-picker.tsx"],"sourcesContent":["export type DaysOfWeek = 0 | 1 | 2 | 3 | 4 | 5 | 6;\n\nexport const DATE_PICKER_TYPE = ['single', 'multi', 'range'] as const;\nexport type TDatePickerType = (typeof DATE_PICKER_TYPE)[number];\n\nexport type TCalendarDate = {\n focusedDate: string;\n value: string;\n min?: string;\n max?: string;\n months?: number;\n tentative?: string;\n pageBy?: 'single' | 'months';\n firstDayOfWeek?: number;\n showOutsideDays?: boolean;\n isDateDisallowed?: (date: Date) => boolean;\n locale?: string;\n onChange?: (ev: Event) => void;\n onRangestart?: (ev: CustomEvent) => void;\n onRangeend?: (ev: CustomEvent) => void;\n};\n","/* -------------------------------------------------------------------------- */\n/* Cally Library loader helper */\n/* -------------------------------------------------------------------------- */\n\nconst CALLY_SCRIPT_ATTRIBUTE = 'data-cally-library';\n//❗ Make sure to update the version here when the library releases a new version\nconst CALLY_LIB_VERSION = '0.8.0';\n/**\n * ❗ Make sure to update the hash here if the `CALLY_LIB_VERSION` is updated\n * This hash is used to ensure the integrity of the library when loading it\n * from a CDN.\n * @see https://developer.mozilla.org/en-US/docs/Web/Security/Subresource_Integrity\n */\nconst CALLY_LIB_HASH = 'sha384-giuY/f8D3+ehgOTmQMr4HvrreOITDmvXsZuDCJ1csQ+3dURHA24NqRd8lkSI6uGF';\n\nlet isLibraryLoaded = false;\n\n/**\n * Checks if the Cally library is already loaded in the document\n * @returns {boolean} True if the library is loaded\n */\nexport const isCallyLibraryLoaded = (): boolean => {\n // This might be a bit redundant, but it's a sanity check to ensure the library is actually loaded\n return isLibraryLoaded || document.querySelector(`script[${CALLY_SCRIPT_ATTRIBUTE}]`) !== null;\n};\n\n/**\n * Loads the Cally library for the date picker component\n * @throws {Error} If the library fails to load\n * @return {Promise<void>}\n */\nexport const loadCallyLibrary = async (): Promise<void> => {\n if (isCallyLibraryLoaded()) return;\n\n try {\n await loadScript({\n type: 'module',\n src: `https://unpkg.com/cally@${CALLY_LIB_VERSION}/dist/cally.js`,\n attributes: {\n [CALLY_SCRIPT_ATTRIBUTE]: '',\n crossOrigin: 'anonymous',\n integrity: CALLY_LIB_HASH,\n },\n });\n\n isLibraryLoaded = true;\n } catch (error) {\n isLibraryLoaded = false;\n throw new Error(`Failed to load the cally library: ${error instanceof Error ? error.message : 'Unknown error'}`);\n }\n};\n\ninterface ScriptConfig {\n type: string;\n src: string;\n attributes?: Record<string, string>;\n}\n\n/**\n * Helper function to load a script with given configuration\n * @param {Object} config - Script configuration\n * @param {string} config.type - The type of the script\n * @param {string} config.src - The source URL of the script\n * @param {Object} [config.attributes] - Additional attributes to set on the script element\n * @returns {Promise<void>}\n */\nconst loadScript = ({ type, src, attributes = {} }: ScriptConfig): Promise<void> => {\n return new Promise<void>((resolve, reject) => {\n const script = document.createElement('script');\n script.type = type;\n script.src = src;\n\n script.onload = () => resolve();\n script.onerror = (error: Event) =>\n reject(new Error(`Failed to load script: ${src}, ${error instanceof Error ? error.message : 'Unknown error'}`));\n\n Object.entries(attributes).forEach(([key, value]) => {\n script.setAttribute(key, value);\n });\n\n document.head.appendChild(script);\n });\n};\n","/* -------------------------------------------------------------------------- */\n/* Date picker styles */\n/* -------------------------------------------------------------------------- */\n\n@import './bq-date-picker.variables';\n\n:host {\n @apply block is-full;\n}\n\n/* -------------------------------------------------------------------------- */\n/* Label */\n/* -------------------------------------------------------------------------- */\n\n.bq-date-picker__label {\n @apply flex flex-grow items-center gap-[--bq-date-picker--gap] m-be-[--bq-date-picker--label-margin-bottom];\n @apply text-[length:--bq-date-picker--label-text-size] text-[color:--bq-date-picker--label-text-color];\n}\n\n/* -------------------------------------------------------------------------- */\n/* Date picker input group control */\n/* -------------------------------------------------------------------------- */\n\n.bq-date-picker__control {\n @apply flex items-center transition-[border-color,box-shadow] is-full;\n // Border\n @apply rounded-[--bq-date-picker--border-radius] border-[length:--bq-date-picker--border-width] border-[color:--bq-date-picker--border-color];\n // Padding\n @apply pe-[--bq-date-picker--padding-end] ps-[--bq-date-picker--padding-start] p-b-[--bq-date-picker--paddingY];\n // Text\n @apply select-none text-[length:--bq-date-picker--text-size] text-[color:--bq-date-picker--text-color] placeholder:text-[color:--bq-date-picker--text-placeholder-color];\n // Hover\n @apply [&:not(.disabled):not(:focus-within)]:hover:border-hover-brand;\n\n border-style: var(--bq-date-picker--border-style);\n\n // Focus\n &:not(.disabled):focus-within {\n --bq-ring-width: 1px;\n --bq-ring-offset-width: 0;\n\n @apply focus border-[color:--bq-focus];\n }\n\n // Enable clear button whenever the input group control is hovered or has focus\n &:not(.disabled):hover,\n &:not(.disabled):focus-within {\n .bq-date-picker__control--clear {\n @apply inline-block;\n }\n }\n}\n\n.bq-date-picker__control.disabled {\n @apply cursor-not-allowed opacity-60;\n}\n\n/* ------------------------------- Validation ------------------------------- */\n\n.bq-date-picker__control.validation-error {\n @apply border-danger [&:not(.disabled):not(:focus-within)]:hover:border-hover-danger;\n\n &:not(.disabled):focus-within {\n --bq-ring-color-focus: theme(stroke.danger);\n\n @apply border-active-danger;\n }\n}\n\n.bq-date-picker__control.validation-success {\n @apply border-success [&:not(.disabled):not(:focus-within)]:hover:border-hover-success;\n\n &:not(.disabled):focus-within {\n --bq-ring-color-focus: theme(stroke.success);\n\n @apply border-active-success;\n }\n}\n\n.bq-date-picker__control.validation-warning {\n @apply border-warning [&:not(.disabled):not(:focus-within)]:hover:border-hover-warning;\n\n &:not(.disabled):focus-within {\n --bq-ring-color-focus: theme(stroke.warning);\n\n @apply border-active-warning;\n }\n}\n\n/* -------------------------------------------------------------------------- */\n/* Native HTML Input */\n/* -------------------------------------------------------------------------- */\n\n.bq-date-picker__control--input {\n @apply flex-auto cursor-inherit select-none appearance-none bg-inherit font-inherit text-[length:inherit] text-inherit;\n @apply border-none min-bs-[--bq-date-picker--icon-size] min-is-0 p-b-0 p-i-0 m-b-0 m-i-0 focus:outline-none focus-visible:outline-none;\n}\n\n/* -------------------------------------------------------------------------- */\n/* Clear button */\n/* -------------------------------------------------------------------------- */\n\n.bq-date-picker__control--clear::part(button) {\n // Since the clear button is inside the input group control,\n // we need to reset the focus ring styles\n --bq-ring-width: initial;\n --bq-ring-offset-width: initial;\n --bq-ring-color-focus: initial;\n\n @apply rounded-xs border-none bs-auto p-b-0 p-i-0;\n}\n\n/* -------------------------------------------------------------------------- */\n/* Prefix and suffix */\n/* -------------------------------------------------------------------------- */\n\n.bq-date-picker__control--prefix,\n.bq-date-picker__control--suffix {\n @apply pointer-events-none flex items-center text-[color:--bq-date-picker--text-color];\n}\n\n.bq-date-picker__control--prefix {\n @apply me-[--bq-date-picker--gap];\n}\n\n.bq-date-picker__control--suffix {\n @apply ms-[--bq-date-picker--gap];\n}\n\n/* -------------------------------------------------------------------------- */\n/* Slotted and internal icons */\n/* -------------------------------------------------------------------------- */\n\nbq-icon,\n::slotted(bq-icon) {\n --bq-icon--size: var(--bq-date-picker--icon-size) !important;\n}\n\n/* -------------------------------------------------------------------------- */\n/* Customize Cally date picker */\n/* -------------------------------------------------------------------------- */\n\ncalendar-date,\ncalendar-range,\ncalendar-multi {\n &::part(header) {\n @apply justify-center gap-s;\n }\n\n &::part(heading) {\n @apply p-b-xs2 p-i-xs;\n }\n\n &::part(button) {\n @apply rounded-s border-0 bg-transparent transition-colors duration-200 p-b-xs2 p-i-xs2;\n @apply focus-visible:focus hover:bg-hover-ui-primary;\n }\n\n &::part(container) {\n @apply bg-[--bq-date-picker--background-color] p-b-0 p-i-0;\n }\n}\n\ncalendar-month {\n /* stylelint-disable-next-line custom-property-pattern */\n --color-accent: var(--bq-ui--brand);\n\n &::part(button) {\n @apply flex items-center justify-center rounded-s bg-transparent font-default text-primary transition-colors duration-200 ease-in-out p-b-0 p-i-0;\n @apply size-[--bq-date-picker--day-size] focus-visible:focus enabled:hover:bg-hover-secondary disabled:cursor-not-allowed;\n }\n\n &::part(button day disallowed) {\n @apply cursor-not-allowed bg-transparent #{!important};\n }\n\n &::part(button day selected) {\n @apply rounded-s bg-[--bq-date-picker--range-background-color] text-alt enabled:hover:bg-hover-ui-brand;\n }\n\n &::part(button day selected range-inner) {\n @apply rounded-none bg-[--bq-date-picker--range-inner-background-color] text-primary hover:text-alt;\n }\n\n &::part(button day outside) {\n @apply cursor-pointer text-secondary opacity-100;\n }\n\n &::part(today) {\n @apply rounded-s border-[length:--bq-date-picker--currentDate-border-width] border-[color:--bq-date-picker--currentDate-border-color];\n\n border-style: var(--bq-date-picker--border-style);\n }\n\n &::part(today selected) {\n @apply text-alt;\n }\n\n &::part(today range-inner) {\n @apply rounded-none;\n }\n\n &::part(today range-start) {\n @apply rounded-s rounded-es-none;\n }\n\n &::part(today range-end) {\n @apply rounded-s rounded-ee-none;\n }\n\n &::part(range-start) {\n @apply rounded-ee-none rounded-se-none;\n }\n\n &::part(range-end) {\n @apply rounded-es-none rounded-ss-none;\n }\n\n &::part(range-start range-end) {\n @apply rounded-s;\n }\n}\n","import {\n AttachInternals,\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Listen,\n Method,\n Prop,\n State,\n Watch,\n} from '@stencil/core';\n\nimport { DATE_PICKER_TYPE, DaysOfWeek, TCalendarDate, TDatePickerType } from './bq-date-picker.types';\nimport { isCallyLibraryLoaded, loadCallyLibrary } from './helper/callyLibrary';\nimport { Placement } from '../../services/interfaces';\nimport {\n hasSlotContent,\n isClient,\n isDefined,\n isEventTargetChildOfElement,\n isHTMLElement,\n isNil,\n validatePropValue,\n} from '../../shared/utils';\nimport { TInputValidation } from '../input/bq-input.types';\n\n/**\n * The Date Picker is a intuitive UI element component allows users to select dates from a visual calendar interface, providing an intuitive way to input date information.\n *\n * @example How to use it\n * ```html\n * <bq-date-picker\n * first-day-of-week=\"1\"\n * locale=\"en-GB\"\n * months-per-view=\"single\"\n * months=\"2\"\n * name=\"bq-date-picker\"\n * placeholder=\"Enter your date\"\n * placement=\"bottom-end\"\n * show-outside-days=\"false\"\n * type=\"range\"\n * validation-status=\"none\"\n * value=\"2024-05-25\"\n * >\n * <label class=\"flex flex-grow items-center\" slot=\"label\">\n * Date picker label\n * </label>\n * </bq-date-picker>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/5793a9-date-picker\n * @status stable\n *\n * @dependency bq-button\n * @dependency bq-dropdown\n * @dependency bq-icon\n *\n * @attr {boolean} autofocus - If `true`, the Date picker input will be focused on component render.\n * @attr {string} clear-button-label - The clear button aria label.\n * @attr {boolean} disable-clear - If `true`, the clear button won't be displayed.\n * @attr {boolean} disabled - Indicates whether the Date picker input is disabled or not.\n * @attr {number} distance - Represents the distance (gutter or margin) between the Date picker panel and the input element.\n * @attr {0 | 1 | 2 | 3 | 4 | 5 | 6} first-day-of-week - The first day of the week, where Sunday is 0, Monday is 1, etc.\n * @attr {Intl.DateTimeFormatOptions} format-options - The options to use when formatting the displayed value. Details: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat#using_options\n * @attr {string} form - The ID of the form that the Date picker input belongs to.\n * @attr {string} form-validation-message - The native form validation message (mandatory if `required` is set).\n * @attr {function} is-date-disallowed - A function that takes a date and returns true if the date should not be selectable.\n * @attr {Intl.LocalesArgument} locale - The locale for formatting dates. If not set, will use the browser's locale. Details: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl#locales_argument\n * @attr {string} max - The latest date that can be selected.\n * @attr {string} min - The earliest date that can be selected.\n * @attr {number} months - Number of months to show when range is `true`.\n * @attr {string} name - The Date picker input name.\n * @attr {boolean} open - If `true`, the Date picker panel will be visible.\n * @attr {string} panel-height - When set, it will override the height of the Date picker panel.\n * @attr {\"top\" | \"right\" | \"bottom\" | \"left\" | \"top-start\" | \"top-end\" | \"right-start\" | \"right-end\" | \"bottom-start\" | \"bottom-end\" | \"left-start\" | \"left-end\"} placement - Position of the Date picker panel.\n * @attr {boolean} required - Indicates whether or not the Date picker input is required to be filled out before submitting the form.\n * @attr {number} skidding - Represents the skidding between the Date picker panel and the input element.\n * @attr {boolean} show-outside-days - Whether to show days outside the month.\n * @attr {string} strategy - Defines the strategy to position the Date picker panel.\n * @attr {string} tentative - The date that is tentatively selected, e.g. the start of a range selection.\n * @attr {\"single\" | \"multi\" | \"range\"} type - It defines how the calendar will behave, allowing single date selection, range selection, or multiple date selection.\n * @attr {\"error\" | \"none\" | \"success\" | \"warning\"} validation-status - The validation status of the Select input.\n * @attr {string} value - The select input value represents the currently selected date or range and can be used to reset the field to a previous value.\n *\n * @method clear - Clears the selected value.\n *\n * @event bqBlur - Callback handler emitted when the input loses focus.\n * @event bqChange - Callback handler emitted when the input value has changed and the input loses focus.\n * @event bqClear - Callback handler emitted when the input value has been cleared.\n * @event bqFocus - Callback handler emitted when the input has received focus.\n *\n * @part base - The component's base wrapper.\n * @part button - The native HTML button used under the hood in the clear button.\n * @part calendar__button - Any button used in the calendar-month component.\n * @part calendar__button - Any button within the calendar-range component.\n * @part calendar__container - The calendar-range container for the entire component.\n * @part calendar__day - The buttons corresponding to each day in the calendar-month grid.\n * @part calendar__disabled - A button that is disabled due to min/max on the calendar-range component.\n * @part calendar__disallowed - Any day that has been disallowed via isDateDisallowed.\n * @part calendar__head - The calendar-month table's header row.\n * @part calendar__header - The calendar-range container for the heading and buttons.\n * @part calendar__heading - The calendar-month heading container that labels the month.\n * @part calendar__heading - The calendar-range heading containing the month and year.\n * @part calendar__next - The next page button on the calendar-range component.\n * @part calendar__outside - Any days which are outside the current month.\n * @part calendar__previous - The previous page button on the calendar-range component.\n * @part calendar__range-end - The day at the end of a date range.\n * @part calendar__range-inner - Any days between the start and end of a date range.\n * @part calendar__range-start - The day at the start of a date range.\n * @part calendar__selected - Any days which are selected.\n * @part calendar__table - The calendar-month <table> element.\n * @part calendar__td - The calendar-month table's body cells.\n * @part calendar__th - The calendar-month table's header cells.\n * @part calendar__today - The Today's day.\n * @part calendar__tr - Any row within the table on the calendar-month component.\n * @part calendar__week - The calendar-month table's body rows.\n * @part clear-btn - The clear button.\n * @part control - The input control wrapper.\n * @part input - The native HTML input element used under the hood.\n * @part label - The label slot container.\n * @part panel - The date picker panel container\n * @part prefix - The prefix slot container.\n * @part suffix - The suffix slot container.\n *\n * @cssprop --bq-date-picker--background-color - Date picker background color.\n * @cssprop --bq-date-picker--border-color - Date picker border color.\n * @cssprop --bq-date-picker--border-color-disabled - Date picker border color when disabled.\n * @cssprop --bq-date-picker--border-color-focus - Date picker border color on focus.\n * @cssprop --bq-date-picker--border-radius - Date picker border radius.\n * @cssprop --bq-date-picker--border-style - Date picker border style.\n * @cssprop --bq-date-picker--border-width - Date picker border width.\n * @cssprop --bq-date-picker--currentDate-border-color - Date picker border color for current date.\n * @cssprop --bq-date-picker--currentDate-border-width - Date picker border width for current date.\n * @cssprop --bq-date-picker--day-size - Date picker button day size.\n * @cssprop --bq-date-picker--gap - Gap between Date picker content and prefix/suffix.\n * @cssprop --bq-date-picker--icon-size - Icon size to use in prefix/suffix and clear button.\n * @cssprop --bq-date-picker--label-margin-bottom - Date picker label margin bottom.\n * @cssprop --bq-date-picker--label-text-color - Date picker label text color.\n * @cssprop --bq-date-picker--label-text-size - Date picker label text size.\n * @cssprop --bq-date-picker--padding-end - Date picker padding end.\n * @cssprop --bq-date-picker--padding-start - Date picker padding start.\n * @cssprop --bq-date-picker--paddingY - Date picker padding top and bottom.\n * @cssprop --bq-date-picker--range-background-color - Background color for the selected date range in the date picker.\n * @cssprop --bq-date-picker--range-inner-background-color - Background color for the selected dates inside the date range in the date picker.\n * @cssprop --bq-date-picker--text-color - Date picker text color.\n * @cssprop --bq-date-picker--text-placeholder-color - Date picker placeholder text color.\n * @cssprop --bq-date-picker--text-size - Date picker text size.\n */\n@Component({\n tag: 'bq-date-picker',\n styleUrl: './scss/bq-date-picker.scss',\n formAssociated: true,\n shadow: {\n delegatesFocus: true,\n },\n})\nexport class BqDatePicker {\n // Own Properties\n // ====================\n\n private callyElem?: TCalendarDate;\n private inputElem?: HTMLInputElement;\n private labelElem?: HTMLElement;\n private prefixElem?: HTMLElement;\n private suffixElem?: HTMLElement;\n\n private fallbackInputId = 'date-picker';\n\n // Export parts of the calendar-month component\n private readonly COMMON_EXPORT_PARTS =\n 'calendar__heading,calendar__table,calendar__tr,calendar__head,calendar__week,calendar__th,calendar__td';\n private readonly BUTTON_EXPORT_PARTS =\n 'calendar__button,calendar__day,calendar__selected,calendar__today,calendar__disallowed,calendar__outside,calendar__range-start,calendar__range-end,calendar__range-inner';\n\n // Reference to host HTML element\n // ===================================\n\n @AttachInternals() internals: ElementInternals;\n @Element() el!: HTMLBqDatePickerElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n @State() isCallyLoaded = false;\n @State() focusedDate: string;\n @State() displayDate: string;\n @State() hasLabel = false;\n @State() hasPrefix = false;\n @State() hasRangeEnd = false;\n @State() hasSuffix = false;\n @State() hasValue = false;\n\n // Public Property API\n // ========================\n\n /** If `true`, the Date picker input will be focused on component render */\n @Prop({ reflect: true }) autofocus: boolean;\n\n /** The clear button aria label */\n @Prop({ reflect: true }) clearButtonLabel? = 'Clear value';\n\n /** If `true`, the clear button won't be displayed */\n @Prop({ reflect: true }) disableClear? = false;\n\n /**\n * Indicates whether the Date picker input is disabled or not.\n * If `true`, the Date picker is disabled and cannot be interacted with.\n */\n @Prop({ mutable: true }) disabled?: boolean = false;\n\n /** Represents the distance (gutter or margin) between the Date picker panel and the input element. */\n @Prop({ reflect: true }) distance?: number = 8;\n\n /** The first day of the week, where Sunday is 0, Monday is 1, etc */\n @Prop({ reflect: true }) firstDayOfWeek?: DaysOfWeek = 1;\n\n /** The options to use when formatting the displayed value.\n * Details: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat#using_options\n */\n @Prop() formatOptions: Intl.DateTimeFormatOptions = {\n day: 'numeric',\n month: 'short',\n year: 'numeric',\n };\n\n /** The ID of the form that the Date picker input belongs to. */\n @Prop({ reflect: true }) form?: string;\n\n /** The native form validation message (mandatory if `required` is set) */\n @Prop({ mutable: true }) formValidationMessage?: string;\n\n /** A function that takes a date and returns true if the date should not be selectable */\n @Prop({ reflect: true }) isDateDisallowed?: (date: Date) => boolean;\n\n /** The locale for formatting dates. If not set, will use the browser's locale.\n * Details: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl#locales_argument\n */\n @Prop({ reflect: true }) locale: Intl.LocalesArgument = 'en-GB';\n\n /** The latest date that can be selected */\n @Prop({ reflect: true }) max?: string;\n\n /** The earliest date that can be selected */\n @Prop({ reflect: true }) min?: string;\n\n /** Number of months to show when range is `true` */\n @Prop({ reflect: true }) months: number;\n\n /**\n * Specifies how the next/previous buttons should navigate the calendar.\n * - single: The buttons will navigate by a single month at a time.\n * - months: The buttons will navigate by the number of months displayed per view.\n */\n @Prop({ reflect: true }) monthsPerView: 'single' | 'months' = 'single';\n\n /** The Date picker input name. */\n @Prop({ reflect: true }) name!: string;\n\n /** If `true`, the Date picker panel will be visible. */\n @Prop({ reflect: true, mutable: true }) open?: boolean = false;\n\n /** When set, it will override the height of the Date picker panel. */\n @Prop({ reflect: true, mutable: true }) panelHeight?: string = 'auto';\n\n /** The Date picker input placeholder text value */\n @Prop({ reflect: true }) placeholder?: string;\n\n /** Position of the Date picker panel */\n @Prop({ reflect: true }) placement?: Placement = 'bottom-end';\n\n /** Indicates whether or not the Date picker input is required to be filled out before submitting the form. */\n @Prop({ reflect: true }) required?: boolean;\n\n /** Represents the skidding between the Date picker panel and the input element. */\n @Prop({ reflect: true }) skidding?: number = 0;\n\n /** Whether to show days outside the month */\n @Prop({ reflect: true }) showOutsideDays: boolean = false;\n\n /** Defines the strategy to position the Date picker panel */\n @Prop({ reflect: true }) strategy?: 'fixed' | 'absolute' = 'fixed';\n\n /** The date that is tentatively selected e.g. the start of a range selection */\n @Prop({ reflect: true, mutable: true }) tentative?: string;\n\n /** It defines how the calendar will behave, allowing single date selection, range selection, or multiple date selection */\n @Prop({ reflect: true }) type: TDatePickerType = 'single';\n\n /**\n * The validation status of the Select input.\n *\n * @remarks\n * This property is used to indicate the validation status of the select input. It can be set to one of the following values:\n * - `'none'`: No validation status is set.\n * - `'error'`: The input has a validation error.\n * - `'warning'`: The input has a validation warning.\n * - `'success'`: The input has passed validation.\n */\n @Prop({ reflect: true }) validationStatus: TInputValidation = 'none';\n\n /** The select input value represents the currently selected date or range and can be used to reset the field to a previous value.\n * All dates are expected in ISO-8601 format (YYYY-MM-DD). */\n @Prop({ reflect: true, mutable: true }) value: string;\n\n // Prop lifecycle events\n // =======================\n\n @Watch('value')\n handleValueChange() {\n const { formatDisplayValue, internals, isCallyLoaded, value } = this;\n if (!isCallyLoaded) return;\n\n internals.setFormValue(!isNil(value) ? `${value}` : undefined);\n this.updateFormValidity();\n\n if (Array.isArray(value)) {\n this.hasValue = value.some((val) => val.length > 0);\n return;\n }\n\n this.hasValue = isDefined(value);\n this.displayDate = formatDisplayValue(value);\n\n this.setFocusedDate();\n }\n\n @Watch('type')\n checkPropValues() {\n validatePropValue(DATE_PICKER_TYPE, 'single', this.el, 'type');\n }\n\n // Events section\n // Requires JSDocs for public API documentation\n // ==============================================\n\n /** Callback handler emitted when the input loses focus */\n @Event() bqBlur!: EventEmitter<HTMLBqDatePickerElement>;\n\n /**\n * Callback handler emitted when the input value has changed and the input loses focus.\n * This handler is called whenever the user finishes typing or pasting text into the input field and then clicks outside of the input field.\n */\n @Event() bqChange!: EventEmitter<{ value: string; el: HTMLBqDatePickerElement }>;\n\n /** Callback handler emitted when the input value has been cleared */\n @Event() bqClear!: EventEmitter<HTMLBqDatePickerElement>;\n\n /** Callback handler emitted when the input has received focus */\n @Event() bqFocus!: EventEmitter<HTMLBqDatePickerElement>;\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n async connectedCallback() {\n if (!isClient() || this.isCallyLoaded) return;\n\n try {\n await loadCallyLibrary();\n this.isCallyLoaded = isCallyLibraryLoaded();\n } catch (error) {\n console.error(error);\n }\n }\n\n async componentDidLoad() {\n this.handleSlotChange();\n this.handleValueChange();\n }\n\n formAssociatedCallback() {\n this.updateFormValidity();\n }\n\n formResetCallback() {\n if (isNil(this.value)) return;\n\n this.clear();\n }\n\n // Listeners\n // ==============\n\n @Listen('bqOpen', { capture: true })\n handleOpenChange(ev: CustomEvent<{ open: boolean }>) {\n if (!ev.composedPath().includes(this.el)) return;\n\n this.open = ev.detail.open;\n this.setFocusedDate();\n }\n\n @Listen('click', { target: 'body', capture: true })\n handleClickOutside(ev: MouseEvent) {\n const { open, type, hasRangeEnd } = this;\n if (!open || type !== 'range' || ev.button !== 0) return;\n if (isEventTargetChildOfElement(ev, this.el) || hasRangeEnd) return;\n if (isEventTargetChildOfElement(ev, this.el)) return;\n\n if (!hasRangeEnd) {\n this.tentative = undefined;\n this.hasRangeEnd = false;\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 /**\n * Clears the selected value.\n *\n * @return {Promise<void>}\n * @memberof BqInput\n */\n @Method()\n async clear(): Promise<void> {\n if (this.disabled) return;\n\n this.value = undefined;\n this.internals.setFormValue(undefined);\n this.bqClear.emit(this.el);\n }\n\n // Local methods\n // Internal business logic.\n // These methods cannot be called from the host element.\n // =======================================================\n\n private handleBlur = () => {\n if (this.disabled) return;\n\n this.bqBlur.emit(this.el);\n };\n\n private handleFocus = () => {\n if (this.disabled) return;\n\n this.bqFocus.emit(this.el);\n };\n\n private setFocusedDate = () => {\n const { callyElem, formatFocusedDate, isCallyLoaded, value } = this;\n if (!(callyElem && isCallyLoaded)) return;\n // We need to set the focused date in the calendar component via a ref\n // because it doesn't work when passed as a prop (the Cally element does not re-render)\n this.focusedDate = value ? formatFocusedDate(value) : new Date().toLocaleDateString('fr-CA');\n this.callyElem.focusedDate = this.focusedDate;\n };\n\n private handleChange = (ev: Event) => {\n if (this.disabled) return;\n if (!isHTMLElement(ev.target, 'input')) return;\n\n const dateValue = new Date(ev.target.value);\n if (!isNaN(dateValue.getTime())) {\n // We need to force the value to respect the format: yyyy-mm-dd, hence the hardcoded locale\n this.value = dateValue.toLocaleDateString('fr-CA');\n this.displayDate = this.formatDisplayValue(this.value);\n this.internals.setFormValue(`${this.value}`);\n this.bqChange.emit({ value: this.value, el: this.el });\n }\n };\n\n private handleCalendarChange = (ev: Event) => {\n const { value } = ev.target as unknown as { value: string };\n\n this.value = value;\n this.displayDate = this.formatDisplayValue(this.value);\n this.inputElem.value = this.displayDate;\n this.inputElem.focus();\n\n this.internals.setFormValue(`${this.value}`);\n this.bqChange.emit({ value: this.value, el: this.el });\n\n this.open = this.type === 'multi';\n };\n\n private handleCalendarRangeStart = (ev: CustomEvent) => {\n this.hasRangeEnd = false;\n this.tentative = new Date(ev.detail).toLocaleDateString('fr-CA');\n };\n\n private handleCalendarRangeEnd = () => {\n this.hasRangeEnd = true;\n };\n\n private handleClearClick = (ev: CustomEvent) => {\n if (this.disabled) return;\n\n this.inputElem.value = '';\n this.value = this.inputElem.value;\n this.hasRangeEnd = false;\n\n this.bqClear.emit(this.el);\n this.bqChange.emit({ value: this.value, el: this.el });\n this.internals.setFormValue(undefined);\n this.inputElem.focus();\n\n ev.stopPropagation();\n };\n\n private handleSlotChange = () => {\n this.hasLabel = hasSlotContent(this.labelElem);\n this.hasPrefix = hasSlotContent(this.prefixElem);\n this.hasSuffix = hasSlotContent(this.suffixElem);\n };\n\n private generateCalendarMonth = (offset?: number, className = ''): Element | null => {\n if (!this.isCallyLoaded) return null;\n\n return (\n <calendar-month\n offset={offset}\n class={className}\n exportparts={`${this.COMMON_EXPORT_PARTS},${this.BUTTON_EXPORT_PARTS}`}\n />\n );\n };\n\n /**\n * Generates an array of Elements representing the calendar months.\n *\n * If the type of the date picker is 'range' or 'multi' and the number of months is specified,\n * it generates an array of calendar months with the specified length. Each month will have an offset\n * and a class name based on its position in the array. The offset is used to determine the month to display,\n * and the class name is used for responsive design.\n *\n * If the type of the date picker is not 'range' or 'multi', or if the number of months is not specified,\n * it generates an array with a single calendar month.\n *\n * @returns {Element[]} An array of elements representing the calendar months.\n */\n private generateCalendarMonths = (): Element[] => {\n if (!this.isCallyLoaded) return [];\n\n if (this.type === 'range' || (this.type === 'multi' && this.months)) {\n return Array.from({ length: this.months }, (_, i) => {\n const offset = i > 0 ? i : undefined;\n const className = offset ? 'hidden sm:block' : '';\n return this.generateCalendarMonth(offset, className);\n });\n }\n\n return [this.generateCalendarMonth()];\n };\n\n /**\n * Extracts and returns the first date part from a given string.\n * When the type of the date picker is 'range' or 'multi', the first or initial date part of the value\n * should be the focused date in the calendar.\n *\n * @param value - The value to be processed, can be a string.\n * @returns The extracted last date portion of the value.\n */\n private formatFocusedDate = (value: string): string | null => {\n if (!value) return;\n\n const dateRegex = /\\b\\d{4}-\\d{2}-\\d{2}\\b/;\n const match = dateRegex.exec(value);\n return match ? match[0] : null;\n };\n\n private formatDisplayValue = (value: string): string | undefined => {\n if (!value) return;\n\n const dateFormatter = new Intl.DateTimeFormat(this.locale, this.formatOptions);\n\n if (this.type === 'range') {\n const [start, end] = value.split('/').map((dateStr) => new Date(dateStr));\n return dateFormatter.formatRange(start, end);\n }\n\n if (this.type === 'multi') {\n const dates = value.split(' ').map((dateStr) => new Date(dateStr));\n return dates.map((date) => dateFormatter.format(date)).join(', ');\n }\n\n return dateFormatter.format(new Date(value));\n };\n\n private updateFormValidity = () => {\n const { formValidationMessage, internals, required, value, inputElem } = this;\n\n // Clear the validity state\n internals?.states.clear();\n\n if (required && (!value || value.toString().trim() === '')) {\n // Set validity state to invalid\n internals?.states.add('invalid');\n internals?.setValidity({ valueMissing: true }, formValidationMessage, inputElem);\n return;\n }\n\n // Set validity state to valid if textarea has value or is not required\n internals?.states.add('valid');\n internals?.setValidity({});\n };\n\n private get CalendarType() {\n const componentTypes = {\n single: 'calendar-date',\n multi: 'calendar-multi',\n range: 'calendar-range',\n } as const;\n\n // Return the corresponding component type, based on the type prop value\n return componentTypes[this.type] || componentTypes.single;\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n const CallyCalendar = this.CalendarType;\n const labelId = `bq-date-picker__label-${this.name || this.fallbackInputId}`;\n\n return (\n <div class=\"bq-date-picker\" part=\"base\">\n {/* Label */}\n <label\n id={labelId}\n class={{ 'bq-date-picker__label': true, '!hidden': !this.hasLabel }}\n aria-label={this.name || this.fallbackInputId}\n htmlFor={this.name || this.fallbackInputId}\n ref={(labelElem: HTMLSpanElement) => (this.labelElem = labelElem)}\n part=\"label\"\n >\n <slot name=\"label\" onSlotchange={this.handleSlotChange} />\n </label>\n {/* Select date picker dropdown */}\n <bq-dropdown\n class=\"bq-date-picker__dropdown is-full [&::part(panel)]:p-m [&::part(panel)]:is-auto\"\n disabled={this.disabled}\n distance={this.distance}\n open={this.open}\n panelHeight={this.panelHeight}\n placement={this.placement}\n skidding={this.skidding}\n strategy={this.strategy}\n exportparts=\"panel\"\n >\n {/* Input control group */}\n <div\n class={{\n 'bq-date-picker__control': true,\n [`validation-${this.validationStatus}`]: true,\n disabled: this.disabled,\n }}\n part=\"control\"\n slot=\"trigger\"\n >\n {/* Prefix */}\n <span\n class={{ 'bq-date-picker__control--prefix': true, '!hidden': !this.hasPrefix }}\n ref={(spanElem: HTMLSpanElement) => (this.prefixElem = spanElem)}\n part=\"prefix\"\n >\n <slot name=\"prefix\" onSlotchange={this.handleSlotChange} />\n </span>\n {/* HTML Input */}\n <input\n id={this.name || this.fallbackInputId}\n class=\"bq-date-picker__control--input\"\n autoComplete=\"off\"\n autoCapitalize=\"off\"\n aria-disabled={this.disabled ? 'true' : 'false'}\n aria-controls={`${this.name}`}\n aria-haspopup=\"dialog\"\n disabled={this.disabled}\n form={this.form}\n name={this.name}\n placeholder={this.placeholder}\n readonly={this.type !== 'single'}\n ref={(inputElem: HTMLInputElement) => (this.inputElem = inputElem)}\n required={this.required}\n spellcheck={false}\n type=\"text\"\n value={this.displayDate}\n part=\"input\"\n // Events\n onBlur={this.handleBlur}\n onFocus={this.handleFocus}\n onChange={this.handleChange}\n />\n {/* Clear Button */}\n {this.hasValue && !this.disabled && !this.disableClear && (\n // The clear button will be visible as long as the input has a value\n // and the parent group is hovered or has focus-within\n <bq-button\n class=\"bq-date-picker__control--clear ms-[--bq-date-picker--gap] hidden\"\n appearance=\"text\"\n aria-label={this.clearButtonLabel}\n size=\"small\"\n onBqClick={this.handleClearClick}\n part=\"clear-btn\"\n exportparts=\"button\"\n >\n <slot name=\"clear-icon\">\n <bq-icon name=\"x-circle\" class=\"flex\" />\n </slot>\n </bq-button>\n )}\n {/* Suffix */}\n <span\n class=\"bq-date-picker__control--suffix\"\n ref={(spanElem: HTMLSpanElement) => (this.suffixElem = spanElem)}\n part=\"suffix\"\n >\n <slot name=\"suffix\" onSlotchange={this.handleSlotChange}>\n <bq-icon name=\"calendar-blank\" class=\"flex\" />\n </slot>\n </span>\n </div>\n {this.isCallyLoaded && (\n <CallyCalendar\n isDateDisallowed={this.isDateDisallowed}\n locale={this.locale as string}\n value={this.value}\n min={this.min}\n max={this.max}\n months={this.months}\n tentative={this.tentative}\n pageBy={this.monthsPerView}\n firstDayOfWeek={this.firstDayOfWeek}\n showOutsideDays={this.showOutsideDays}\n onChange={this.handleCalendarChange}\n onRangestart={this.handleCalendarRangeStart}\n onRangeend={this.handleCalendarRangeEnd}\n exportparts=\"container:calendar__container,header:calendar__header,button:calendar__button,previous:calendar__previous,next:calendar__next,disabled:calendar__disabled,heading:calendar__heading\"\n ref={(elem: TCalendarDate) => (this.callyElem = elem)}\n >\n <bq-icon color=\"text--primary\" slot=\"previous\" name=\"caret-left\" label=\"Previous\" />\n <bq-icon color=\"text--primary\" slot=\"next\" name=\"caret-right\" label=\"Next\" />\n\n <div class=\"flex flex-wrap justify-center gap-[--bq-spacing-m]\">{this.generateCalendarMonths()}</div>\n </CallyCalendar>\n )}\n </bq-dropdown>\n </div>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["bqOptionCss","BqOptionStyle0","BqOption","prefixElem","suffixElem","hasPrefix","hasSuffix","hidden","disabled","value","selected","bqBlur","bqFocus","bqClick","bqEnter","componentDidLoad","this","handleSlotChange","onKeyDown","event","key","emit","el","onBlur","isDisabledOrHidden","preventDefault","stopPropagation","onFocus","onClick","hasSlotContent","render","h","Host","role","class","active","tabindex","part","ref","elem","name","onSlotchange"],"sources":["../../packages/beeq/src/components/option/scss/bq-option.scss?tag=bq-option&encapsulation=shadow","../../packages/beeq/src/components/option/bq-option.tsx"],"sourcesContent":["/* -------------------------------------------------------------------------- */\n/* Option styles */\n/* -------------------------------------------------------------------------- */\n\n@import './bq-option.variables';\n\n:host {\n @apply block;\n}\n\n:host([hidden]) {\n @apply hidden;\n}\n\n.bq-option {\n @apply flex cursor-pointer items-center text-[length:--bq-option--font-size] is-full;\n @apply pe-[--bq-option--padding-end] ps-[--bq-option--padding-start] p-b-[--bq-option--paddingY] p-i-[--bq-option--paddingY];\n @apply rounded-[--bq-option--border-radius] bg-[--bq-option--background] shadow-[shadow:--bq-option--box-shadow];\n @apply border-[length:--bq-option--border-width] border-[color:--bq-option--border-color];\n // Transition\n @apply transition-colors duration-150 ease-in-out;\n // Focus\n @apply [&:not(.disabled)]:focus-visible:focus;\n // Hover\n @apply [&:not(.disabled)]:hover:bg-hover-ui-secondary;\n // Active\n @apply [&.active:not(.disabled)]:bg-ui-brand-alt [&.active:not(.disabled)]:text-brand;\n // Disabled\n @apply [&.disabled]:cursor-not-allowed [&.disabled]:opacity-60;\n\n border-style: var(--bq-option--border-style);\n}\n\n.bq-option__label {\n @apply inline-block flex-auto overflow-hidden text-ellipsis whitespace-nowrap;\n @apply pe-[--bq-option-label--padding-end] ps-[--bq-option-label--padding-start];\n}\n","import { Component, Element, Event, EventEmitter, h, Host, Listen, Prop, State } from '@stencil/core';\n\nimport { hasSlotContent } from '../../shared/utils';\n\n/**\n * An option refers to a specific choice that appears in a list of selectable items that can be opened or closed by the user.\n * It can be an element of the navigation system that allows users to select different sections or pages within an application or it can be used within a dropdown list.\n *\n * @example How to use it\n * ```html\n * <bq-option value=\"user\">\n * <span>User profile</span>\n * <bq-icon slot=\"suffix\" name=\"user\"></bq-icon>\n * </bq-option>\n * ```\n *\n * @documentation https://storybook.beeq.design/?path=/story/components-option--with-option-group\n * @status stable\n *\n * @attr {boolean} disabled - If true, the option is disabled.\n * @attr {boolean} hidden - If true, the option is hidden.\n * @attr {string} value - A string representing the value of the option. Can be used to identify the item.\n * @attr {boolean} selected - If true, the option is selected and active.\n *\n * @event bqBlur - Handler to be called when item loses focus.\n * @event bqFocus - Handler to be called when item is focused.\n * @event bqClick - Handler to be called when item is clicked.\n * @event bqEnter - Handler to be called on enter key press.\n *\n * @slot prefix - The prefix content to be displayed before the label.\n * @slot - The label content to be displayed.\n *\n * @part base - The component's internal wrapper.\n * @part label - The `span` element in which the label text is displayed.\n * @part prefix - The `span` element in which the prefix is displayed (generally `bq-icon`).\n * @part suffix - The `span` element in which the suffix is displayed (generally `bq-icon`).\n *\n * @cssprop --bq-option--background - background color\n * @cssprop --bq-option--font-size - font size\n * @cssprop --bq-option--border-color - border color\n * @cssprop --bq-option--border-style - border style\n * @cssprop --bq-option--border-width - border width\n * @cssprop --bq-option--border-radius - border radius\n * @cssprop --bq-option--box-shadow - box shadow\n * @cssprop --bq-option--gap-start - gap space between prefix and label\n * @cssprop --bq-option--gap-end - gap space between label and suffix\n * @cssprop --bq-option--paddingY - padding Y axis\n * @cssprop --bq-option--padding-start - option label padding start\n * @cssprop --bq-option--padding-end - option label padding end\n */\n@Component({\n tag: 'bq-option',\n styleUrl: './scss/bq-option.scss',\n shadow: true,\n})\nexport class BqOption {\n // Own Properties\n // ====================\n\n private prefixElem: HTMLElement;\n private suffixElem: HTMLElement;\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqOptionElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n @State() hasPrefix: boolean = false;\n @State() hasSuffix: boolean = false;\n\n // Public Property API\n // ========================\n\n /** If true, the option is hidden. */\n @Prop({ reflect: true }) hidden: boolean = false;\n\n /** If true, the option is disabled. */\n @Prop({ reflect: true }) disabled?: boolean = false;\n\n /** A string representing the value of the option. Can be used to identify the item */\n @Prop({ reflect: true }) value?: string;\n\n /** If true, the option is selected and active. */\n @Prop({ reflect: true }) selected: boolean = false;\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 item loses focus */\n @Event() bqBlur: EventEmitter<HTMLBqOptionElement>;\n\n /** Handler to be called when item is focused */\n @Event() bqFocus: EventEmitter<HTMLBqOptionElement>;\n\n /** Handler to be called when item is clicked */\n @Event() bqClick: EventEmitter<HTMLBqOptionElement>;\n\n /** Handler to be called on enter key press */\n @Event() bqEnter: EventEmitter<HTMLBqOptionElement>;\n\n // Component lifecycle events\n // Ordered by their natural call order\n // =====================================\n\n componentDidLoad() {\n this.handleSlotChange();\n }\n\n // Listeners\n // ==============\n\n @Listen('keydown')\n onKeyDown(event: KeyboardEvent) {\n if (event.key !== 'Enter') return;\n this.bqEnter.emit(this.el);\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 onBlur = (event: Event) => {\n if (this.isDisabledOrHidden) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n this.bqBlur.emit(this.el);\n };\n\n private onFocus = (event: Event) => {\n if (this.isDisabledOrHidden) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n this.bqFocus.emit(this.el);\n };\n\n private onClick = (event: Event) => {\n if (this.isDisabledOrHidden) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n this.bqClick.emit(this.el);\n };\n\n private handleSlotChange = () => {\n this.hasPrefix = hasSlotContent(this.prefixElem, 'prefix');\n this.hasSuffix = hasSlotContent(this.suffixElem, 'suffix');\n };\n\n private get isDisabledOrHidden() {\n return this.disabled || this.hidden;\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <Host\n aria-disabled={this.isDisabledOrHidden ? 'true' : 'false'}\n aria-hidden={this.hidden ? 'true' : 'false'}\n aria-selected={this.selected ? 'true' : 'false'}\n role=\"option\"\n >\n <div\n class={{\n 'bq-option': true,\n disabled: this.disabled,\n active: !this.disabled && this.selected,\n }}\n onBlur={this.onBlur}\n onFocus={this.onFocus}\n onClick={this.onClick}\n tabindex={this.isDisabledOrHidden ? '-1' : '0'}\n role=\"button\"\n part=\"base\"\n >\n <span\n class={{\n 'bq-option__prefix me-[--bq-option--gap-start] flex items-center': true,\n '!hidden': !this.hasPrefix,\n }}\n ref={(elem) => (this.prefixElem = elem)}\n part=\"prefix\"\n >\n <slot name=\"prefix\" onSlotchange={this.handleSlotChange} />\n </span>\n <span class=\"bq-option__label\" part=\"label\">\n <slot />\n </span>\n <span\n class={{\n 'bq-option__suffix ml-auto ms-[--bq-option--gap-end] flex items-center': true,\n '!hidden': !this.hasSuffix,\n }}\n ref={(elem) => (this.suffixElem = elem)}\n part=\"suffix\"\n >\n <slot name=\"suffix\" onSlotchange={this.handleSlotChange} />\n </span>\n </div>\n </Host>\n );\n }\n}\n"],"mappings":";;;;oGAAA,MAAMA,EAAc,kuuBACpB,MAAAC,EAAeD,E,MCsDFE,EAAQ,M,2JAIXC,WACAC,W,wBAWCC,UAAqB,MACrBC,UAAqB,MAMLC,OAAkB,MAGlBC,SAAqB,MAGrBC,MAGAC,SAAoB,MAUpCC,OAGAC,QAGAC,QAGAC,QAMT,gBAAAC,GACEC,KAAKC,kB,CAOP,SAAAC,CAAUC,GACR,GAAIA,EAAMC,MAAQ,QAAS,OAC3BJ,KAAKF,QAAQO,KAAKL,KAAKM,G,CAejBC,OAAUJ,IAChB,GAAIH,KAAKQ,mBAAoB,CAC3BL,EAAMM,iBACNN,EAAMO,kBACN,M,CAGFV,KAAKL,OAAOU,KAAKL,KAAKM,GAAG,EAGnBK,QAAWR,IACjB,GAAIH,KAAKQ,mBAAoB,CAC3BL,EAAMM,iBACNN,EAAMO,kBACN,M,CAGFV,KAAKJ,QAAQS,KAAKL,KAAKM,GAAG,EAGpBM,QAAWT,IACjB,GAAIH,KAAKQ,mBAAoB,CAC3BL,EAAMM,iBACNN,EAAMO,kBACN,M,CAGFV,KAAKH,QAAQQ,KAAKL,KAAKM,GAAG,EAGpBL,iBAAmB,KACzBD,KAAKX,UAAYwB,EAAeb,KAAKb,WAAY,UACjDa,KAAKV,UAAYuB,EAAeb,KAAKZ,WAAY,SAAS,EAG5D,sBAAYoB,GACV,OAAOR,KAAKR,UAAYQ,KAAKT,M,CAO/B,MAAAuB,GACE,OACEC,EAACC,EAAI,CAAAZ,IAAA,2DACYJ,KAAKQ,mBAAqB,OAAS,QAAO,cAC5CR,KAAKT,OAAS,OAAS,QAAO,gBAC5BS,KAAKN,SAAW,OAAS,QACxCuB,KAAK,UAELF,EAAA,OAAAX,IAAA,2CACEc,MAAO,CACL,YAAa,KACb1B,SAAUQ,KAAKR,SACf2B,QAASnB,KAAKR,UAAYQ,KAAKN,UAEjCa,OAAQP,KAAKO,OACbI,QAASX,KAAKW,QACdC,QAASZ,KAAKY,QACdQ,SAAUpB,KAAKQ,mBAAqB,KAAO,IAC3CS,KAAK,SACLI,KAAK,QAELN,EAAA,QAAAX,IAAA,2CACEc,MAAO,CACL,kEAAmE,KACnE,WAAYlB,KAAKX,WAEnBiC,IAAMC,GAAUvB,KAAKb,WAAaoC,EAClCF,KAAK,UAELN,EAAA,QAAAX,IAAA,2CAAMoB,KAAK,SAASC,aAAczB,KAAKC,oBAEzCc,EAAA,QAAAX,IAAA,2CAAMc,MAAM,mBAAmBG,KAAK,SAClCN,EAAA,QAAAX,IAAA,8CAEFW,EAAA,QAAAX,IAAA,2CACEc,MAAO,CACL,wEAAyE,KACzE,WAAYlB,KAAKV,WAEnBgC,IAAMC,GAAUvB,KAAKZ,WAAamC,EAClCF,KAAK,UAELN,EAAA,QAAAX,IAAA,2CAAMoB,KAAK,SAASC,aAAczB,KAAKC,qB","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["EMPTY_STATE_SIZE","SIZE_TO_VALUE_MAP","small","medium","large","bqEmptyStateCss","BqEmptyStateStyle0","BqEmptyState","bodyElem","footerElem","hasBody","hasFooter","size","checkPropValues","validatePropValue","this","el","componentWillLoad","componentDidLoad","handleSlotChange","hasSlotContent","iconSize","render","h","key","class","part","name","exportparts","ref","div","onSlotchange"],"sources":["../../packages/beeq/src/components/empty-state/bq-empty-state.types.ts","../../packages/beeq/src/components/empty-state/scss/bq-empty-state.scss?tag=bq-empty-state&encapsulation=shadow","../../packages/beeq/src/components/empty-state/bq-empty-state.tsx"],"sourcesContent":["export const EMPTY_STATE_SIZE = ['small', 'medium', 'large'] as const;\nexport type TEmptyStateSize = (typeof EMPTY_STATE_SIZE)[number];\n\nexport const SIZE_TO_VALUE_MAP: Record<TEmptyStateSize, number> = {\n small: 40,\n medium: 80,\n large: 180,\n};\n","/* -------------------------------------------------------------------------- */\n/* Empty state styles */\n/* -------------------------------------------------------------------------- */\n\n:host {\n @apply relative inline-block;\n}\n","import { Component, Element, h, Prop, State, Watch } from '@stencil/core';\n\nimport { EMPTY_STATE_SIZE, SIZE_TO_VALUE_MAP, TEmptyStateSize } from './bq-empty-state.types';\nimport { hasSlotContent, validatePropValue } from '../../shared/utils';\n\n/**\n * An Empty State is a UI component displayed when there is no data or content available, often used in dynamic or inactive application states.\n *\n * @example How to use it\n * ```html\n * <bq-empty-state size=\"medium\">Title</bq-empty-state>\n * ```\n *\n * @documentation https://www.beeq.design/3d466e231/p/673ae0-empty-state/b/09d7b1\n * @status stable\n *\n * @dependency bq-icon\n *\n * @attr {\"large\" | \"medium\" | \"small\"} size - The size of the empty state component\n *\n * @slot thumbnail - The element that wraps the thumbnail element\n * @slot body - The content to be displayed after the thumbnail section\n * @slot footer - The content to be displayed after the body section as footer\n *\n * @part body - The container `<div>` that wraps the alert description content\n * @part footer - The container `<div>` that wraps the alert footer content\n * @part icon - The `<bq-icon>` element used to render a predefined icon size based on the empty state size (small, medium, large)\n * @part thumbnail - The container `<div>` that wraps the thumbnail element\n * @part title - The container `<div>` that wraps the empty state title content\n * @part wrapper - The wrapper container `<div>` of the element inside the shadow DOM\n */\n\n@Component({\n tag: 'bq-empty-state',\n styleUrl: './scss/bq-empty-state.scss',\n shadow: true,\n})\nexport class BqEmptyState {\n // Own Properties\n // ====================\n\n private bodyElem: HTMLDivElement;\n private footerElem: HTMLDivElement;\n\n // Reference to host HTML element\n // ===================================\n\n @Element() el!: HTMLBqEmptyStateElement;\n\n // State() variables\n // Inlined decorator, alphabetical order\n // =======================================\n\n @State() private hasBody = false;\n @State() private hasFooter = false;\n\n // Public Property API\n // ========================\n\n /** The size of the empty state component */\n @Prop({ reflect: true, mutable: true }) size: TEmptyStateSize = 'medium';\n\n // Prop lifecycle events\n // =======================\n\n @Watch('size')\n checkPropValues() {\n validatePropValue(EMPTY_STATE_SIZE, 'medium', this.el, 'size');\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.checkPropValues();\n }\n\n componentDidLoad() {\n this.handleSlotChange();\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 handleSlotChange = () => {\n this.hasBody = hasSlotContent(this.bodyElem, 'body');\n this.hasFooter = hasSlotContent(this.footerElem, 'footer');\n };\n\n private get iconSize(): number {\n return SIZE_TO_VALUE_MAP[this.size] || SIZE_TO_VALUE_MAP.medium;\n }\n\n // render() function\n // Always the last one in the class.\n // ===================================\n\n render() {\n return (\n <div class=\"inline-flex flex-col items-center\" part=\"wrapper\">\n <div\n class={{\n 'm-be-m': this.size === 'small',\n 'm-be-xl': this.size === 'medium',\n 'm-be-xxl': this.size === 'large',\n }}\n part=\"thumbnail\"\n >\n <slot name=\"thumbnail\">\n <bq-icon size={this.iconSize} name=\"database\" part=\"icon\" exportparts=\"base,svg\" />\n </slot>\n </div>\n <div\n class={{\n 'font-bold leading-regular text-primary': true,\n 'text-m': this.size === 'small',\n 'text-l': this.size === 'medium',\n 'text-xxl2': this.size === 'large',\n 'm-be-xs': this.size === 'small' && this.hasBody,\n 'm-be-m': this.size === 'medium' && this.hasBody,\n 'm-be-l': this.size === 'large' && this.hasBody,\n }}\n part=\"title\"\n >\n <slot />\n </div>\n <div\n class={{\n 'font-normal leading-regular': true,\n 'text-s': this.size === 'small',\n 'text-m': this.size === 'medium',\n 'text-l': this.size === 'large',\n 'm-be-m': this.size === 'small' && this.hasFooter,\n 'm-be-l': this.size === 'medium' && this.hasFooter,\n 'm-be-xl': this.size === 'large' && this.hasFooter,\n }}\n ref={(div) => (this.bodyElem = div)}\n part=\"body\"\n >\n <slot name=\"body\" onSlotchange={this.handleSlotChange} />\n </div>\n <div class=\"flex items-start gap-xs\" ref={(div) => (this.footerElem = div)} part=\"footer\">\n <slot name=\"footer\" onSlotchange={this.handleSlotChange} />\n </div>\n </div>\n );\n }\n}\n"],"mappings":";;;;0HAAO,MAAMA,EAAmB,CAAC,QAAS,SAAU,SAG7C,MAAMC,EAAqD,CAChEC,MAAO,GACPC,OAAQ,GACRC,MAAO,KCNT,MAAMC,EAAkB,6pnBACxB,MAAAC,EAAeD,E,MCoCFE,EAAY,M,yBAIfC,SACAC,W,wBAWSC,QAAU,MACVC,UAAY,MAMWC,KAAwB,SAMhE,eAAAC,GACEC,EAAkBd,EAAkB,SAAUe,KAAKC,GAAI,O,CAWzD,iBAAAC,GACEF,KAAKF,iB,CAGP,gBAAAK,GACEH,KAAKI,kB,CAkBCA,iBAAmB,KACzBJ,KAAKL,QAAUU,EAAeL,KAAKP,SAAU,QAC7CO,KAAKJ,UAAYS,EAAeL,KAAKN,WAAY,SAAS,EAG5D,YAAYY,GACV,OAAOpB,EAAkBc,KAAKH,OAASX,EAAkBE,M,CAO3D,MAAAmB,GACE,OACEC,EAAA,OAAAC,IAAA,2CAAKC,MAAM,oCAAoCC,KAAK,WAClDH,EAAA,OAAAC,IAAA,2CACEC,MAAO,CACL,SAAUV,KAAKH,OAAS,QACxB,UAAWG,KAAKH,OAAS,SACzB,WAAYG,KAAKH,OAAS,SAE5Bc,KAAK,aAELH,EAAA,QAAAC,IAAA,2CAAMG,KAAK,aACTJ,EAAA,WAAAC,IAAA,2CAASZ,KAAMG,KAAKM,SAAUM,KAAK,WAAWD,KAAK,OAAOE,YAAY,eAG1EL,EAAA,OAAAC,IAAA,2CACEC,MAAO,CACL,yCAA0C,KAC1C,SAAUV,KAAKH,OAAS,QACxB,SAAUG,KAAKH,OAAS,SACxB,YAAaG,KAAKH,OAAS,QAC3B,UAAWG,KAAKH,OAAS,SAAWG,KAAKL,QACzC,SAAUK,KAAKH,OAAS,UAAYG,KAAKL,QACzC,SAAUK,KAAKH,OAAS,SAAWG,KAAKL,SAE1CgB,KAAK,SAELH,EAAA,QAAAC,IAAA,8CAEFD,EAAA,OAAAC,IAAA,2CACEC,MAAO,CACL,8BAA+B,KAC/B,SAAUV,KAAKH,OAAS,QACxB,SAAUG,KAAKH,OAAS,SACxB,SAAUG,KAAKH,OAAS,QACxB,SAAUG,KAAKH,OAAS,SAAWG,KAAKJ,UACxC,SAAUI,KAAKH,OAAS,UAAYG,KAAKJ,UACzC,UAAWI,KAAKH,OAAS,SAAWG,KAAKJ,WAE3CkB,IAAMC,GAASf,KAAKP,SAAWsB,EAC/BJ,KAAK,QAELH,EAAA,QAAAC,IAAA,2CAAMG,KAAK,OAAOI,aAAchB,KAAKI,oBAEvCI,EAAA,OAAAC,IAAA,2CAAKC,MAAM,0BAA0BI,IAAMC,GAASf,KAAKN,WAAaqB,EAAMJ,KAAK,UAC/EH,EAAA,QAAAC,IAAA,2CAAMG,KAAK,SAASI,aAAchB,KAAKI,oB","ignoreList":[]}