bootstrap-vue-next 0.44.7 → 0.45.1

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 (828) hide show
  1. package/dist/{BAccordion-CJZMsvwP.js → BAccordion-DgXJMqdG.js} +2 -2
  2. package/dist/{BAccordion-CJZMsvwP.js.map → BAccordion-DgXJMqdG.js.map} +1 -1
  3. package/dist/{BAccordion-CNzV6f8e.mjs → BAccordion-Gz2SpRmq.mjs} +2 -2
  4. package/dist/{BAccordion-CNzV6f8e.mjs.map → BAccordion-Gz2SpRmq.mjs.map} +1 -1
  5. package/dist/{BAlert-Qiyqq4rE.mjs → BAlert-BFPBalmr.mjs} +9 -10
  6. package/dist/BAlert-BFPBalmr.mjs.map +1 -0
  7. package/dist/{BAlert-BnT7fF6B.js → BAlert-Dk3rgEOI.js} +9 -10
  8. package/dist/BAlert-Dk3rgEOI.js.map +1 -0
  9. package/dist/{BApp-DJWC2mB8.mjs → BApp-CIu-zI8K.mjs} +2 -2
  10. package/dist/BApp-CIu-zI8K.mjs.map +1 -0
  11. package/dist/{BApp-DaM0UKIg.js → BApp-cBKQc5Dd.js} +2 -2
  12. package/dist/BApp-cBKQc5Dd.js.map +1 -0
  13. package/dist/BAspect-BULTO240.js.map +1 -1
  14. package/dist/BAspect-CwokVvvn.mjs.map +1 -1
  15. package/dist/{BAutocomplete-jAlZC6_t.js → BAutocomplete-B1qC2xDb.js} +114 -65
  16. package/dist/{BAutocomplete-jAlZC6_t.js.map → BAutocomplete-B1qC2xDb.js.map} +1 -1
  17. package/dist/{BAutocomplete-QBIaWPY1.mjs → BAutocomplete-DQjfkhoO.mjs} +115 -66
  18. package/dist/{BAutocomplete-QBIaWPY1.mjs.map → BAutocomplete-DQjfkhoO.mjs.map} +1 -1
  19. package/dist/{BAvatar-lefHkDuG.js → BAvatar-CZn0MQHY.js} +7 -8
  20. package/dist/BAvatar-CZn0MQHY.js.map +1 -0
  21. package/dist/{BAvatar-D7aFEXLH.mjs → BAvatar-DODGnQMY.mjs} +7 -8
  22. package/dist/BAvatar-DODGnQMY.mjs.map +1 -0
  23. package/dist/{BBadge-D5ra3W5R.mjs → BBadge-CZ219I7a.mjs} +5 -5
  24. package/dist/BBadge-CZ219I7a.mjs.map +1 -0
  25. package/dist/{BBadge-BBUcrujj.js → BBadge-DTJcCo9u.js} +5 -5
  26. package/dist/BBadge-DTJcCo9u.js.map +1 -0
  27. package/dist/{BBreadcrumb-BSsiwCNB.js → BBreadcrumb-DFG2Qxl9.js} +2 -2
  28. package/dist/BBreadcrumb-DFG2Qxl9.js.map +1 -0
  29. package/dist/{BBreadcrumb-amkzWyz6.mjs → BBreadcrumb-Dk4ia-9c.mjs} +2 -2
  30. package/dist/BBreadcrumb-Dk4ia-9c.mjs.map +1 -0
  31. package/dist/{BButton-kykTWnBy.js → BButton-BZ9eI3ZX.js} +6 -6
  32. package/dist/BButton-BZ9eI3ZX.js.map +1 -0
  33. package/dist/{BButton-DNmtqoqR.mjs → BButton-C0Ylhonf.mjs} +6 -6
  34. package/dist/BButton-C0Ylhonf.mjs.map +1 -0
  35. package/dist/{BButton-BRvIFnRm.mjs → BButton-D_sCrjpg.mjs} +13 -17
  36. package/dist/BButton-D_sCrjpg.mjs.map +1 -0
  37. package/dist/{BButton-DBRs8Pz_.js → BButton-Dr-RadYQ.js} +13 -17
  38. package/dist/BButton-Dr-RadYQ.js.map +1 -0
  39. package/dist/{BCard-CSyEHz8Z.js → BCard-BjQkY783.js} +2 -2
  40. package/dist/BCard-BjQkY783.js.map +1 -0
  41. package/dist/{BCard-CgbTFn3S.js → BCard-BkvG5Zzw.js} +5 -11
  42. package/dist/BCard-BkvG5Zzw.js.map +1 -0
  43. package/dist/{BCard-C1G8PO5k.mjs → BCard-TS8DtOwm.mjs} +6 -12
  44. package/dist/BCard-TS8DtOwm.mjs.map +1 -0
  45. package/dist/{BCard-CJ822HyH.mjs → BCard-cj8_dIcz.mjs} +2 -2
  46. package/dist/BCard-cj8_dIcz.mjs.map +1 -0
  47. package/dist/{BCarousel-BgT74ryc.js → BCarousel-D23rApAX.js} +3 -3
  48. package/dist/{BCarousel-BgT74ryc.js.map → BCarousel-D23rApAX.js.map} +1 -1
  49. package/dist/{BCarousel-D9Yei1Q4.mjs → BCarousel-VL1gVXpt.mjs} +3 -3
  50. package/dist/{BCarousel-D9Yei1Q4.mjs.map → BCarousel-VL1gVXpt.mjs.map} +1 -1
  51. package/dist/{BCloseButton-CjgbR1Ec.mjs → BCloseButton-CCdRwLDo.mjs} +1 -1
  52. package/dist/BCloseButton-CCdRwLDo.mjs.map +1 -0
  53. package/dist/{BCloseButton-CN__Jjcj.js → BCloseButton-fw5ONnhr.js} +1 -1
  54. package/dist/BCloseButton-fw5ONnhr.js.map +1 -0
  55. package/dist/{BCol-0tZmpOme.js → BCol-CArTYHqb.js} +2 -2
  56. package/dist/BCol-CArTYHqb.js.map +1 -0
  57. package/dist/{BCol-C4v-TOX6.mjs → BCol-VPaTVLsM.mjs} +2 -2
  58. package/dist/BCol-VPaTVLsM.mjs.map +1 -0
  59. package/dist/{BCollapse-D-xTGkX_.mjs → BCollapse-CTvK48kB.mjs} +2 -2
  60. package/dist/BCollapse-CTvK48kB.mjs.map +1 -0
  61. package/dist/{BCollapse-DZ1z2c8U.js → BCollapse-CZlDVTpI.js} +2 -2
  62. package/dist/BCollapse-CZlDVTpI.js.map +1 -0
  63. package/dist/{BContainer-BZUI2qQv.js → BContainer-CNmEk2mi.js} +3 -3
  64. package/dist/BContainer-CNmEk2mi.js.map +1 -0
  65. package/dist/{BContainer-DjIGH6-y.mjs → BContainer-CeHyMYb_.mjs} +3 -3
  66. package/dist/BContainer-CeHyMYb_.mjs.map +1 -0
  67. package/dist/{BDateField-RWwEMIwd.js → BDateField-B4yL8Pju.js} +6 -6
  68. package/dist/BDateField-B4yL8Pju.js.map +1 -0
  69. package/dist/{BDateField-BJIq6gs9.mjs → BDateField-gRWIwMnA.mjs} +6 -6
  70. package/dist/BDateField-gRWIwMnA.mjs.map +1 -0
  71. package/dist/{BDatePicker-DfzZBWjU.mjs → BDatePicker-ZuMpgD91.mjs} +8 -8
  72. package/dist/{BDatePicker-DfzZBWjU.mjs.map → BDatePicker-ZuMpgD91.mjs.map} +1 -1
  73. package/dist/{BDatePicker-BQN6qZXa.js → BDatePicker-m2drV1fl.js} +8 -8
  74. package/dist/{BDatePicker-BQN6qZXa.js.map → BDatePicker-m2drV1fl.js.map} +1 -1
  75. package/dist/{BDropdown-DAHnN54Z.mjs → BDropdown-B2vWJ-u0.mjs} +24 -25
  76. package/dist/BDropdown-B2vWJ-u0.mjs.map +1 -0
  77. package/dist/{BDropdown-C1AxRj81.js → BDropdown-BSCasYDc.js} +24 -25
  78. package/dist/BDropdown-BSCasYDc.js.map +1 -0
  79. package/dist/{BDropdown-CuVOxCzu.js → BDropdown-CL-erjq8.js} +4 -4
  80. package/dist/BDropdown-CL-erjq8.js.map +1 -0
  81. package/dist/{BDropdown-BW_O8vPQ.mjs → BDropdown-D2ep4wKG.mjs} +4 -4
  82. package/dist/BDropdown-D2ep4wKG.mjs.map +1 -0
  83. package/dist/{BForm-Oh6PpdcD.mjs → BForm-CpNuvbIt.mjs} +1 -1
  84. package/dist/BForm-CpNuvbIt.mjs.map +1 -0
  85. package/dist/{BForm-_h0kYDl7.js → BForm-CriVh5cC.js} +5 -5
  86. package/dist/BForm-CriVh5cC.js.map +1 -0
  87. package/dist/{BForm-Bp7SFxiK.js → BForm-K67Ciyza.js} +1 -1
  88. package/dist/BForm-K67Ciyza.js.map +1 -0
  89. package/dist/{BForm-C8I6v7bU.mjs → BForm-__5Chigr.mjs} +5 -5
  90. package/dist/BForm-__5Chigr.mjs.map +1 -0
  91. package/dist/{BFormCheckbox-Bdk2rgVe.js → BFormCheckbox-g7gtIrhy.js} +8 -8
  92. package/dist/BFormCheckbox-g7gtIrhy.js.map +1 -0
  93. package/dist/{BFormCheckbox-CcDK-lh1.mjs → BFormCheckbox-xN7AQw4O.mjs} +8 -8
  94. package/dist/BFormCheckbox-xN7AQw4O.mjs.map +1 -0
  95. package/dist/{BFormFile-BWknj7fW.js → BFormFile-DC-x9wQo.js} +3 -3
  96. package/dist/{BFormFile-BWknj7fW.js.map → BFormFile-DC-x9wQo.js.map} +1 -1
  97. package/dist/{BFormFile-Bf3GMYeX.mjs → BFormFile-DXdAyYmv.mjs} +3 -3
  98. package/dist/{BFormFile-Bf3GMYeX.mjs.map → BFormFile-DXdAyYmv.mjs.map} +1 -1
  99. package/dist/BFormGroup-DZTiChgT.js +505 -0
  100. package/dist/BFormGroup-DZTiChgT.js.map +1 -0
  101. package/dist/BFormGroup-ayltvQts.mjs +499 -0
  102. package/dist/BFormGroup-ayltvQts.mjs.map +1 -0
  103. package/dist/{BFormInput-BuRSGYdY.js → BFormInput-DNuvqbFQ.js} +2 -2
  104. package/dist/BFormInput-DNuvqbFQ.js.map +1 -0
  105. package/dist/{BFormInput-Dg9dbwHp.mjs → BFormInput-NKko58M2.mjs} +2 -2
  106. package/dist/BFormInput-NKko58M2.mjs.map +1 -0
  107. package/dist/{BFormOtp-DYjsPhQN.mjs → BFormOtp-B4al7MJf.mjs} +6 -6
  108. package/dist/{BFormOtp-DYjsPhQN.mjs.map → BFormOtp-B4al7MJf.mjs.map} +1 -1
  109. package/dist/{BFormOtp-C1YJvwN8.js → BFormOtp-UcLR9oFd.js} +6 -6
  110. package/dist/{BFormOtp-C1YJvwN8.js.map → BFormOtp-UcLR9oFd.js.map} +1 -1
  111. package/dist/{BFormRadio-CRDbgMiR.mjs → BFormRadio-DHx68AdL.mjs} +8 -8
  112. package/dist/BFormRadio-DHx68AdL.mjs.map +1 -0
  113. package/dist/{BFormRadio-DuVYw-Vs.js → BFormRadio-DX-gM5Rc.js} +8 -8
  114. package/dist/BFormRadio-DX-gM5Rc.js.map +1 -0
  115. package/dist/{BFormRating-Bb_ACp-9.mjs → BFormRating-BR7RMvZG.mjs} +2 -2
  116. package/dist/BFormRating-BR7RMvZG.mjs.map +1 -0
  117. package/dist/{BFormRating-CNqf91vN.js → BFormRating-CF-x5qkB.js} +2 -2
  118. package/dist/BFormRating-CF-x5qkB.js.map +1 -0
  119. package/dist/{BFormSelect-DIKVsG--.js → BFormSelect-CUkyKBNN.js} +9 -9
  120. package/dist/BFormSelect-CUkyKBNN.js.map +1 -0
  121. package/dist/{BFormSelect-Bb8yE8vz.mjs → BFormSelect-Co-ZU8yY.mjs} +9 -9
  122. package/dist/BFormSelect-Co-ZU8yY.mjs.map +1 -0
  123. package/dist/{BFormSelectOption-O8cyyv3i.mjs → BFormSelectOption-B3BO50XB.mjs} +1 -1
  124. package/dist/BFormSelectOption-B3BO50XB.mjs.map +1 -0
  125. package/dist/{BFormSelectOption-BY4P8HOf.js → BFormSelectOption-CQ3j1Q5j.js} +1 -1
  126. package/dist/BFormSelectOption-CQ3j1Q5j.js.map +1 -0
  127. package/dist/{BFormSpinbutton-BLO0Yf36.mjs → BFormSpinbutton-CPsVUIh9.mjs} +4 -4
  128. package/dist/{BFormSpinbutton-BLO0Yf36.mjs.map → BFormSpinbutton-CPsVUIh9.mjs.map} +1 -1
  129. package/dist/{BFormSpinbutton-BaOTL1k1.js → BFormSpinbutton-DPCXum9q.js} +4 -4
  130. package/dist/{BFormSpinbutton-BaOTL1k1.js.map → BFormSpinbutton-DPCXum9q.js.map} +1 -1
  131. package/dist/{BFormTag-C7B-bX72.js → BFormTag-Bsy6Znok.js} +3 -3
  132. package/dist/BFormTag-Bsy6Znok.js.map +1 -0
  133. package/dist/{BFormTag-BUWEugEC.mjs → BFormTag-Cjg1R-Lj.mjs} +3 -3
  134. package/dist/BFormTag-Cjg1R-Lj.mjs.map +1 -0
  135. package/dist/{BFormTags-BFA6xbr3.js → BFormTags-BIZyBseI.js} +11 -9
  136. package/dist/BFormTags-BIZyBseI.js.map +1 -0
  137. package/dist/{BFormTags-CJb4H67g.mjs → BFormTags-D2Dk598Q.mjs} +11 -9
  138. package/dist/BFormTags-D2Dk598Q.mjs.map +1 -0
  139. package/dist/{BFormTextarea-8c3B3kAI.js → BFormTextarea-CYh47SxL.js} +3 -3
  140. package/dist/BFormTextarea-CYh47SxL.js.map +1 -0
  141. package/dist/{BFormTextarea-BMk05ojJ.mjs → BFormTextarea-M21mholw.mjs} +3 -3
  142. package/dist/BFormTextarea-M21mholw.mjs.map +1 -0
  143. package/dist/{BFormValidFeedback-DvTgwqSe.js → BFormValidFeedback-BhkEhSa0.js} +3 -3
  144. package/dist/BFormValidFeedback-BhkEhSa0.js.map +1 -0
  145. package/dist/{BFormValidFeedback-_Dgzm0Ag.mjs → BFormValidFeedback-DWkakzVO.mjs} +3 -3
  146. package/dist/BFormValidFeedback-DWkakzVO.mjs.map +1 -0
  147. package/dist/{BImg-Dyy0N-WQ.js → BImg-DFiJSy66.js} +7 -7
  148. package/dist/BImg-DFiJSy66.js.map +1 -0
  149. package/dist/{BImg-BQqZfIM9.mjs → BImg-UUMOpbK0.mjs} +7 -7
  150. package/dist/BImg-UUMOpbK0.mjs.map +1 -0
  151. package/dist/{BInputGroup-DpX10xwR.mjs → BInputGroup-3AVRA3U7.mjs} +3 -3
  152. package/dist/BInputGroup-3AVRA3U7.mjs.map +1 -0
  153. package/dist/{BInputGroup-Duk6Jk0v.js → BInputGroup-BAC-B_UM.js} +3 -3
  154. package/dist/BInputGroup-BAC-B_UM.js.map +1 -0
  155. package/dist/{BInputGroup-C7k0tS9j.mjs → BInputGroup-CfELrPhK.mjs} +2 -2
  156. package/dist/BInputGroup-CfELrPhK.mjs.map +1 -0
  157. package/dist/{BInputGroup-BScMw6Zr.js → BInputGroup-CiKwWBSu.js} +2 -2
  158. package/dist/BInputGroup-CiKwWBSu.js.map +1 -0
  159. package/dist/{BLink-Cz5YCsnv.mjs → BLink-CNFWSz0D.mjs} +2 -2
  160. package/dist/{BLink-Cz5YCsnv.mjs.map → BLink-CNFWSz0D.mjs.map} +1 -1
  161. package/dist/{BLink-uemyYKst.js → BLink-uLjtY3bY.js} +2 -2
  162. package/dist/{BLink-uemyYKst.js.map → BLink-uLjtY3bY.js.map} +1 -1
  163. package/dist/{BListGroup-BmtN0xQ3.mjs → BListGroup-CGxa7ZEu.mjs} +2 -2
  164. package/dist/BListGroup-CGxa7ZEu.mjs.map +1 -0
  165. package/dist/{BListGroup-DuyMdAxJ.js → BListGroup-CeXKZio1.js} +2 -2
  166. package/dist/BListGroup-CeXKZio1.js.map +1 -0
  167. package/dist/{BModal-D0LB339D.js → BModal-6hh-azT8.js} +12 -12
  168. package/dist/BModal-6hh-azT8.js.map +1 -0
  169. package/dist/{BModal-Br5xLT0-.mjs → BModal-BEmloby5.mjs} +12 -12
  170. package/dist/BModal-BEmloby5.mjs.map +1 -0
  171. package/dist/{BNav-BRjdHsjC.mjs → BNav-EHHlEg1E.mjs} +7 -6
  172. package/dist/BNav-EHHlEg1E.mjs.map +1 -0
  173. package/dist/{BNav-tYBwz1wU.js → BNav-u9QwSGj3.js} +7 -6
  174. package/dist/BNav-u9QwSGj3.js.map +1 -0
  175. package/dist/{BNavbar-vN3_CMLn.mjs → BNavbar-kgHIo_Gr.mjs} +5 -5
  176. package/dist/BNavbar-kgHIo_Gr.mjs.map +1 -0
  177. package/dist/{BNavbar-s9Ak5PnO.js → BNavbar-s8yvmhyz.js} +5 -5
  178. package/dist/BNavbar-s8yvmhyz.js.map +1 -0
  179. package/dist/{BOffcanvas-jETHbtC3.mjs → BOffcanvas-DaKJOICF.mjs} +9 -9
  180. package/dist/BOffcanvas-DaKJOICF.mjs.map +1 -0
  181. package/dist/{BOffcanvas-D33pEfZe.js → BOffcanvas-mlOkh8T1.js} +9 -9
  182. package/dist/BOffcanvas-mlOkh8T1.js.map +1 -0
  183. package/dist/{BOverlay-B7vJAdHO.js → BOverlay--gZBEMlX.js} +5 -5
  184. package/dist/BOverlay--gZBEMlX.js.map +1 -0
  185. package/dist/{BOverlay-BGxH9JVy.mjs → BOverlay-DSUoseNJ.mjs} +5 -5
  186. package/dist/BOverlay-DSUoseNJ.mjs.map +1 -0
  187. package/dist/{BPagination-CvoSN1He.mjs → BPagination-C7MKOk8h.mjs} +8 -8
  188. package/dist/BPagination-C7MKOk8h.mjs.map +1 -0
  189. package/dist/{BPagination-C0-4NVzW.js → BPagination-D6W1LdgK.js} +8 -8
  190. package/dist/BPagination-D6W1LdgK.js.map +1 -0
  191. package/dist/{BPlaceholder-DYYYuNgR.js → BPlaceholder-Ckvq3tMu.js} +14 -14
  192. package/dist/BPlaceholder-Ckvq3tMu.js.map +1 -0
  193. package/dist/{BPlaceholder-C4AOg29f.mjs → BPlaceholder-D__hNPyQ.mjs} +14 -14
  194. package/dist/BPlaceholder-D__hNPyQ.mjs.map +1 -0
  195. package/dist/{BProgress-BIqo6vLh.mjs → BProgress-I1ucNlpA.mjs} +3 -3
  196. package/dist/BProgress-I1ucNlpA.mjs.map +1 -0
  197. package/dist/{BProgress-Bc3ZSkac.js → BProgress-ySlPjpRn.js} +3 -3
  198. package/dist/BProgress-ySlPjpRn.js.map +1 -0
  199. package/dist/{BRow-tqMEhkZS.js → BRow-CmKiMcMZ.js} +3 -3
  200. package/dist/BRow-CmKiMcMZ.js.map +1 -0
  201. package/dist/{BRow-BCEK3fe6.mjs → BRow-U3L8AcKV.mjs} +3 -3
  202. package/dist/BRow-U3L8AcKV.mjs.map +1 -0
  203. package/dist/{BSpinner-8UMAINYb.js → BSpinner-C1bm8U4-.js} +2 -2
  204. package/dist/BSpinner-C1bm8U4-.js.map +1 -0
  205. package/dist/{BSpinner-BpnwONvx.mjs → BSpinner-CAo-XD04.mjs} +2 -2
  206. package/dist/BSpinner-CAo-XD04.mjs.map +1 -0
  207. package/dist/{BTable-CjHMx8Yv.mjs → BTable-DYS8Lftg.mjs} +7 -7
  208. package/dist/BTable-DYS8Lftg.mjs.map +1 -0
  209. package/dist/{BTable-Btzu1IJ_.js → BTable-G-Pjvx68.js} +7 -7
  210. package/dist/BTable-G-Pjvx68.js.map +1 -0
  211. package/dist/{BTableSimple-C901Z5V9.mjs → BTableSimple-CThwYBVl.mjs} +3 -3
  212. package/dist/BTableSimple-CThwYBVl.mjs.map +1 -0
  213. package/dist/{BTableSimple-BcdizuDm.js → BTableSimple-pyz_6D4s.js} +3 -3
  214. package/dist/BTableSimple-pyz_6D4s.js.map +1 -0
  215. package/dist/{BTabs-DiYaJi22.js → BTabs-C8rUY0Lx.js} +41 -13
  216. package/dist/BTabs-C8rUY0Lx.js.map +1 -0
  217. package/dist/{BTabs-DZEF9kgT.mjs → BTabs-Krs_Lv-R.mjs} +42 -14
  218. package/dist/BTabs-Krs_Lv-R.mjs.map +1 -0
  219. package/dist/{BTimeField-DSWZeGYP.mjs → BTimeField-DSf4cMpN.mjs} +5 -5
  220. package/dist/{BTimeField-DSWZeGYP.mjs.map → BTimeField-DSf4cMpN.mjs.map} +1 -1
  221. package/dist/{BTimeField-VTrtxGkI.js → BTimeField-W2LqGCjB.js} +5 -5
  222. package/dist/{BTimeField-VTrtxGkI.js.map → BTimeField-W2LqGCjB.js.map} +1 -1
  223. package/dist/{BToast-DCSZYXIi.js → BToast-DZuxMDbe.js} +10 -11
  224. package/dist/BToast-DZuxMDbe.js.map +1 -0
  225. package/dist/{BToast-B2rFKhLD.mjs → BToast-Dcfnqbxt.mjs} +10 -11
  226. package/dist/BToast-Dcfnqbxt.mjs.map +1 -0
  227. package/dist/{BTooltip-CryTO-SM.js → BTooltip-BGTjsV1z.js} +2 -2
  228. package/dist/BTooltip-BGTjsV1z.js.map +1 -0
  229. package/dist/{BTooltip-DtpjIEBu.mjs → BTooltip-BWij0hjE.mjs} +2 -2
  230. package/dist/BTooltip-BWij0hjE.mjs.map +1 -0
  231. package/dist/{BootstrapVueOptions-DbXZtoXX.js → BootstrapVueOptions-DeViqxoD.js} +1 -1
  232. package/dist/{BootstrapVueOptions-DbXZtoXX.js.map → BootstrapVueOptions-DeViqxoD.js.map} +1 -1
  233. package/dist/{BootstrapVueOptions-D3flIVqU.mjs → BootstrapVueOptions-Dt1TQdih.mjs} +1 -1
  234. package/dist/{BootstrapVueOptions-D3flIVqU.mjs.map → BootstrapVueOptions-Dt1TQdih.mjs.map} +1 -1
  235. package/dist/{ConditionalTeleport-BNsziElf.mjs → ConditionalTeleport-B4KYZIM6.mjs} +1 -1
  236. package/dist/ConditionalTeleport-B4KYZIM6.mjs.map +1 -0
  237. package/dist/{ConditionalTeleport-BJZk6HAx.js → ConditionalTeleport-BDWcebyD.js} +1 -1
  238. package/dist/ConditionalTeleport-BDWcebyD.js.map +1 -0
  239. package/dist/{ConditionalWrapper-Cc7EIszd.js → ConditionalWrapper-DZH_VSwb.js} +1 -1
  240. package/dist/{ConditionalWrapper-Cc7EIszd.js.map → ConditionalWrapper-DZH_VSwb.js.map} +1 -1
  241. package/dist/{ConditionalWrapper-D9ovtbHB.mjs → ConditionalWrapper-Dbc_O6qe.mjs} +1 -1
  242. package/dist/{ConditionalWrapper-D9ovtbHB.mjs.map → ConditionalWrapper-Dbc_O6qe.mjs.map} +1 -1
  243. package/dist/{DateRangeFieldInput-DiVuhf4Y.mjs → DateRangeFieldInput-B86VEz0H.mjs} +5 -5
  244. package/dist/{DateRangeFieldInput-DiVuhf4Y.mjs.map → DateRangeFieldInput-B86VEz0H.mjs.map} +1 -1
  245. package/dist/{DateRangeFieldInput-Ce7PM3PJ.js → DateRangeFieldInput-HvvI2You.js} +5 -5
  246. package/dist/{DateRangeFieldInput-Ce7PM3PJ.js.map → DateRangeFieldInput-HvvI2You.js.map} +1 -1
  247. package/dist/{PopperContent-CSwv2Fih.js → PopperContent-BS_eKjzD.js} +6 -6
  248. package/dist/{PopperContent-CSwv2Fih.js.map → PopperContent-BS_eKjzD.js.map} +1 -1
  249. package/dist/{PopperContent-BTUvv6Tu.mjs → PopperContent-DmSgsjSC.mjs} +6 -6
  250. package/dist/{PopperContent-BTUvv6Tu.mjs.map → PopperContent-DmSgsjSC.mjs.map} +1 -1
  251. package/dist/{VisuallyHidden-Bbwok8oL.mjs → VisuallyHidden-C4sXnc-k.mjs} +2 -2
  252. package/dist/{VisuallyHidden-Bbwok8oL.mjs.map → VisuallyHidden-C4sXnc-k.mjs.map} +1 -1
  253. package/dist/{VisuallyHidden-DaN947I0.js → VisuallyHidden-Cx0phlXT.js} +2 -2
  254. package/dist/{VisuallyHidden-DaN947I0.js.map → VisuallyHidden-Cx0phlXT.js.map} +1 -1
  255. package/dist/{VisuallyHiddenInput-Biq4Qv5j.js → VisuallyHiddenInput-BNrInt6d.js} +2 -2
  256. package/dist/{VisuallyHiddenInput-Biq4Qv5j.js.map → VisuallyHiddenInput-BNrInt6d.js.map} +1 -1
  257. package/dist/{VisuallyHiddenInput-D1SjTCVH.mjs → VisuallyHiddenInput-DKIzxsQR.mjs} +2 -2
  258. package/dist/{VisuallyHiddenInput-D1SjTCVH.mjs.map → VisuallyHiddenInput-DKIzxsQR.mjs.map} +1 -1
  259. package/dist/bootstrap-vue-next.css +56 -1
  260. package/dist/bootstrap-vue-next.mjs +60 -60
  261. package/dist/bootstrap-vue-next.umd.js +60 -60
  262. package/dist/components/BAccordion/BAccordionItem.vue.d.mts +1 -2
  263. package/dist/components/BAccordion/BAccordionItem.vue.d.ts +1 -2
  264. package/dist/components/BAlert/BAlert.vue.d.mts +1 -1
  265. package/dist/components/BAlert/BAlert.vue.d.ts +1 -1
  266. package/dist/components/BApp/BApp.vue.d.mts +1 -1
  267. package/dist/components/BApp/BApp.vue.d.ts +1 -1
  268. package/dist/components/BApp/BOrchestrator.vue.d.mts +1 -1
  269. package/dist/components/BApp/BOrchestrator.vue.d.ts +1 -1
  270. package/dist/components/BAspect/BAspect.vue.d.mts +2 -4
  271. package/dist/components/BAspect/BAspect.vue.d.ts +2 -4
  272. package/dist/components/BAutocomplete/BAutocomplete.vue.d.mts +266 -6
  273. package/dist/components/BAutocomplete/BAutocomplete.vue.d.ts +266 -6
  274. package/dist/components/BAvatar/BAvatar.vue.d.mts +1 -2
  275. package/dist/components/BAvatar/BAvatar.vue.d.ts +1 -2
  276. package/dist/components/BAvatar/BAvatarGroup.vue.d.mts +1 -2
  277. package/dist/components/BAvatar/BAvatarGroup.vue.d.ts +1 -2
  278. package/dist/components/BBadge/BBadge.vue.d.mts +1 -2
  279. package/dist/components/BBadge/BBadge.vue.d.ts +1 -2
  280. package/dist/components/BBreadcrumb/BBreadcrumb.vue.d.mts +1 -2
  281. package/dist/components/BBreadcrumb/BBreadcrumb.vue.d.ts +1 -2
  282. package/dist/components/BBreadcrumb/BBreadcrumbItem.vue.d.mts +1 -2
  283. package/dist/components/BBreadcrumb/BBreadcrumbItem.vue.d.ts +1 -2
  284. package/dist/components/BButton/BButton.vue.d.mts +1 -3
  285. package/dist/components/BButton/BButton.vue.d.ts +1 -3
  286. package/dist/components/BButton/BButtonGroup.vue.d.mts +1 -2
  287. package/dist/components/BButton/BButtonGroup.vue.d.ts +1 -2
  288. package/dist/components/BButton/BCloseButton.vue.d.mts +1 -1
  289. package/dist/components/BButton/BCloseButton.vue.d.ts +1 -1
  290. package/dist/components/BCard/BCard.vue.d.mts +1 -2
  291. package/dist/components/BCard/BCard.vue.d.ts +1 -2
  292. package/dist/components/BCard/BCardBody.vue.d.mts +1 -2
  293. package/dist/components/BCard/BCardBody.vue.d.ts +1 -2
  294. package/dist/components/BCard/BCardGroup.vue.d.mts +1 -2
  295. package/dist/components/BCard/BCardGroup.vue.d.ts +1 -2
  296. package/dist/components/BCard/BCardHeader.vue.d.mts +1 -1
  297. package/dist/components/BCard/BCardHeader.vue.d.ts +1 -1
  298. package/dist/components/BCard/BCardImg.vue.d.mts +1 -1
  299. package/dist/components/BCard/BCardImg.vue.d.ts +1 -1
  300. package/dist/components/BCard/BCardSubtitle.vue.d.mts +1 -2
  301. package/dist/components/BCard/BCardSubtitle.vue.d.ts +1 -2
  302. package/dist/components/BCard/BCardText.vue.d.mts +1 -2
  303. package/dist/components/BCard/BCardText.vue.d.ts +1 -2
  304. package/dist/components/BCard/BCardTitle.vue.d.mts +1 -2
  305. package/dist/components/BCard/BCardTitle.vue.d.ts +1 -2
  306. package/dist/components/BCardHeadFoot.vue.d.mts +1 -2
  307. package/dist/components/BCardHeadFoot.vue.d.ts +1 -2
  308. package/dist/components/BCarousel/BCarousel.vue.d.mts +1 -1
  309. package/dist/components/BCarousel/BCarousel.vue.d.ts +1 -1
  310. package/dist/components/BCarousel/BCarouselSlide.vue.d.mts +1 -2
  311. package/dist/components/BCarousel/BCarouselSlide.vue.d.ts +1 -2
  312. package/dist/components/BCollapse/BCollapse.vue.d.mts +1 -2
  313. package/dist/components/BCollapse/BCollapse.vue.d.ts +1 -2
  314. package/dist/components/BContainer/BCol.vue.d.mts +2 -3
  315. package/dist/components/BContainer/BCol.vue.d.ts +2 -3
  316. package/dist/components/BContainer/BContainer.vue.d.mts +1 -2
  317. package/dist/components/BContainer/BContainer.vue.d.ts +1 -2
  318. package/dist/components/BContainer/BRow.vue.d.mts +1 -2
  319. package/dist/components/BContainer/BRow.vue.d.ts +1 -2
  320. package/dist/components/BDateField/BDateField.vue.d.mts +2 -3
  321. package/dist/components/BDateField/BDateField.vue.d.ts +2 -3
  322. package/dist/components/BDateField/BDateRangeField.vue.d.mts +2 -3
  323. package/dist/components/BDateField/BDateRangeField.vue.d.ts +2 -3
  324. package/dist/components/BDateField/BTimeRangeField.vue.d.mts +5 -6
  325. package/dist/components/BDateField/BTimeRangeField.vue.d.ts +5 -6
  326. package/dist/components/BDatePicker/BDatePicker.vue.d.mts +3 -4
  327. package/dist/components/BDatePicker/BDatePicker.vue.d.ts +3 -4
  328. package/dist/components/BDatePicker/BDateRangePicker.vue.d.mts +3 -4
  329. package/dist/components/BDatePicker/BDateRangePicker.vue.d.ts +3 -4
  330. package/dist/components/BDropdown/BDropdown.vue.d.mts +1 -0
  331. package/dist/components/BDropdown/BDropdown.vue.d.ts +1 -0
  332. package/dist/components/BDropdown/BDropdownDivider.vue.d.mts +1 -1
  333. package/dist/components/BDropdown/BDropdownDivider.vue.d.ts +1 -1
  334. package/dist/components/BDropdown/BDropdownForm.vue.d.mts +1 -2
  335. package/dist/components/BDropdown/BDropdownForm.vue.d.ts +1 -2
  336. package/dist/components/BDropdown/BDropdownGroup.vue.d.mts +1 -2
  337. package/dist/components/BDropdown/BDropdownGroup.vue.d.ts +1 -2
  338. package/dist/components/BDropdown/BDropdownHeader.vue.d.mts +1 -2
  339. package/dist/components/BDropdown/BDropdownHeader.vue.d.ts +1 -2
  340. package/dist/components/BDropdown/BDropdownItem.vue.d.mts +1 -2
  341. package/dist/components/BDropdown/BDropdownItem.vue.d.ts +1 -2
  342. package/dist/components/BDropdown/BDropdownItemButton.vue.d.mts +1 -2
  343. package/dist/components/BDropdown/BDropdownItemButton.vue.d.ts +1 -2
  344. package/dist/components/BDropdown/BDropdownText.vue.d.mts +1 -2
  345. package/dist/components/BDropdown/BDropdownText.vue.d.ts +1 -2
  346. package/dist/components/BForm/BForm.vue.d.mts +1 -2
  347. package/dist/components/BForm/BForm.vue.d.ts +1 -2
  348. package/dist/components/BForm/BFormDatalist.vue.d.mts +1 -2
  349. package/dist/components/BForm/BFormDatalist.vue.d.ts +1 -2
  350. package/dist/components/BForm/BFormDatalistBase.vue.d.mts +1 -1
  351. package/dist/components/BForm/BFormDatalistBase.vue.d.ts +1 -1
  352. package/dist/components/BForm/BFormFloatingLabel.vue.d.mts +1 -2
  353. package/dist/components/BForm/BFormFloatingLabel.vue.d.ts +1 -2
  354. package/dist/components/BForm/BFormRow.vue.d.mts +1 -2
  355. package/dist/components/BForm/BFormRow.vue.d.ts +1 -2
  356. package/dist/components/BForm/BFormText.vue.d.mts +1 -2
  357. package/dist/components/BForm/BFormText.vue.d.ts +1 -2
  358. package/dist/components/BFormCheckbox/BFormCheckbox.vue.d.mts +1 -3
  359. package/dist/components/BFormCheckbox/BFormCheckbox.vue.d.ts +1 -3
  360. package/dist/components/BFormCheckbox/BFormCheckboxGroup.vue.d.mts +1 -2
  361. package/dist/components/BFormCheckbox/BFormCheckboxGroup.vue.d.ts +1 -2
  362. package/dist/components/BFormCheckbox/BFormCheckboxGroupBase.vue.d.mts +1 -2
  363. package/dist/components/BFormCheckbox/BFormCheckboxGroupBase.vue.d.ts +1 -2
  364. package/dist/components/BFormGroup/BFormGroup.vue.d.mts +3 -3
  365. package/dist/components/BFormGroup/BFormGroup.vue.d.ts +3 -3
  366. package/dist/components/BFormGroupContent.vue.d.mts +35 -0
  367. package/dist/components/BFormGroupContent.vue.d.ts +35 -0
  368. package/dist/components/BFormGroupLabel.vue.d.mts +35 -0
  369. package/dist/components/BFormGroupLabel.vue.d.ts +35 -0
  370. package/dist/components/BFormInput/BFormInput.vue.d.mts +2 -2
  371. package/dist/components/BFormInput/BFormInput.vue.d.ts +2 -2
  372. package/dist/components/BFormRadio/BFormRadio.vue.d.mts +1 -3
  373. package/dist/components/BFormRadio/BFormRadio.vue.d.ts +1 -3
  374. package/dist/components/BFormRadio/BFormRadioGroup.vue.d.mts +1 -2
  375. package/dist/components/BFormRadio/BFormRadioGroup.vue.d.ts +1 -2
  376. package/dist/components/BFormRadio/BFormRadioGroupBase.vue.d.mts +1 -2
  377. package/dist/components/BFormRadio/BFormRadioGroupBase.vue.d.ts +1 -2
  378. package/dist/components/BFormSelect/BFormSelect.vue.d.mts +1 -3
  379. package/dist/components/BFormSelect/BFormSelect.vue.d.ts +1 -3
  380. package/dist/components/BFormSelect/BFormSelectBase.vue.d.mts +1 -1
  381. package/dist/components/BFormSelect/BFormSelectBase.vue.d.ts +1 -1
  382. package/dist/components/BFormSelect/BFormSelectOption.vue.d.mts +1 -2
  383. package/dist/components/BFormSelect/BFormSelectOption.vue.d.ts +1 -2
  384. package/dist/components/BFormSelect/BFormSelectOptionGroup.vue.d.mts +1 -2
  385. package/dist/components/BFormSelect/BFormSelectOptionGroup.vue.d.ts +1 -2
  386. package/dist/components/BFormSpinbutton/BFormSpinbutton.vue.d.mts +3 -3
  387. package/dist/components/BFormSpinbutton/BFormSpinbutton.vue.d.ts +3 -3
  388. package/dist/components/BFormTags/BFormTag.vue.d.mts +1 -2
  389. package/dist/components/BFormTags/BFormTag.vue.d.ts +1 -2
  390. package/dist/components/BFormTags/BFormTags.vue.d.mts +4 -3
  391. package/dist/components/BFormTags/BFormTags.vue.d.ts +4 -3
  392. package/dist/components/BFormTextarea/BFormTextarea.vue.d.mts +2 -2
  393. package/dist/components/BFormTextarea/BFormTextarea.vue.d.ts +2 -2
  394. package/dist/components/BImg/BImg.vue.d.mts +1 -1
  395. package/dist/components/BImg/BImg.vue.d.ts +1 -1
  396. package/dist/components/BInputGroup/BInputGroup.vue.d.mts +1 -2
  397. package/dist/components/BInputGroup/BInputGroup.vue.d.ts +1 -2
  398. package/dist/components/BInputGroup/BInputGroupText.vue.d.mts +1 -2
  399. package/dist/components/BInputGroup/BInputGroupText.vue.d.ts +1 -2
  400. package/dist/components/BListGroup/BListGroup.vue.d.mts +1 -2
  401. package/dist/components/BListGroup/BListGroup.vue.d.ts +1 -2
  402. package/dist/components/BListGroup/BListGroupItem.vue.d.mts +1 -2
  403. package/dist/components/BListGroup/BListGroupItem.vue.d.ts +1 -2
  404. package/dist/components/BModal/BModal.vue.d.mts +2 -2
  405. package/dist/components/BModal/BModal.vue.d.ts +2 -2
  406. package/dist/components/BNav/BNav.vue.d.mts +1 -2
  407. package/dist/components/BNav/BNav.vue.d.ts +1 -2
  408. package/dist/components/BNav/BNavForm.vue.d.mts +1 -2
  409. package/dist/components/BNav/BNavForm.vue.d.ts +1 -2
  410. package/dist/components/BNav/BNavItem.vue.d.mts +1 -2
  411. package/dist/components/BNav/BNavItem.vue.d.ts +1 -2
  412. package/dist/components/BNav/BNavItemDropdown.vue.d.mts +14 -4
  413. package/dist/components/BNav/BNavItemDropdown.vue.d.ts +14 -4
  414. package/dist/components/BNav/BNavText.vue.d.mts +1 -2
  415. package/dist/components/BNav/BNavText.vue.d.ts +1 -2
  416. package/dist/components/BNavbar/BNavbar.vue.d.mts +1 -2
  417. package/dist/components/BNavbar/BNavbar.vue.d.ts +1 -2
  418. package/dist/components/BNavbar/BNavbarBrand.vue.d.mts +1 -2
  419. package/dist/components/BNavbar/BNavbarBrand.vue.d.ts +1 -2
  420. package/dist/components/BNavbar/BNavbarNav.vue.d.mts +1 -2
  421. package/dist/components/BNavbar/BNavbarNav.vue.d.ts +1 -2
  422. package/dist/components/BNavbar/BNavbarToggle.vue.d.mts +1 -2
  423. package/dist/components/BNavbar/BNavbarToggle.vue.d.ts +1 -2
  424. package/dist/components/BOffcanvas/BOffcanvas.vue.d.mts +1 -2
  425. package/dist/components/BOffcanvas/BOffcanvas.vue.d.ts +1 -2
  426. package/dist/components/BOverlay/BOverlay.vue.d.mts +1 -2
  427. package/dist/components/BOverlay/BOverlay.vue.d.ts +1 -2
  428. package/dist/components/BPagination/BPagination.vue.d.mts +1 -1
  429. package/dist/components/BPagination/BPagination.vue.d.ts +1 -1
  430. package/dist/components/BPlaceholder/BPlaceholder.vue.d.mts +1 -1
  431. package/dist/components/BPlaceholder/BPlaceholder.vue.d.ts +1 -1
  432. package/dist/components/BPlaceholder/BPlaceholderButton.vue.d.mts +1 -1
  433. package/dist/components/BPlaceholder/BPlaceholderButton.vue.d.ts +1 -1
  434. package/dist/components/BPlaceholder/BPlaceholderCard.vue.d.mts +1 -2
  435. package/dist/components/BPlaceholder/BPlaceholderCard.vue.d.ts +1 -2
  436. package/dist/components/BPlaceholder/BPlaceholderTable.vue.d.mts +1 -2
  437. package/dist/components/BPlaceholder/BPlaceholderTable.vue.d.ts +1 -2
  438. package/dist/components/BPlaceholder/BPlaceholderWrapper.vue.d.mts +1 -2
  439. package/dist/components/BPlaceholder/BPlaceholderWrapper.vue.d.ts +1 -2
  440. package/dist/components/BPopover/BPopover.vue.d.mts +1 -1
  441. package/dist/components/BPopover/BPopover.vue.d.ts +1 -1
  442. package/dist/components/BProgress/BProgress.vue.d.mts +1 -2
  443. package/dist/components/BProgress/BProgress.vue.d.ts +1 -2
  444. package/dist/components/BProgress/BProgressBar.vue.d.mts +1 -2
  445. package/dist/components/BProgress/BProgressBar.vue.d.ts +1 -2
  446. package/dist/components/BSpinner/BSpinner.vue.d.mts +1 -2
  447. package/dist/components/BSpinner/BSpinner.vue.d.ts +1 -2
  448. package/dist/components/BTable/BTableLite.vue.d.mts +1 -2
  449. package/dist/components/BTable/BTableLite.vue.d.ts +1 -2
  450. package/dist/components/BTable/BTableSimple.vue.d.mts +1 -2
  451. package/dist/components/BTable/BTableSimple.vue.d.ts +1 -2
  452. package/dist/components/BTable/BTbody.vue.d.mts +1 -2
  453. package/dist/components/BTable/BTbody.vue.d.ts +1 -2
  454. package/dist/components/BTable/BTd.vue.d.mts +1 -2
  455. package/dist/components/BTable/BTd.vue.d.ts +1 -2
  456. package/dist/components/BTable/BTfoot.vue.d.mts +1 -2
  457. package/dist/components/BTable/BTfoot.vue.d.ts +1 -2
  458. package/dist/components/BTable/BTh.vue.d.mts +1 -2
  459. package/dist/components/BTable/BTh.vue.d.ts +1 -2
  460. package/dist/components/BTable/BThead.vue.d.mts +1 -2
  461. package/dist/components/BTable/BThead.vue.d.ts +1 -2
  462. package/dist/components/BTable/BTr.vue.d.mts +1 -2
  463. package/dist/components/BTable/BTr.vue.d.ts +1 -2
  464. package/dist/components/BTabs/BTabs.vue.d.mts +2 -0
  465. package/dist/components/BTabs/BTabs.vue.d.ts +2 -0
  466. package/dist/components/BTabsTabContent.vue.d.mts +27 -0
  467. package/dist/components/BTabsTabContent.vue.d.ts +27 -0
  468. package/dist/components/BTimeField/BTimeField.vue.d.mts +2 -3
  469. package/dist/components/BTimeField/BTimeField.vue.d.ts +2 -3
  470. package/dist/components/BToast/BToast.vue.d.mts +1 -2
  471. package/dist/components/BToast/BToast.vue.d.ts +1 -2
  472. package/dist/components/BTooltip/BTooltip.vue.d.mts +1 -1
  473. package/dist/components/BTooltip/BTooltip.vue.d.ts +1 -1
  474. package/dist/composables/useAriaInvalid.d.mts +3 -2
  475. package/dist/composables/useAriaInvalid.d.ts +3 -2
  476. package/dist/composables/useFormInput.d.mts +1 -1
  477. package/dist/composables/useFormInput.d.ts +1 -1
  478. package/dist/{constants-hccBP09R.js → constants-BLIvvaat.js} +1 -1
  479. package/dist/{constants-hccBP09R.js.map → constants-BLIvvaat.js.map} +1 -1
  480. package/dist/{constants-BSIK14yA.mjs → constants-Ba9iJn2H.mjs} +1 -1
  481. package/dist/{constants-BSIK14yA.mjs.map → constants-Ba9iJn2H.mjs.map} +1 -1
  482. package/dist/{debounce-C-5Oukxb.js → debounce-D6kifS6w.js} +1 -1
  483. package/dist/{debounce-C-5Oukxb.js.map → debounce-D6kifS6w.js.map} +1 -1
  484. package/dist/{debounce-C_wjWVGH.mjs → debounce-DHxNfjan.mjs} +1 -1
  485. package/dist/{debounce-C_wjWVGH.mjs.map → debounce-DHxNfjan.mjs.map} +1 -1
  486. package/dist/{dist-BJ15ThEs.js → dist-DiXKLh_W.js} +2 -66
  487. package/dist/{dist-BJ15ThEs.js.map → dist-DiXKLh_W.js.map} +1 -1
  488. package/dist/{dist-B10a-gZ8.mjs → dist-Dk9C_HFS.mjs} +4 -62
  489. package/dist/dist-Dk9C_HFS.mjs.map +1 -0
  490. package/dist/{floating-ui.vue-CAMaNcqI.mjs → floating-ui.vue-CH2o_mZU.mjs} +1 -1
  491. package/dist/{floating-ui.vue-CAMaNcqI.mjs.map → floating-ui.vue-CH2o_mZU.mjs.map} +1 -1
  492. package/dist/{floating-ui.vue-GXIS2sFG.js → floating-ui.vue-DDOIU2nS.js} +1 -1
  493. package/dist/{floating-ui.vue-GXIS2sFG.js.map → floating-ui.vue-DDOIU2nS.js.map} +1 -1
  494. package/dist/{floatingUi-DHMrP__c.mjs → floatingUi-8xXp54zf.mjs} +21 -13
  495. package/dist/floatingUi-8xXp54zf.mjs.map +1 -0
  496. package/dist/{floatingUi-Cs4rDXmO.js → floatingUi-9SWu8BgZ.js} +26 -12
  497. package/dist/floatingUi-9SWu8BgZ.js.map +1 -0
  498. package/dist/{getClasses-qqI6x4f4.js → getClasses-8P0iBind.js} +1 -1
  499. package/dist/{getClasses-qqI6x4f4.js.map → getClasses-8P0iBind.js.map} +1 -1
  500. package/dist/{getClasses-DaWzwT2S.mjs → getClasses-COokMI60.mjs} +1 -1
  501. package/dist/{getClasses-DaWzwT2S.mjs.map → getClasses-COokMI60.mjs.map} +1 -1
  502. package/dist/{getElement-0_htvrFw.mjs → getElement-D2Jr1cbp.mjs} +1 -1
  503. package/dist/{getElement-0_htvrFw.mjs.map → getElement-D2Jr1cbp.mjs.map} +1 -1
  504. package/dist/{getElement-CxWWOx3K.js → getElement-DWGFJn0w.js} +1 -1
  505. package/dist/{getElement-CxWWOx3K.js.map → getElement-DWGFJn0w.js.map} +1 -1
  506. package/dist/keys-CQKrwmvN.mjs.map +1 -1
  507. package/dist/keys-durSVUrO.js.map +1 -1
  508. package/dist/{registryAccess-D-YxwQJq.js → registryAccess-B9QDQwV8.js} +1 -1
  509. package/dist/{registryAccess-D-YxwQJq.js.map → registryAccess-B9QDQwV8.js.map} +1 -1
  510. package/dist/{registryAccess-C1Ti_nxW.mjs → registryAccess-BkJDdh-3.mjs} +1 -1
  511. package/dist/{registryAccess-C1Ti_nxW.mjs.map → registryAccess-BkJDdh-3.mjs.map} +1 -1
  512. package/dist/src/components/BAccordion/index.mjs +1 -1
  513. package/dist/src/components/BAccordion/index.umd.js +1 -1
  514. package/dist/src/components/BAlert/index.mjs +1 -1
  515. package/dist/src/components/BAlert/index.umd.js +1 -1
  516. package/dist/src/components/BApp/index.mjs +1 -1
  517. package/dist/src/components/BApp/index.umd.js +1 -1
  518. package/dist/src/components/BAutocomplete/index.mjs +1 -1
  519. package/dist/src/components/BAutocomplete/index.umd.js +1 -1
  520. package/dist/src/components/BAvatar/index.mjs +1 -1
  521. package/dist/src/components/BAvatar/index.umd.js +1 -1
  522. package/dist/src/components/BBadge/index.mjs +1 -1
  523. package/dist/src/components/BBadge/index.umd.js +1 -1
  524. package/dist/src/components/BBreadcrumb/index.mjs +1 -1
  525. package/dist/src/components/BBreadcrumb/index.umd.js +1 -1
  526. package/dist/src/components/BButton/index.mjs +3 -3
  527. package/dist/src/components/BButton/index.umd.js +3 -3
  528. package/dist/src/components/BCard/index.mjs +2 -2
  529. package/dist/src/components/BCard/index.umd.js +2 -2
  530. package/dist/src/components/BCarousel/index.mjs +1 -1
  531. package/dist/src/components/BCarousel/index.umd.js +1 -1
  532. package/dist/src/components/BCol/index.mjs +1 -1
  533. package/dist/src/components/BCol/index.umd.js +1 -1
  534. package/dist/src/components/BCollapse/index.mjs +1 -1
  535. package/dist/src/components/BCollapse/index.umd.js +1 -1
  536. package/dist/src/components/BContainer/index.mjs +3 -3
  537. package/dist/src/components/BContainer/index.umd.js +3 -3
  538. package/dist/src/components/BDateField/index.mjs +1 -1
  539. package/dist/src/components/BDateField/index.umd.js +1 -1
  540. package/dist/src/components/BDatePicker/index.mjs +1 -1
  541. package/dist/src/components/BDatePicker/index.umd.js +1 -1
  542. package/dist/src/components/BDropdown/index.mjs +2 -2
  543. package/dist/src/components/BDropdown/index.umd.js +2 -2
  544. package/dist/src/components/BForm/index.mjs +3 -3
  545. package/dist/src/components/BForm/index.umd.js +3 -3
  546. package/dist/src/components/BFormCheckbox/index.mjs +1 -1
  547. package/dist/src/components/BFormCheckbox/index.umd.js +1 -1
  548. package/dist/src/components/BFormFile/index.mjs +1 -1
  549. package/dist/src/components/BFormFile/index.umd.js +1 -1
  550. package/dist/src/components/BFormGroup/index.mjs +1 -1
  551. package/dist/src/components/BFormGroup/index.umd.js +1 -1
  552. package/dist/src/components/BFormInput/index.mjs +1 -1
  553. package/dist/src/components/BFormInput/index.umd.js +1 -1
  554. package/dist/src/components/BFormOtp/index.mjs +1 -1
  555. package/dist/src/components/BFormOtp/index.umd.js +1 -1
  556. package/dist/src/components/BFormRadio/index.mjs +1 -1
  557. package/dist/src/components/BFormRadio/index.umd.js +1 -1
  558. package/dist/src/components/BFormRating/index.mjs +1 -1
  559. package/dist/src/components/BFormRating/index.umd.js +1 -1
  560. package/dist/src/components/BFormSelect/index.mjs +2 -2
  561. package/dist/src/components/BFormSelect/index.umd.js +2 -2
  562. package/dist/src/components/BFormSpinbutton/index.mjs +1 -1
  563. package/dist/src/components/BFormSpinbutton/index.umd.js +1 -1
  564. package/dist/src/components/BFormTags/index.mjs +2 -2
  565. package/dist/src/components/BFormTags/index.umd.js +2 -2
  566. package/dist/src/components/BFormTextarea/index.mjs +1 -1
  567. package/dist/src/components/BFormTextarea/index.umd.js +1 -1
  568. package/dist/src/components/BImg/index.mjs +1 -1
  569. package/dist/src/components/BImg/index.umd.js +1 -1
  570. package/dist/src/components/BInputGroup/index.mjs +2 -2
  571. package/dist/src/components/BInputGroup/index.umd.js +2 -2
  572. package/dist/src/components/BLink/index.mjs +1 -1
  573. package/dist/src/components/BLink/index.umd.js +1 -1
  574. package/dist/src/components/BListGroup/index.mjs +1 -1
  575. package/dist/src/components/BListGroup/index.umd.js +1 -1
  576. package/dist/src/components/BModal/index.mjs +1 -1
  577. package/dist/src/components/BModal/index.umd.js +1 -1
  578. package/dist/src/components/BNav/index.mjs +1 -1
  579. package/dist/src/components/BNav/index.umd.js +1 -1
  580. package/dist/src/components/BNavbar/index.mjs +1 -1
  581. package/dist/src/components/BNavbar/index.umd.js +1 -1
  582. package/dist/src/components/BOffcanvas/index.mjs +1 -1
  583. package/dist/src/components/BOffcanvas/index.umd.js +1 -1
  584. package/dist/src/components/BOverlay/index.mjs +1 -1
  585. package/dist/src/components/BOverlay/index.umd.js +1 -1
  586. package/dist/src/components/BPagination/index.mjs +1 -1
  587. package/dist/src/components/BPagination/index.umd.js +1 -1
  588. package/dist/src/components/BPlaceholder/index.mjs +1 -1
  589. package/dist/src/components/BPlaceholder/index.umd.js +1 -1
  590. package/dist/src/components/BPopover/index.mjs +1 -1
  591. package/dist/src/components/BPopover/index.umd.js +1 -1
  592. package/dist/src/components/BProgress/index.mjs +1 -1
  593. package/dist/src/components/BProgress/index.umd.js +1 -1
  594. package/dist/src/components/BRow/index.mjs +1 -1
  595. package/dist/src/components/BRow/index.umd.js +1 -1
  596. package/dist/src/components/BSpinner/index.mjs +1 -1
  597. package/dist/src/components/BSpinner/index.umd.js +1 -1
  598. package/dist/src/components/BTable/index.mjs +2 -2
  599. package/dist/src/components/BTable/index.umd.js +2 -2
  600. package/dist/src/components/BTabs/index.mjs +1 -1
  601. package/dist/src/components/BTabs/index.umd.js +1 -1
  602. package/dist/src/components/BTimeField/index.mjs +1 -1
  603. package/dist/src/components/BTimeField/index.umd.js +1 -1
  604. package/dist/src/components/BToast/index.mjs +1 -1
  605. package/dist/src/components/BToast/index.umd.js +1 -1
  606. package/dist/src/components/BTooltip/index.mjs +1 -1
  607. package/dist/src/components/BTooltip/index.umd.js +1 -1
  608. package/dist/src/components/index.mjs +58 -58
  609. package/dist/src/components/index.umd.js +58 -58
  610. package/dist/src/composables/useColorMode/index.mjs +1 -1
  611. package/dist/src/composables/useColorMode/index.umd.js +1 -1
  612. package/dist/src/composables/useModal/index.mjs +1 -1
  613. package/dist/src/composables/useModal/index.umd.js +1 -1
  614. package/dist/src/composables/usePopover/index.mjs +2 -2
  615. package/dist/src/composables/usePopover/index.umd.js +2 -2
  616. package/dist/src/composables/useScrollLock/index.mjs +1 -1
  617. package/dist/src/composables/useScrollLock/index.umd.js +1 -1
  618. package/dist/src/composables/useScrollspy/index.mjs +2 -2
  619. package/dist/src/composables/useScrollspy/index.umd.js +2 -2
  620. package/dist/src/composables/useToast/index.mjs +1 -1
  621. package/dist/src/composables/useToast/index.umd.js +1 -1
  622. package/dist/src/composables/useToggle/index.mjs +1 -1
  623. package/dist/src/composables/useToggle/index.umd.js +1 -1
  624. package/dist/src/directives/BPopover/index.mjs +2 -2
  625. package/dist/src/directives/BPopover/index.umd.js +2 -2
  626. package/dist/src/directives/BScrollspy/index.mjs +1 -1
  627. package/dist/src/directives/BScrollspy/index.umd.js +1 -1
  628. package/dist/src/directives/BToggle/index.mjs +3 -3
  629. package/dist/src/directives/BToggle/index.umd.js +3 -3
  630. package/dist/src/directives/BTooltip/index.mjs +2 -2
  631. package/dist/src/directives/BTooltip/index.umd.js +2 -2
  632. package/dist/src/resolvers/index.mjs +1 -1
  633. package/dist/src/resolvers/index.umd.js +1 -1
  634. package/dist/src/types/index.mjs +1 -1
  635. package/dist/src/types/index.umd.js +1 -1
  636. package/dist/{stringUtils-BwKOASdU.js → stringUtils-68ZN_GRt.js} +2 -2
  637. package/dist/{stringUtils-BwKOASdU.js.map → stringUtils-68ZN_GRt.js.map} +1 -1
  638. package/dist/{stringUtils-CslYpDTt.mjs → stringUtils-D4eEDlt1.mjs} +2 -2
  639. package/dist/{stringUtils-CslYpDTt.mjs.map → stringUtils-D4eEDlt1.mjs.map} +1 -1
  640. package/dist/types/AriaInvalid.d.mts +1 -0
  641. package/dist/types/AriaInvalid.d.ts +1 -0
  642. package/dist/types/ComponentEmits.d.mts +5 -0
  643. package/dist/types/ComponentEmits.d.ts +5 -0
  644. package/dist/types/ComponentProps.d.mts +4 -0
  645. package/dist/types/ComponentProps.d.ts +4 -0
  646. package/dist/types/ComponentSlots.d.mts +25 -1
  647. package/dist/types/ComponentSlots.d.ts +25 -1
  648. package/dist/types/Size.d.mts +0 -1
  649. package/dist/types/Size.d.ts +0 -1
  650. package/dist/{useAlignment-BiCREohQ.mjs → useAlignment-DuR8ymKI.mjs} +1 -1
  651. package/dist/{useAlignment-BiCREohQ.mjs.map → useAlignment-DuR8ymKI.mjs.map} +1 -1
  652. package/dist/{useAlignment-D5xKBRez.js → useAlignment-oKolnDpb.js} +1 -1
  653. package/dist/{useAlignment-D5xKBRez.js.map → useAlignment-oKolnDpb.js.map} +1 -1
  654. package/dist/useAriaInvalid-CHHPHNLU.js.map +1 -1
  655. package/dist/useAriaInvalid-apOwgexm.mjs.map +1 -1
  656. package/dist/{useColorVariantClasses-B6Me_Kx6.mjs → useColorVariantClasses-CqeXHjRh.mjs} +1 -1
  657. package/dist/{useColorVariantClasses-B6Me_Kx6.mjs.map → useColorVariantClasses-CqeXHjRh.mjs.map} +1 -1
  658. package/dist/{useColorVariantClasses-CEfOwjPv.js → useColorVariantClasses-Dq0sOYDL.js} +1 -1
  659. package/dist/{useColorVariantClasses-CEfOwjPv.js.map → useColorVariantClasses-Dq0sOYDL.js.map} +1 -1
  660. package/dist/{useCountdownHover-t9O7DHoK.mjs → useCountdownHover-C3NXiAaF.mjs} +2 -2
  661. package/dist/{useCountdownHover-t9O7DHoK.mjs.map → useCountdownHover-C3NXiAaF.mjs.map} +1 -1
  662. package/dist/{useCountdownHover-8bwLWYoN.js → useCountdownHover-DbVhE-N0.js} +2 -2
  663. package/dist/{useCountdownHover-8bwLWYoN.js.map → useCountdownHover-DbVhE-N0.js.map} +1 -1
  664. package/dist/{useDateField-DmmXa0_5.mjs → useDateField-CJKgollJ.mjs} +3 -3
  665. package/dist/{useDateField-DmmXa0_5.mjs.map → useDateField-CJKgollJ.mjs.map} +1 -1
  666. package/dist/{useDateField-COTiu3aN.js → useDateField-DWv3600o.js} +3 -3
  667. package/dist/{useDateField-COTiu3aN.js.map → useDateField-DWv3600o.js.map} +1 -1
  668. package/dist/{useFormCheck-CJvIDxcO.mjs → useFormCheck-BKXrwS3g.mjs} +4 -4
  669. package/dist/useFormCheck-BKXrwS3g.mjs.map +1 -0
  670. package/dist/{useFormCheck-UHNy_iZ0.js → useFormCheck-DYjLG4WA.js} +4 -4
  671. package/dist/useFormCheck-DYjLG4WA.js.map +1 -0
  672. package/dist/{useFormInput-BgJCT9k_.mjs → useFormInput-CA4FYoV7.mjs} +4 -4
  673. package/dist/{useFormInput-BgJCT9k_.mjs.map → useFormInput-CA4FYoV7.mjs.map} +1 -1
  674. package/dist/{useFormInput-CsR38QR6.js → useFormInput-D31FCDxr.js} +4 -4
  675. package/dist/{useFormInput-CsR38QR6.js.map → useFormInput-D31FCDxr.js.map} +1 -1
  676. package/dist/{useFormSelect-D3gVO4jJ.mjs → useFormSelect-C0nvno12.mjs} +1 -1
  677. package/dist/{useFormSelect-D3gVO4jJ.mjs.map → useFormSelect-C0nvno12.mjs.map} +1 -1
  678. package/dist/{useFormSelect-CiIMUolC.js → useFormSelect-CjAziZpu.js} +1 -1
  679. package/dist/{useFormSelect-CiIMUolC.js.map → useFormSelect-CjAziZpu.js.map} +1 -1
  680. package/dist/{useForwardExpose-DrJOy0jY.js → useForwardExpose-BpZJluPs.js} +2 -2
  681. package/dist/{useForwardExpose-DrJOy0jY.js.map → useForwardExpose-BpZJluPs.js.map} +1 -1
  682. package/dist/{useForwardExpose-4OUimdPL.mjs → useForwardExpose-Cob6LlGd.mjs} +2 -2
  683. package/dist/{useForwardExpose-4OUimdPL.mjs.map → useForwardExpose-Cob6LlGd.mjs.map} +1 -1
  684. package/dist/{useKbd-IZRktImL.mjs → useKbd-DfmgFov6.mjs} +1 -1
  685. package/dist/{useKbd-IZRktImL.mjs.map → useKbd-DfmgFov6.mjs.map} +1 -1
  686. package/dist/{useKbd-ZZushx7D.js → useKbd-sqDCJtXL.js} +1 -1
  687. package/dist/{useKbd-ZZushx7D.js.map → useKbd-sqDCJtXL.js.map} +1 -1
  688. package/dist/{useNumberishToStyle-DFf9fokb.js → useNumberishToStyle-BtMa0R27.js} +2 -2
  689. package/dist/{useNumberishToStyle-DFf9fokb.js.map → useNumberishToStyle-BtMa0R27.js.map} +1 -1
  690. package/dist/{useNumberishToStyle-DEqGK1UH.mjs → useNumberishToStyle-DgS1slD3.mjs} +2 -2
  691. package/dist/{useNumberishToStyle-DEqGK1UH.mjs.map → useNumberishToStyle-DgS1slD3.mjs.map} +1 -1
  692. package/dist/{useRadiusElementClasses-BlrN-T6U.mjs → useRadiusElementClasses-BW832F7F.mjs} +1 -1
  693. package/dist/{useRadiusElementClasses-BlrN-T6U.mjs.map → useRadiusElementClasses-BW832F7F.mjs.map} +1 -1
  694. package/dist/{useRadiusElementClasses-C13_PhPM.js → useRadiusElementClasses-DWiUVgex.js} +1 -1
  695. package/dist/{useRadiusElementClasses-C13_PhPM.js.map → useRadiusElementClasses-DWiUVgex.js.map} +1 -1
  696. package/dist/{useRtl-DXAooTrl.js → useRtl-DDPRnA7g.js} +1 -1
  697. package/dist/{useRtl-DXAooTrl.js.map → useRtl-DDPRnA7g.js.map} +1 -1
  698. package/dist/{useRtl-DpwU_RM8.mjs → useRtl-VR3M2Txg.mjs} +1 -1
  699. package/dist/{useRtl-DpwU_RM8.mjs.map → useRtl-VR3M2Txg.mjs.map} +1 -1
  700. package/dist/{useSafeScrollLock-Bm9RxDoY.js → useSafeScrollLock-7wmPH_Hy.js} +2 -2
  701. package/dist/{useSafeScrollLock-Bm9RxDoY.js.map → useSafeScrollLock-7wmPH_Hy.js.map} +1 -1
  702. package/dist/{useSafeScrollLock-D62o8jto.mjs → useSafeScrollLock-Me5LyqjD.mjs} +2 -2
  703. package/dist/{useSafeScrollLock-D62o8jto.mjs.map → useSafeScrollLock-Me5LyqjD.mjs.map} +1 -1
  704. package/dist/{useShowHide-BTCaeU5j.js → useShowHide-BhdrR1wG.js} +2 -2
  705. package/dist/{useShowHide-BTCaeU5j.js.map → useShowHide-BhdrR1wG.js.map} +1 -1
  706. package/dist/{useShowHide-yAK5dhPT.mjs → useShowHide-DKdljnpv.mjs} +2 -2
  707. package/dist/{useShowHide-yAK5dhPT.mjs.map → useShowHide-DKdljnpv.mjs.map} +1 -1
  708. package/dist/{useStateClass-CJ24hpkn.js → useStateClass-CXK3nCg9.js} +1 -1
  709. package/dist/{useStateClass-CJ24hpkn.js.map → useStateClass-CXK3nCg9.js.map} +1 -1
  710. package/dist/{useStateClass-CdmlbrGn.mjs → useStateClass-DxlL_m2E.mjs} +1 -1
  711. package/dist/{useStateClass-CdmlbrGn.mjs.map → useStateClass-DxlL_m2E.mjs.map} +1 -1
  712. package/dist/utils/floatingUi.d.mts +1 -0
  713. package/dist/utils/floatingUi.d.ts +1 -0
  714. package/dist/utils/keys.d.mts +2 -2
  715. package/dist/utils/keys.d.ts +2 -2
  716. package/dist/{utils-CaC78Zdk.js → utils-BTPjS0XS.js} +3 -4
  717. package/dist/utils-BTPjS0XS.js.map +1 -0
  718. package/dist/{utils-CgwCsk6U.mjs → utils-Dgz9Trtl.mjs} +3 -4
  719. package/dist/utils-Dgz9Trtl.mjs.map +1 -0
  720. package/package.json +1 -1
  721. package/src/components/BAutocomplete/_autocomplete.scss +69 -1
  722. package/dist/BAlert-BnT7fF6B.js.map +0 -1
  723. package/dist/BAlert-Qiyqq4rE.mjs.map +0 -1
  724. package/dist/BApp-DJWC2mB8.mjs.map +0 -1
  725. package/dist/BApp-DaM0UKIg.js.map +0 -1
  726. package/dist/BAvatar-D7aFEXLH.mjs.map +0 -1
  727. package/dist/BAvatar-lefHkDuG.js.map +0 -1
  728. package/dist/BBadge-BBUcrujj.js.map +0 -1
  729. package/dist/BBadge-D5ra3W5R.mjs.map +0 -1
  730. package/dist/BBreadcrumb-BSsiwCNB.js.map +0 -1
  731. package/dist/BBreadcrumb-amkzWyz6.mjs.map +0 -1
  732. package/dist/BButton-BRvIFnRm.mjs.map +0 -1
  733. package/dist/BButton-DBRs8Pz_.js.map +0 -1
  734. package/dist/BButton-DNmtqoqR.mjs.map +0 -1
  735. package/dist/BButton-kykTWnBy.js.map +0 -1
  736. package/dist/BCard-C1G8PO5k.mjs.map +0 -1
  737. package/dist/BCard-CJ822HyH.mjs.map +0 -1
  738. package/dist/BCard-CSyEHz8Z.js.map +0 -1
  739. package/dist/BCard-CgbTFn3S.js.map +0 -1
  740. package/dist/BCloseButton-CN__Jjcj.js.map +0 -1
  741. package/dist/BCloseButton-CjgbR1Ec.mjs.map +0 -1
  742. package/dist/BCol-0tZmpOme.js.map +0 -1
  743. package/dist/BCol-C4v-TOX6.mjs.map +0 -1
  744. package/dist/BCollapse-D-xTGkX_.mjs.map +0 -1
  745. package/dist/BCollapse-DZ1z2c8U.js.map +0 -1
  746. package/dist/BContainer-BZUI2qQv.js.map +0 -1
  747. package/dist/BContainer-DjIGH6-y.mjs.map +0 -1
  748. package/dist/BDateField-BJIq6gs9.mjs.map +0 -1
  749. package/dist/BDateField-RWwEMIwd.js.map +0 -1
  750. package/dist/BDropdown-BW_O8vPQ.mjs.map +0 -1
  751. package/dist/BDropdown-C1AxRj81.js.map +0 -1
  752. package/dist/BDropdown-CuVOxCzu.js.map +0 -1
  753. package/dist/BDropdown-DAHnN54Z.mjs.map +0 -1
  754. package/dist/BForm-Bp7SFxiK.js.map +0 -1
  755. package/dist/BForm-C8I6v7bU.mjs.map +0 -1
  756. package/dist/BForm-Oh6PpdcD.mjs.map +0 -1
  757. package/dist/BForm-_h0kYDl7.js.map +0 -1
  758. package/dist/BFormCheckbox-Bdk2rgVe.js.map +0 -1
  759. package/dist/BFormCheckbox-CcDK-lh1.mjs.map +0 -1
  760. package/dist/BFormGroup--38dFj0X.mjs +0 -381
  761. package/dist/BFormGroup--38dFj0X.mjs.map +0 -1
  762. package/dist/BFormGroup-BwO1BZD1.js +0 -387
  763. package/dist/BFormGroup-BwO1BZD1.js.map +0 -1
  764. package/dist/BFormInput-BuRSGYdY.js.map +0 -1
  765. package/dist/BFormInput-Dg9dbwHp.mjs.map +0 -1
  766. package/dist/BFormRadio-CRDbgMiR.mjs.map +0 -1
  767. package/dist/BFormRadio-DuVYw-Vs.js.map +0 -1
  768. package/dist/BFormRating-Bb_ACp-9.mjs.map +0 -1
  769. package/dist/BFormRating-CNqf91vN.js.map +0 -1
  770. package/dist/BFormSelect-Bb8yE8vz.mjs.map +0 -1
  771. package/dist/BFormSelect-DIKVsG--.js.map +0 -1
  772. package/dist/BFormSelectOption-BY4P8HOf.js.map +0 -1
  773. package/dist/BFormSelectOption-O8cyyv3i.mjs.map +0 -1
  774. package/dist/BFormTag-BUWEugEC.mjs.map +0 -1
  775. package/dist/BFormTag-C7B-bX72.js.map +0 -1
  776. package/dist/BFormTags-BFA6xbr3.js.map +0 -1
  777. package/dist/BFormTags-CJb4H67g.mjs.map +0 -1
  778. package/dist/BFormTextarea-8c3B3kAI.js.map +0 -1
  779. package/dist/BFormTextarea-BMk05ojJ.mjs.map +0 -1
  780. package/dist/BFormValidFeedback-DvTgwqSe.js.map +0 -1
  781. package/dist/BFormValidFeedback-_Dgzm0Ag.mjs.map +0 -1
  782. package/dist/BImg-BQqZfIM9.mjs.map +0 -1
  783. package/dist/BImg-Dyy0N-WQ.js.map +0 -1
  784. package/dist/BInputGroup-BScMw6Zr.js.map +0 -1
  785. package/dist/BInputGroup-C7k0tS9j.mjs.map +0 -1
  786. package/dist/BInputGroup-DpX10xwR.mjs.map +0 -1
  787. package/dist/BInputGroup-Duk6Jk0v.js.map +0 -1
  788. package/dist/BListGroup-BmtN0xQ3.mjs.map +0 -1
  789. package/dist/BListGroup-DuyMdAxJ.js.map +0 -1
  790. package/dist/BModal-Br5xLT0-.mjs.map +0 -1
  791. package/dist/BModal-D0LB339D.js.map +0 -1
  792. package/dist/BNav-BRjdHsjC.mjs.map +0 -1
  793. package/dist/BNav-tYBwz1wU.js.map +0 -1
  794. package/dist/BNavbar-s9Ak5PnO.js.map +0 -1
  795. package/dist/BNavbar-vN3_CMLn.mjs.map +0 -1
  796. package/dist/BOffcanvas-D33pEfZe.js.map +0 -1
  797. package/dist/BOffcanvas-jETHbtC3.mjs.map +0 -1
  798. package/dist/BOverlay-B7vJAdHO.js.map +0 -1
  799. package/dist/BOverlay-BGxH9JVy.mjs.map +0 -1
  800. package/dist/BPagination-C0-4NVzW.js.map +0 -1
  801. package/dist/BPagination-CvoSN1He.mjs.map +0 -1
  802. package/dist/BPlaceholder-C4AOg29f.mjs.map +0 -1
  803. package/dist/BPlaceholder-DYYYuNgR.js.map +0 -1
  804. package/dist/BProgress-BIqo6vLh.mjs.map +0 -1
  805. package/dist/BProgress-Bc3ZSkac.js.map +0 -1
  806. package/dist/BRow-BCEK3fe6.mjs.map +0 -1
  807. package/dist/BRow-tqMEhkZS.js.map +0 -1
  808. package/dist/BSpinner-8UMAINYb.js.map +0 -1
  809. package/dist/BSpinner-BpnwONvx.mjs.map +0 -1
  810. package/dist/BTable-Btzu1IJ_.js.map +0 -1
  811. package/dist/BTable-CjHMx8Yv.mjs.map +0 -1
  812. package/dist/BTableSimple-BcdizuDm.js.map +0 -1
  813. package/dist/BTableSimple-C901Z5V9.mjs.map +0 -1
  814. package/dist/BTabs-DZEF9kgT.mjs.map +0 -1
  815. package/dist/BTabs-DiYaJi22.js.map +0 -1
  816. package/dist/BToast-B2rFKhLD.mjs.map +0 -1
  817. package/dist/BToast-DCSZYXIi.js.map +0 -1
  818. package/dist/BTooltip-CryTO-SM.js.map +0 -1
  819. package/dist/BTooltip-DtpjIEBu.mjs.map +0 -1
  820. package/dist/ConditionalTeleport-BJZk6HAx.js.map +0 -1
  821. package/dist/ConditionalTeleport-BNsziElf.mjs.map +0 -1
  822. package/dist/dist-B10a-gZ8.mjs.map +0 -1
  823. package/dist/floatingUi-Cs4rDXmO.js.map +0 -1
  824. package/dist/floatingUi-DHMrP__c.mjs.map +0 -1
  825. package/dist/useFormCheck-CJvIDxcO.mjs.map +0 -1
  826. package/dist/useFormCheck-UHNy_iZ0.js.map +0 -1
  827. package/dist/utils-CaC78Zdk.js.map +0 -1
  828. package/dist/utils-CgwCsk6U.mjs.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"floatingUi-Cs4rDXmO.js","names":[],"sources":["../src/composables/useMouse.ts","../src/components/BPopover/BPopover.vue","../src/components/BPopover/BPopover.vue","../src/utils/floatingUi.ts"],"sourcesContent":["import {useMouse as _useMouse, createSharedComposable} from '@vueuse/core'\n\nexport const useMouse = createSharedComposable(_useMouse)\n","<template>\n <span :id=\"computedId + '_placeholder'\" ref=\"_placeholder\" style=\"display: none\" />\n <slot name=\"target\" v-bind=\"sharedSlots\" />\n <ConditionalTeleport\n :to=\"props.teleportTo\"\n :disabled=\"!props.teleportTo || props.teleportDisabled\"\n >\n <Transition\n v-if=\"renderRef || contentShowing\"\n v-bind=\"transitionProps\"\n :appear=\"modelValue || props.visible\"\n >\n <div\n v-show=\"showRef && !hidden\"\n :id=\"computedId\"\n v-bind=\"attrs\"\n ref=\"_element\"\n :class=\"computedClasses\"\n role=\"tooltip\"\n tabindex=\"-1\"\n :style=\"floatingStyles\"\n >\n <div\n ref=\"_arrow\"\n :class=\"`${props.tooltip ? 'tooltip' : 'popover'}-arrow`\"\n :style=\"arrowStyle\"\n data-popper-arrow\n />\n <div ref=\"_content\" class=\"overflow-auto b-floating-size\" :style=\"sizeStyles\">\n <template v-if=\"props.title || slots.title\">\n <div\n class=\"position-sticky top-0\"\n :class=\"[props.tooltip ? 'tooltip-inner' : 'popover-header', props.titleClass]\"\n >\n <slot name=\"title\" v-bind=\"sharedSlots\">\n {{ props.title }}\n </slot>\n </div>\n </template>\n <template v-if=\"(props.tooltip && !slots.title && !props.title) || !props.tooltip\">\n <div :class=\"[props.tooltip ? 'tooltip-inner' : 'popover-body', props.bodyClass]\">\n <slot v-bind=\"sharedSlots\">{{ props.body }}{{ attrs.content }}</slot>\n </div>\n </template>\n </div>\n </div>\n </Transition>\n </ConditionalTeleport>\n</template>\n\n<script setup lang=\"ts\">\nimport {\n type Alignment,\n arrow as arrowMiddleware,\n autoPlacement,\n autoUpdate,\n type Boundary,\n flip,\n type Placement as FloatingPlacement,\n hide as hideMiddleware,\n inline as inlineMiddleware,\n type Middleware,\n offset as offsetMiddleware,\n type ReferenceElement,\n type RootBoundary,\n shift,\n size as sizeMiddleware,\n useFloating,\n} from '@floating-ui/vue'\nimport {onClickOutside, useToNumber} from '@vueuse/core'\nimport {\n computed,\n type ComputedRef,\n type CSSProperties,\n type EmitFn,\n nextTick,\n onBeforeUnmount,\n onMounted,\n ref,\n toRef,\n toValue,\n useAttrs,\n useTemplateRef,\n watch,\n} from 'vue'\nimport {useDefaults} from '../../composables/useDefaults'\nimport {useMouse} from '../../composables/useMouse'\nimport {useId} from '../../composables/useId'\nimport type {BPopoverSlots, ShowHideSlotsData, BPopoverProps, BPopoverEmits} from '../../types'\nimport {isBoundary, isRootBoundary, resolveBootstrapPlacement} from '../../utils/floatingUi'\nimport {getElement} from '../../utils/getElement'\nimport ConditionalTeleport from '../ConditionalTeleport.vue'\nimport {useShowHide} from '../../composables/useShowHide'\nimport {getSafeDocument, getSafeWindow} from '../../utils/dom'\n\ndefineOptions({\n inheritAttrs: false,\n})\n\nconst _props = withDefaults(defineProps<Omit<BPopoverProps, 'modelValue'>>(), {\n boundary: 'clippingAncestors',\n boundaryPadding: undefined,\n bodyClass: undefined,\n click: undefined,\n closeOnHide: false,\n focus: undefined,\n hover: undefined,\n teleportTo: undefined,\n teleportDisabled: false,\n body: undefined,\n delay: () => ({show: 100, hide: 300}),\n floatingMiddleware: undefined,\n hideMargin: 2,\n id: undefined,\n initialAnimation: false,\n inline: false,\n lazy: false,\n manual: false,\n noAutoClose: false,\n noFade: false,\n noFlip: false,\n noHide: false,\n noShift: false,\n noSize: false,\n noninteractive: false,\n offset: null,\n unmountLazy: false,\n placement: 'top',\n realtime: false,\n reference: null,\n strategy: 'absolute',\n target: null,\n title: undefined,\n titleClass: undefined,\n show: false,\n tooltip: false,\n visible: false,\n})\nconst props = useDefaults(_props, 'BPopover')\nconst emit = defineEmits<BPopoverEmits>()\nconst slots = defineSlots<BPopoverSlots>()\nconst attrs = useAttrs()\n\nconst modelValue = defineModel<Exclude<BPopoverProps['modelValue'], undefined>>({\n default: false,\n})\n\nconst computedId = useId(() => props.id, 'popover')\n\nconst hidden = ref(false)\n\nconst floatingElement = useTemplateRef('_element')\nconst content = useTemplateRef('_content')\nconst arrow = useTemplateRef('_arrow')\nconst placeholder = useTemplateRef('_placeholder')\n\nconst referenceElement = ref<HTMLElement | null>(null)\nconst triggerElement = ref<HTMLElement | null>(null)\n\nconst isAutoPlacement = computed(() => props.placement.startsWith('auto'))\nconst offsetNumber = useToNumber(() => props.offset ?? Number.NaN)\n\nconst boundary = computed<Boundary | undefined>(() =>\n isBoundary(props.boundary) ? props.boundary : undefined\n)\nconst rootBoundary = computed<RootBoundary | undefined>(() =>\n isRootBoundary(props.boundary) ? props.boundary : undefined\n)\n\nconst sizeStyles = ref<CSSProperties>({})\nconst floatingMiddleware = computed<readonly Middleware[]>(() => {\n if (props.floatingMiddleware !== undefined) {\n return props.floatingMiddleware\n }\n const off = props.offset !== null ? offsetNumber.value : props.tooltip ? 6 : 8\n const arr: Middleware[] = [offsetMiddleware(off)]\n if (props.noFlip === false && !isAutoPlacement.value) {\n arr.push(\n flip({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (isAutoPlacement.value) {\n arr.push(\n autoPlacement({\n alignment: (props.placement.split('-')[1] as Alignment) || undefined,\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.noShift === false) {\n arr.push(\n shift({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.noHide === false) {\n arr.push(\n hideMiddleware({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.inline === true) {\n arr.push(inlineMiddleware())\n }\n arr.push(arrowMiddleware({element: arrow, padding: 10}))\n if (props.noSize === false) {\n arr.push(\n sizeMiddleware({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n apply({availableWidth, availableHeight}) {\n sizeStyles.value = {\n '--bv-floating-max-height':\n availableHeight >= (content.value?.scrollHeight ?? 0)\n ? undefined\n : availableHeight\n ? `${Math.max(0, availableHeight)}px`\n : undefined,\n '--bv-floating-max-width':\n availableWidth >= (content.value?.scrollWidth ?? 0)\n ? undefined\n : availableWidth\n ? `${Math.max(0, availableWidth)}px`\n : undefined,\n }\n },\n })\n )\n }\n return arr\n})\n\nconst placementRef = computed(() =>\n isAutoPlacement.value ? undefined : (props.placement as FloatingPlacement)\n)\n\nconst {floatingStyles, middlewareData, placement, update} = useFloating(\n referenceElement,\n floatingElement,\n {\n placement: placementRef,\n middleware: floatingMiddleware as ComputedRef<Middleware[]>,\n strategy: toRef(() => props.strategy),\n }\n)\n\nconst arrowStyle = ref<CSSProperties>({position: 'absolute'})\n\nlet cleanup: ReturnType<typeof autoUpdate> | undefined\nconst {\n showRef,\n hide,\n show,\n toggle,\n throttleHide,\n computedNoAnimation,\n transitionProps,\n contentShowing,\n isVisible,\n isActive,\n renderRef,\n localTemporaryHide,\n setLocalTemporaryHide,\n} = useShowHide(modelValue, props, emit as EmitFn, floatingElement, computedId, {\n showFn: () => {\n update()\n nextTick(() => {\n cleanup = autoUpdate(\n referenceElement.value as ReferenceElement,\n floatingElement.value as HTMLElement,\n update,\n {animationFrame: props.realtime}\n )\n })\n },\n hideFn: () => {\n if (cleanup) {\n cleanup()\n cleanup = undefined\n }\n },\n})\n\nwatch(middlewareData, (newValue) => {\n if (props.noHide === false) {\n if (newValue.hide?.referenceHidden && !hidden.value && showRef.value) {\n if (props.closeOnHide && !props.noAutoClose && !props.manual) {\n throttleHide('close-on-hide')\n } else {\n setLocalTemporaryHide(true)\n hidden.value = true\n }\n } else if (localTemporaryHide.value && !newValue.hide?.referenceHidden) {\n setLocalTemporaryHide(false)\n hidden.value = false\n }\n }\n if (newValue.arrow) {\n const {x, y} = newValue.arrow\n arrowStyle.value = {\n position: 'absolute',\n top: y ? `${y}px` : '',\n left: x ? `${x}px` : '',\n }\n }\n})\n\nconst computedClasses = computed(() => {\n const type = props.tooltip ? 'tooltip' : 'popover'\n return [\n type,\n `b-${type}`,\n {\n show: isVisible.value && !hidden.value,\n fade: !computedNoAnimation.value,\n [`bs-${type}-${resolveBootstrapPlacement(placement.value)}`]: placement.value !== undefined,\n },\n ]\n})\n\nconst {x, y} = useMouse()\n\nconst isElementAndTriggerOutside = () => {\n const triggerRect = triggerElement.value?.getBoundingClientRect()\n const elementRect = floatingElement.value?.getBoundingClientRect()\n const margin = Number.parseInt(props.hideMargin as unknown as string, 10) || 0\n const offsetX = getSafeWindow()?.scrollX || 0\n const offsetY = getSafeWindow()?.scrollY || 0\n const triggerIsOutside =\n !triggerRect ||\n x.value < triggerRect.left + offsetX - margin ||\n x.value > triggerRect.right + offsetX + margin ||\n y.value < triggerRect.top + offsetY - margin ||\n y.value > triggerRect.bottom + offsetY + margin\n\n const isOutside =\n !elementRect ||\n x.value < elementRect.left + offsetX - margin ||\n x.value > elementRect.right + offsetX + margin ||\n y.value < elementRect.top + offsetY - margin ||\n y.value > elementRect.bottom + offsetY + margin\n\n return {triggerIsOutside, isOutside}\n}\n\nlet looptimeout: ReturnType<typeof setTimeout> | undefined\nconst tryHide = (e?: Readonly<Event>) => {\n const {triggerIsOutside, isOutside} = isElementAndTriggerOutside()\n const doc = getSafeDocument()\n if (\n (!props.noninteractive &&\n isOutside &&\n triggerIsOutside &&\n doc &&\n !floatingElement.value?.contains(doc.activeElement) &&\n (!computedTriggers.value.focus || !triggerElement.value?.contains(doc.activeElement))) ||\n (props.noninteractive && triggerIsOutside)\n ) {\n hide(e?.type)\n } else {\n if (looptimeout) clearTimeout(looptimeout)\n looptimeout = setTimeout(() => {\n tryHide(e)\n }, 50)\n }\n}\n\nwatch(isVisible, () => {\n update()\n})\n\ndefineExpose({\n hide,\n show,\n toggle,\n})\n\nconst localToggle = (e: Event) => {\n if (showRef.value) {\n hide(e.type === 'click' ? 'click' : 'toggle')\n } else {\n show()\n }\n}\n\nconst localShow = () => {\n show()\n}\n\n// Compute final trigger configuration\nconst computedTriggers = computed(() => {\n // Manual mode disables all automatic triggers\n if (props.manual) {\n return {hover: false, focus: false, click: false}\n }\n\n // If explicit boolean props are set, use them\n if (props.hover !== undefined || props.focus !== undefined || props.click !== undefined) {\n return {\n hover: props.hover ?? false,\n focus: props.focus ?? false,\n click: props.click ?? false,\n }\n }\n\n // If no explicit props, use default behavior: hover + focus\n return {hover: true, focus: true, click: false}\n})\n\nconst bind = () => {\n // TODO: is this the best way to bind the events?\n // we place a span and get the next element sibling for the listeners\n if (props.target) {\n const elem = getElement(toValue(props.target))\n if (elem) {\n triggerElement.value = elem\n } else {\n console.warn('Target element not found', props.target)\n }\n } else {\n triggerElement.value = placeholder.value?.nextElementSibling as HTMLElement\n }\n if (props.reference) {\n const elem = getElement(toValue(props.reference))\n if (elem) {\n referenceElement.value = elem\n } else {\n console.warn('Reference element not found', props.reference)\n }\n } else {\n referenceElement.value = triggerElement.value\n }\n if (!triggerElement.value || props.manual) {\n return\n }\n\n const triggers = computedTriggers.value\n\n if (triggers.click) {\n triggerElement.value.addEventListener('click', localToggle)\n }\n\n if (triggers.hover) {\n triggerElement.value.addEventListener('pointerenter', localShow)\n triggerElement.value.addEventListener('pointerleave', tryHide)\n }\n\n if (triggers.focus) {\n triggerElement.value.addEventListener('focus', localShow)\n triggerElement.value.addEventListener('blur', tryHide)\n }\n}\n\nconst unbind = () => {\n if (triggerElement.value) {\n triggerElement.value.removeEventListener('click', localToggle)\n triggerElement.value.removeEventListener('pointerenter', localShow)\n triggerElement.value.removeEventListener('pointerleave', tryHide)\n triggerElement.value.removeEventListener('focus', localShow)\n triggerElement.value.removeEventListener('blur', tryHide)\n }\n}\n\nonClickOutside(\n floatingElement,\n () => {\n if (showRef.value && computedTriggers.value.click && !props.noAutoClose && !props.manual)\n hide('click-outside')\n },\n {ignore: [triggerElement]}\n)\n\nwatch(\n [\n () => props.click,\n () => props.hover,\n () => props.focus,\n () => props.manual,\n () => props.target,\n () => props.reference,\n ],\n () => {\n unbind()\n bind()\n // update()\n }\n)\n\nconst sharedSlots = computed<ShowHideSlotsData>(() => ({\n toggle,\n show,\n hide,\n id: computedId.value,\n visible: isVisible.value,\n active: isActive.value,\n}))\n\nonMounted(() => {\n bind()\n nextTick(() => {\n update()\n })\n})\n\nonBeforeUnmount(unbind)\n</script>\n","<template>\n <span :id=\"computedId + '_placeholder'\" ref=\"_placeholder\" style=\"display: none\" />\n <slot name=\"target\" v-bind=\"sharedSlots\" />\n <ConditionalTeleport\n :to=\"props.teleportTo\"\n :disabled=\"!props.teleportTo || props.teleportDisabled\"\n >\n <Transition\n v-if=\"renderRef || contentShowing\"\n v-bind=\"transitionProps\"\n :appear=\"modelValue || props.visible\"\n >\n <div\n v-show=\"showRef && !hidden\"\n :id=\"computedId\"\n v-bind=\"attrs\"\n ref=\"_element\"\n :class=\"computedClasses\"\n role=\"tooltip\"\n tabindex=\"-1\"\n :style=\"floatingStyles\"\n >\n <div\n ref=\"_arrow\"\n :class=\"`${props.tooltip ? 'tooltip' : 'popover'}-arrow`\"\n :style=\"arrowStyle\"\n data-popper-arrow\n />\n <div ref=\"_content\" class=\"overflow-auto b-floating-size\" :style=\"sizeStyles\">\n <template v-if=\"props.title || slots.title\">\n <div\n class=\"position-sticky top-0\"\n :class=\"[props.tooltip ? 'tooltip-inner' : 'popover-header', props.titleClass]\"\n >\n <slot name=\"title\" v-bind=\"sharedSlots\">\n {{ props.title }}\n </slot>\n </div>\n </template>\n <template v-if=\"(props.tooltip && !slots.title && !props.title) || !props.tooltip\">\n <div :class=\"[props.tooltip ? 'tooltip-inner' : 'popover-body', props.bodyClass]\">\n <slot v-bind=\"sharedSlots\">{{ props.body }}{{ attrs.content }}</slot>\n </div>\n </template>\n </div>\n </div>\n </Transition>\n </ConditionalTeleport>\n</template>\n\n<script setup lang=\"ts\">\nimport {\n type Alignment,\n arrow as arrowMiddleware,\n autoPlacement,\n autoUpdate,\n type Boundary,\n flip,\n type Placement as FloatingPlacement,\n hide as hideMiddleware,\n inline as inlineMiddleware,\n type Middleware,\n offset as offsetMiddleware,\n type ReferenceElement,\n type RootBoundary,\n shift,\n size as sizeMiddleware,\n useFloating,\n} from '@floating-ui/vue'\nimport {onClickOutside, useToNumber} from '@vueuse/core'\nimport {\n computed,\n type ComputedRef,\n type CSSProperties,\n type EmitFn,\n nextTick,\n onBeforeUnmount,\n onMounted,\n ref,\n toRef,\n toValue,\n useAttrs,\n useTemplateRef,\n watch,\n} from 'vue'\nimport {useDefaults} from '../../composables/useDefaults'\nimport {useMouse} from '../../composables/useMouse'\nimport {useId} from '../../composables/useId'\nimport type {BPopoverSlots, ShowHideSlotsData, BPopoverProps, BPopoverEmits} from '../../types'\nimport {isBoundary, isRootBoundary, resolveBootstrapPlacement} from '../../utils/floatingUi'\nimport {getElement} from '../../utils/getElement'\nimport ConditionalTeleport from '../ConditionalTeleport.vue'\nimport {useShowHide} from '../../composables/useShowHide'\nimport {getSafeDocument, getSafeWindow} from '../../utils/dom'\n\ndefineOptions({\n inheritAttrs: false,\n})\n\nconst _props = withDefaults(defineProps<Omit<BPopoverProps, 'modelValue'>>(), {\n boundary: 'clippingAncestors',\n boundaryPadding: undefined,\n bodyClass: undefined,\n click: undefined,\n closeOnHide: false,\n focus: undefined,\n hover: undefined,\n teleportTo: undefined,\n teleportDisabled: false,\n body: undefined,\n delay: () => ({show: 100, hide: 300}),\n floatingMiddleware: undefined,\n hideMargin: 2,\n id: undefined,\n initialAnimation: false,\n inline: false,\n lazy: false,\n manual: false,\n noAutoClose: false,\n noFade: false,\n noFlip: false,\n noHide: false,\n noShift: false,\n noSize: false,\n noninteractive: false,\n offset: null,\n unmountLazy: false,\n placement: 'top',\n realtime: false,\n reference: null,\n strategy: 'absolute',\n target: null,\n title: undefined,\n titleClass: undefined,\n show: false,\n tooltip: false,\n visible: false,\n})\nconst props = useDefaults(_props, 'BPopover')\nconst emit = defineEmits<BPopoverEmits>()\nconst slots = defineSlots<BPopoverSlots>()\nconst attrs = useAttrs()\n\nconst modelValue = defineModel<Exclude<BPopoverProps['modelValue'], undefined>>({\n default: false,\n})\n\nconst computedId = useId(() => props.id, 'popover')\n\nconst hidden = ref(false)\n\nconst floatingElement = useTemplateRef('_element')\nconst content = useTemplateRef('_content')\nconst arrow = useTemplateRef('_arrow')\nconst placeholder = useTemplateRef('_placeholder')\n\nconst referenceElement = ref<HTMLElement | null>(null)\nconst triggerElement = ref<HTMLElement | null>(null)\n\nconst isAutoPlacement = computed(() => props.placement.startsWith('auto'))\nconst offsetNumber = useToNumber(() => props.offset ?? Number.NaN)\n\nconst boundary = computed<Boundary | undefined>(() =>\n isBoundary(props.boundary) ? props.boundary : undefined\n)\nconst rootBoundary = computed<RootBoundary | undefined>(() =>\n isRootBoundary(props.boundary) ? props.boundary : undefined\n)\n\nconst sizeStyles = ref<CSSProperties>({})\nconst floatingMiddleware = computed<readonly Middleware[]>(() => {\n if (props.floatingMiddleware !== undefined) {\n return props.floatingMiddleware\n }\n const off = props.offset !== null ? offsetNumber.value : props.tooltip ? 6 : 8\n const arr: Middleware[] = [offsetMiddleware(off)]\n if (props.noFlip === false && !isAutoPlacement.value) {\n arr.push(\n flip({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (isAutoPlacement.value) {\n arr.push(\n autoPlacement({\n alignment: (props.placement.split('-')[1] as Alignment) || undefined,\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.noShift === false) {\n arr.push(\n shift({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.noHide === false) {\n arr.push(\n hideMiddleware({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.inline === true) {\n arr.push(inlineMiddleware())\n }\n arr.push(arrowMiddleware({element: arrow, padding: 10}))\n if (props.noSize === false) {\n arr.push(\n sizeMiddleware({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n apply({availableWidth, availableHeight}) {\n sizeStyles.value = {\n '--bv-floating-max-height':\n availableHeight >= (content.value?.scrollHeight ?? 0)\n ? undefined\n : availableHeight\n ? `${Math.max(0, availableHeight)}px`\n : undefined,\n '--bv-floating-max-width':\n availableWidth >= (content.value?.scrollWidth ?? 0)\n ? undefined\n : availableWidth\n ? `${Math.max(0, availableWidth)}px`\n : undefined,\n }\n },\n })\n )\n }\n return arr\n})\n\nconst placementRef = computed(() =>\n isAutoPlacement.value ? undefined : (props.placement as FloatingPlacement)\n)\n\nconst {floatingStyles, middlewareData, placement, update} = useFloating(\n referenceElement,\n floatingElement,\n {\n placement: placementRef,\n middleware: floatingMiddleware as ComputedRef<Middleware[]>,\n strategy: toRef(() => props.strategy),\n }\n)\n\nconst arrowStyle = ref<CSSProperties>({position: 'absolute'})\n\nlet cleanup: ReturnType<typeof autoUpdate> | undefined\nconst {\n showRef,\n hide,\n show,\n toggle,\n throttleHide,\n computedNoAnimation,\n transitionProps,\n contentShowing,\n isVisible,\n isActive,\n renderRef,\n localTemporaryHide,\n setLocalTemporaryHide,\n} = useShowHide(modelValue, props, emit as EmitFn, floatingElement, computedId, {\n showFn: () => {\n update()\n nextTick(() => {\n cleanup = autoUpdate(\n referenceElement.value as ReferenceElement,\n floatingElement.value as HTMLElement,\n update,\n {animationFrame: props.realtime}\n )\n })\n },\n hideFn: () => {\n if (cleanup) {\n cleanup()\n cleanup = undefined\n }\n },\n})\n\nwatch(middlewareData, (newValue) => {\n if (props.noHide === false) {\n if (newValue.hide?.referenceHidden && !hidden.value && showRef.value) {\n if (props.closeOnHide && !props.noAutoClose && !props.manual) {\n throttleHide('close-on-hide')\n } else {\n setLocalTemporaryHide(true)\n hidden.value = true\n }\n } else if (localTemporaryHide.value && !newValue.hide?.referenceHidden) {\n setLocalTemporaryHide(false)\n hidden.value = false\n }\n }\n if (newValue.arrow) {\n const {x, y} = newValue.arrow\n arrowStyle.value = {\n position: 'absolute',\n top: y ? `${y}px` : '',\n left: x ? `${x}px` : '',\n }\n }\n})\n\nconst computedClasses = computed(() => {\n const type = props.tooltip ? 'tooltip' : 'popover'\n return [\n type,\n `b-${type}`,\n {\n show: isVisible.value && !hidden.value,\n fade: !computedNoAnimation.value,\n [`bs-${type}-${resolveBootstrapPlacement(placement.value)}`]: placement.value !== undefined,\n },\n ]\n})\n\nconst {x, y} = useMouse()\n\nconst isElementAndTriggerOutside = () => {\n const triggerRect = triggerElement.value?.getBoundingClientRect()\n const elementRect = floatingElement.value?.getBoundingClientRect()\n const margin = Number.parseInt(props.hideMargin as unknown as string, 10) || 0\n const offsetX = getSafeWindow()?.scrollX || 0\n const offsetY = getSafeWindow()?.scrollY || 0\n const triggerIsOutside =\n !triggerRect ||\n x.value < triggerRect.left + offsetX - margin ||\n x.value > triggerRect.right + offsetX + margin ||\n y.value < triggerRect.top + offsetY - margin ||\n y.value > triggerRect.bottom + offsetY + margin\n\n const isOutside =\n !elementRect ||\n x.value < elementRect.left + offsetX - margin ||\n x.value > elementRect.right + offsetX + margin ||\n y.value < elementRect.top + offsetY - margin ||\n y.value > elementRect.bottom + offsetY + margin\n\n return {triggerIsOutside, isOutside}\n}\n\nlet looptimeout: ReturnType<typeof setTimeout> | undefined\nconst tryHide = (e?: Readonly<Event>) => {\n const {triggerIsOutside, isOutside} = isElementAndTriggerOutside()\n const doc = getSafeDocument()\n if (\n (!props.noninteractive &&\n isOutside &&\n triggerIsOutside &&\n doc &&\n !floatingElement.value?.contains(doc.activeElement) &&\n (!computedTriggers.value.focus || !triggerElement.value?.contains(doc.activeElement))) ||\n (props.noninteractive && triggerIsOutside)\n ) {\n hide(e?.type)\n } else {\n if (looptimeout) clearTimeout(looptimeout)\n looptimeout = setTimeout(() => {\n tryHide(e)\n }, 50)\n }\n}\n\nwatch(isVisible, () => {\n update()\n})\n\ndefineExpose({\n hide,\n show,\n toggle,\n})\n\nconst localToggle = (e: Event) => {\n if (showRef.value) {\n hide(e.type === 'click' ? 'click' : 'toggle')\n } else {\n show()\n }\n}\n\nconst localShow = () => {\n show()\n}\n\n// Compute final trigger configuration\nconst computedTriggers = computed(() => {\n // Manual mode disables all automatic triggers\n if (props.manual) {\n return {hover: false, focus: false, click: false}\n }\n\n // If explicit boolean props are set, use them\n if (props.hover !== undefined || props.focus !== undefined || props.click !== undefined) {\n return {\n hover: props.hover ?? false,\n focus: props.focus ?? false,\n click: props.click ?? false,\n }\n }\n\n // If no explicit props, use default behavior: hover + focus\n return {hover: true, focus: true, click: false}\n})\n\nconst bind = () => {\n // TODO: is this the best way to bind the events?\n // we place a span and get the next element sibling for the listeners\n if (props.target) {\n const elem = getElement(toValue(props.target))\n if (elem) {\n triggerElement.value = elem\n } else {\n console.warn('Target element not found', props.target)\n }\n } else {\n triggerElement.value = placeholder.value?.nextElementSibling as HTMLElement\n }\n if (props.reference) {\n const elem = getElement(toValue(props.reference))\n if (elem) {\n referenceElement.value = elem\n } else {\n console.warn('Reference element not found', props.reference)\n }\n } else {\n referenceElement.value = triggerElement.value\n }\n if (!triggerElement.value || props.manual) {\n return\n }\n\n const triggers = computedTriggers.value\n\n if (triggers.click) {\n triggerElement.value.addEventListener('click', localToggle)\n }\n\n if (triggers.hover) {\n triggerElement.value.addEventListener('pointerenter', localShow)\n triggerElement.value.addEventListener('pointerleave', tryHide)\n }\n\n if (triggers.focus) {\n triggerElement.value.addEventListener('focus', localShow)\n triggerElement.value.addEventListener('blur', tryHide)\n }\n}\n\nconst unbind = () => {\n if (triggerElement.value) {\n triggerElement.value.removeEventListener('click', localToggle)\n triggerElement.value.removeEventListener('pointerenter', localShow)\n triggerElement.value.removeEventListener('pointerleave', tryHide)\n triggerElement.value.removeEventListener('focus', localShow)\n triggerElement.value.removeEventListener('blur', tryHide)\n }\n}\n\nonClickOutside(\n floatingElement,\n () => {\n if (showRef.value && computedTriggers.value.click && !props.noAutoClose && !props.manual)\n hide('click-outside')\n },\n {ignore: [triggerElement]}\n)\n\nwatch(\n [\n () => props.click,\n () => props.hover,\n () => props.focus,\n () => props.manual,\n () => props.target,\n () => props.reference,\n ],\n () => {\n unbind()\n bind()\n // update()\n }\n)\n\nconst sharedSlots = computed<ShowHideSlotsData>(() => ({\n toggle,\n show,\n hide,\n id: computedId.value,\n visible: isVisible.value,\n active: isActive.value,\n}))\n\nonMounted(() => {\n bind()\n nextTick(() => {\n update()\n })\n})\n\nonBeforeUnmount(unbind)\n</script>\n","import type {Boundary, Placement, RootBoundary} from '@floating-ui/vue'\nexport {autoUpdate} from '@floating-ui/vue'\n\nimport {type DirectiveBinding, h, render} from 'vue'\nimport BPopover from '../components/BPopover/BPopover.vue'\nimport type {BPopoverProps} from '../types'\nimport {getSafeDocument} from './dom'\n\nexport const resolveBootstrapPlacement = (placement: Placement): string => {\n const [_placement] = placement.split('-')\n switch (_placement) {\n case 'left':\n return 'start'\n case 'right':\n return 'end'\n default:\n return _placement || 'start'\n }\n}\nexport const resolveBootstrapCaret = (placement: Placement): string => {\n const [_placement] = placement.split('-')\n switch (_placement) {\n case 'left':\n return 'start'\n case 'right':\n return 'end'\n case 'top':\n return 'up'\n case 'bottom':\n return 'down'\n default:\n return _placement || 'start'\n }\n}\n\nexport const resolveActiveStatus = (values: DirectiveBinding['value']): boolean =>\n typeof values !== 'object' || values.active !== false\n\nexport const resolveContent = (\n values: DirectiveBinding['value'],\n el: HTMLElement\n): {title?: string; body?: string} => {\n const isActive = resolveActiveStatus(values)\n if (!isActive) return {}\n\n const missingBindingValue =\n typeof values === 'undefined' ||\n (typeof values === 'object' && !values.title && !values.content && !values.body)\n\n // SSR guard: skip DOM attribute access on server\n const doc = getSafeDocument()\n if (doc !== null) {\n const titleAttr = el.getAttribute('title') || el.getAttribute('data-original-title')\n\n // Always remove title attribute to prevent native tooltip conflicts\n if (titleAttr) {\n el.removeAttribute('title')\n el.setAttribute('data-original-title', titleAttr)\n }\n\n if (missingBindingValue) {\n if (titleAttr) {\n return {\n body: titleAttr,\n }\n }\n return {}\n }\n\n // For string directive values, use title attribute as popover title\n if (typeof values === 'string') {\n return {\n title: titleAttr || undefined,\n body: values,\n }\n }\n } else {\n // SSR: if no binding value provided, return empty\n if (missingBindingValue) return {}\n }\n\n if (typeof values === 'string') {\n return {\n body: values,\n }\n }\n\n // TODO: deprication remove warning in 2025-07\n if (values?.content)\n console.warn('v-b-popover/v-b-tooltip: `content` is deprecated, use `body` instead')\n\n return {\n title: values?.title ? values?.title : undefined,\n body: values?.body ? values?.body : values?.content ? values?.content : undefined,\n }\n}\n\nexport const resolveDirectiveProps = (\n binding: Readonly<DirectiveBinding>,\n el: Readonly<HTMLElement>\n) => ({\n target: el,\n modelValue: binding.modifiers.show,\n inline: binding.modifiers.inline,\n click: binding.modifiers.click,\n hover: binding.modifiers.hover,\n focus: binding.modifiers.focus,\n manual: binding.modifiers.manual,\n realtime: binding.modifiers.realtime,\n lazy: binding.modifiers.lazy,\n placement: binding.modifiers.left\n ? 'left'\n : binding.modifiers.right\n ? 'right'\n : binding.modifiers.bottom\n ? 'bottom'\n : binding.modifiers.top\n ? 'top'\n : undefined,\n ...(typeof binding.value === 'object' ? binding.value : undefined),\n ...(binding.modifiers.interactive ? {noninteractive: false} : undefined),\n title: null,\n body: null,\n})\n\nexport interface ElementWithPopper extends HTMLElement {\n [key: string]: unknown\n $__element?: HTMLElement\n $__tooltip?: Record<\n number,\n {\n binding: string\n destroying: boolean\n }\n >\n $__popover?: Record<\n number,\n {\n binding: string\n destroying: boolean\n }\n >\n}\n\nexport const bind = (\n el: ElementWithPopper,\n binding: Readonly<DirectiveBinding>,\n props: BPopoverProps\n) => {\n const doc = getSafeDocument()\n // SSR guard: skip DOM manipulation on server\n if (doc === null) return\n\n const div = doc.createElement('span')\n if (binding.modifiers.body) doc.body.appendChild(div)\n else if (binding.modifiers.child) el.appendChild(div)\n else el.parentNode?.insertBefore(div, el.nextSibling)\n render(h(BPopover, props), div)\n el.$__element = div\n}\n\nexport const unbind = (el: ElementWithPopper) => {\n const div = el.$__element\n if (!div) return\n\n // Unmount Vue component immediately\n render(null, div)\n\n // SSR guard: skip DOM cleanup on server\n if (getSafeDocument() !== null) {\n delete el.$__element\n return\n }\n\n // Use microtask instead of setTimeout(0) for more predictable cleanup\n // and better performance\n queueMicrotask(() => {\n // Remove the element in next microtask\n // The directive's beforeUnmount will have already cleaned up UID-specific state\n div.remove()\n // Only delete the reference if it still points to the div we just unmounted\n // This prevents deleting a fresh reference if bind() was called again immediately\n if (el.$__element === div) {\n delete el.$__element\n }\n })\n}\n\nexport const isBoundary = (input: unknown): input is Boundary =>\n input === 'clippingAncestors' || input instanceof Element || Array.isArray(input)\n\nexport const isRootBoundary = (input: Boundary | RootBoundary): input is RootBoundary =>\n !isBoundary(input)\n"],"mappings":";;;;;;;;;;;AAEA,IAAa,WAAW,aAAA,uBAAuB,aAAA,SAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ECwIzD,MAAM,QAAQ,oBAAA,YAvCC,SAuCmB,WAAU;EAC5C,MAAM,OAAO;EACb,MAAM,SAAA,GAAA,IAAA,WAAQ;EACd,MAAM,SAAA,GAAA,IAAA,WAAiB;EAEvB,MAAM,cAAA,GAAA,IAAA,UAAyE,SAAA,aAE9E;EAED,MAAM,aAAa,cAAA,YAAY,MAAM,IAAI,UAAS;EAElD,MAAM,UAAA,GAAA,IAAA,KAAa,MAAK;EAExB,MAAM,mBAAA,GAAA,IAAA,gBAAiC,WAAU;EACjD,MAAM,WAAA,GAAA,IAAA,gBAAyB,WAAU;EACzC,MAAM,WAAA,GAAA,IAAA,gBAAuB,SAAQ;EACrC,MAAM,eAAA,GAAA,IAAA,gBAA6B,eAAc;EAEjD,MAAM,oBAAA,GAAA,IAAA,KAA2C,KAAI;EACrD,MAAM,kBAAA,GAAA,IAAA,KAAyC,KAAI;EAEnD,MAAM,mBAAA,GAAA,IAAA,gBAAiC,MAAM,UAAU,WAAW,OAAO,CAAA;EACzE,MAAM,eAAe,aAAA,kBAAkB,MAAM,UAAU,IAAU;EAEjE,MAAM,YAAA,GAAA,IAAA,gBACJ,WAAW,MAAM,SAAS,GAAG,MAAM,WAAW,KAAA,EAChD;EACA,MAAM,gBAAA,GAAA,IAAA,gBACJ,eAAe,MAAM,SAAS,GAAG,MAAM,WAAW,KAAA,EACpD;EAEA,MAAM,cAAA,GAAA,IAAA,KAAgC,EAAE,CAAA;EACxC,MAAM,sBAAA,GAAA,IAAA,gBAA2D;AAC/D,OAAI,MAAM,uBAAuB,KAAA,EAC/B,QAAO,MAAM;GAGf,MAAM,MAAoB,CAAC,wBAAA,OADf,MAAM,WAAW,OAAO,aAAa,QAAQ,MAAM,UAAU,IAAI,EAC7B,CAAA;AAChD,OAAI,MAAM,WAAW,SAAS,CAAC,gBAAgB,MAC7C,KAAI,KACF,wBAAA,KAAK;IACH,UAAU,SAAS;IACnB,cAAc,aAAa;IAC3B,SAAS,MAAM;IAChB,CAAA,CACH;AAEF,OAAI,gBAAgB,MAClB,KAAI,KACF,wBAAA,cAAc;IACZ,WAAY,MAAM,UAAU,MAAM,IAAI,CAAC,MAAoB,KAAA;IAC3D,UAAU,SAAS;IACnB,cAAc,aAAa;IAC3B,SAAS,MAAM;IAChB,CAAA,CACH;AAEF,OAAI,MAAM,YAAY,MACpB,KAAI,KACF,wBAAA,MAAM;IACJ,UAAU,SAAS;IACnB,cAAc,aAAa;IAC3B,SAAS,MAAM;IAChB,CAAA,CACH;AAEF,OAAI,MAAM,WAAW,MACnB,KAAI,KACF,wBAAA,KAAe;IACb,UAAU,SAAS;IACnB,cAAc,aAAa;IAC3B,SAAS,MAAM;IAChB,CAAA,CACH;AAEF,OAAI,MAAM,WAAW,KACnB,KAAI,KAAK,wBAAA,QAAkB,CAAA;AAE7B,OAAI,KAAK,wBAAA,MAAgB;IAAC,SAAS;IAAO,SAAS;IAAG,CAAC,CAAA;AACvD,OAAI,MAAM,WAAW,MACnB,KAAI,KACF,wBAAA,KAAe;IACb,UAAU,SAAS;IACnB,cAAc,aAAa;IAC3B,SAAS,MAAM;IACf,MAAM,EAAC,gBAAgB,mBAAkB;AACvC,gBAAW,QAAQ;MACjB,4BACE,oBAAoB,QAAQ,OAAO,gBAAgB,KAC/C,KAAA,IACA,kBACE,GAAG,KAAK,IAAI,GAAG,gBAAgB,CAAC,MAChC,KAAA;MACR,2BACE,mBAAmB,QAAQ,OAAO,eAAe,KAC7C,KAAA,IACA,iBACE,GAAG,KAAK,IAAI,GAAG,eAAe,CAAC,MAC/B,KAAA;MACV;;IAEH,CAAA,CACH;AAEF,UAAO;IACR;EAMD,MAAM,EAAC,gBAAgB,gBAAgB,WAAW,WAAU,wBAAA,YAC1D,kBACA,iBACA;GACE,YAAA,GAAA,IAAA,gBAPF,gBAAgB,QAAQ,KAAA,IAAa,MAAM,UAC7C;GAOI,YAAY;GACZ,WAAA,GAAA,IAAA,aAAsB,MAAM,SAAA;GAC9B,CACF;EAEA,MAAM,cAAA,GAAA,IAAA,KAAgC,EAAC,UAAU,YAAW,CAAA;EAE5D,IAAI;EACJ,MAAM,EACJ,SACA,MAAA,QACA,MACA,QACA,cACA,qBACA,iBACA,gBACA,WACA,UACA,WACA,oBACA,0BACE,oBAAA,YAAY,YAAY,OAAO,MAAgB,iBAAiB,YAAY;GAC9E,cAAc;AACZ,YAAO;AACP,KAAA,GAAA,IAAA,gBAAe;AACb,eAAU,wBAAA,WACR,iBAAiB,OACjB,gBAAgB,OAChB,QACA,EAAC,gBAAgB,MAAM,UAAQ,CACjC;MACD;;GAEH,cAAc;AACZ,QAAI,SAAS;AACX,cAAQ;AACR,eAAU,KAAA;;;GAGf,CAAA;AAED,GAAA,GAAA,IAAA,OAAM,iBAAiB,aAAa;AAClC,OAAI,MAAM,WAAW;QACf,SAAS,MAAM,mBAAmB,CAAC,OAAO,SAAS,QAAQ,MAC7D,KAAI,MAAM,eAAe,CAAC,MAAM,eAAe,CAAC,MAAM,OACpD,cAAa,gBAAe;SACvB;AACL,2BAAsB,KAAI;AAC1B,YAAO,QAAQ;;aAER,mBAAmB,SAAS,CAAC,SAAS,MAAM,iBAAiB;AACtE,2BAAsB,MAAK;AAC3B,YAAO,QAAQ;;;AAGnB,OAAI,SAAS,OAAO;IAClB,MAAM,EAAC,GAAG,MAAK,SAAS;AACxB,eAAW,QAAQ;KACjB,UAAU;KACV,KAAK,IAAI,GAAG,EAAE,MAAM;KACpB,MAAM,IAAI,GAAG,EAAE,MAAM;KACvB;;IAEH;EAED,MAAM,mBAAA,GAAA,IAAA,gBAAiC;GACrC,MAAM,OAAO,MAAM,UAAU,YAAY;AACzC,UAAO;IACL;IACA,KAAK;IACL;KACE,MAAM,UAAU,SAAS,CAAC,OAAO;KACjC,MAAM,CAAC,oBAAoB;MAC1B,MAAM,KAAK,GAAG,0BAA0B,UAAU,MAAM,KAAK,UAAU,UAAU,KAAA;;IAEtF;IACD;EAED,MAAM,EAAC,GAAG,MAAK,UAAS;EAExB,MAAM,mCAAmC;GACvC,MAAM,cAAc,eAAe,OAAO,uBAAsB;GAChE,MAAM,cAAc,gBAAgB,OAAO,uBAAsB;GACjE,MAAM,SAAS,OAAO,SAAS,MAAM,YAAiC,GAAG,IAAI;GAC7E,MAAM,UAAU,YAAA,eAAe,EAAE,WAAW;GAC5C,MAAM,UAAU,YAAA,eAAe,EAAE,WAAW;AAe5C,UAAO;IAAC,kBAbN,CAAC,eACD,EAAE,QAAQ,YAAY,OAAO,UAAU,UACvC,EAAE,QAAQ,YAAY,QAAQ,UAAU,UACxC,EAAE,QAAQ,YAAY,MAAM,UAAU,UACtC,EAAE,QAAQ,YAAY,SAAS,UAAU;IASjB,WANxB,CAAC,eACD,EAAE,QAAQ,YAAY,OAAO,UAAU,UACvC,EAAE,QAAQ,YAAY,QAAQ,UAAU,UACxC,EAAE,QAAQ,YAAY,MAAM,UAAU,UACtC,EAAE,QAAQ,YAAY,SAAS,UAAU;IAER;;EAGrC,IAAI;EACJ,MAAM,WAAW,MAAwB;GACvC,MAAM,EAAC,kBAAkB,cAAa,4BAA2B;GACjE,MAAM,MAAM,YAAA,iBAAgB;AAC5B,OACG,CAAC,MAAM,kBACN,aACA,oBACA,OACA,CAAC,gBAAgB,OAAO,SAAS,IAAI,cAAc,KAClD,CAAC,iBAAiB,MAAM,SAAS,CAAC,eAAe,OAAO,SAAS,IAAI,cAAc,KACrF,MAAM,kBAAkB,iBAEzB,QAAK,GAAG,KAAI;QACP;AACL,QAAI,YAAa,cAAa,YAAW;AACzC,kBAAc,iBAAiB;AAC7B,aAAQ,EAAC;OACR,GAAE;;;AAIT,GAAA,GAAA,IAAA,OAAM,iBAAiB;AACrB,WAAO;IACR;AAED,WAAa;GACX,MAAA;GACA;GACA;GACD,CAAA;EAED,MAAM,eAAe,MAAa;AAChC,OAAI,QAAQ,MACV,QAAK,EAAE,SAAS,UAAU,UAAU,SAAQ;OAE5C,OAAK;;EAIT,MAAM,kBAAkB;AACtB,SAAK;;EAIP,MAAM,oBAAA,GAAA,IAAA,gBAAkC;AAEtC,OAAI,MAAM,OACR,QAAO;IAAC,OAAO;IAAO,OAAO;IAAO,OAAO;IAAK;AAIlD,OAAI,MAAM,UAAU,KAAA,KAAa,MAAM,UAAU,KAAA,KAAa,MAAM,UAAU,KAAA,EAC5E,QAAO;IACL,OAAO,MAAM,SAAS;IACtB,OAAO,MAAM,SAAS;IACtB,OAAO,MAAM,SAAS;IACxB;AAIF,UAAO;IAAC,OAAO;IAAM,OAAO;IAAM,OAAO;IAAK;IAC/C;EAED,MAAM,aAAa;AAGjB,OAAI,MAAM,QAAQ;IAChB,MAAM,OAAO,mBAAA,YAAA,GAAA,IAAA,SAAmB,MAAM,OAAO,CAAA;AAC7C,QAAI,KACF,gBAAe,QAAQ;QAEvB,SAAQ,KAAK,4BAA4B,MAAM,OAAM;SAGvD,gBAAe,QAAQ,YAAY,OAAO;AAE5C,OAAI,MAAM,WAAW;IACnB,MAAM,OAAO,mBAAA,YAAA,GAAA,IAAA,SAAmB,MAAM,UAAU,CAAA;AAChD,QAAI,KACF,kBAAiB,QAAQ;QAEzB,SAAQ,KAAK,+BAA+B,MAAM,UAAS;SAG7D,kBAAiB,QAAQ,eAAe;AAE1C,OAAI,CAAC,eAAe,SAAS,MAAM,OACjC;GAGF,MAAM,WAAW,iBAAiB;AAElC,OAAI,SAAS,MACX,gBAAe,MAAM,iBAAiB,SAAS,YAAW;AAG5D,OAAI,SAAS,OAAO;AAClB,mBAAe,MAAM,iBAAiB,gBAAgB,UAAS;AAC/D,mBAAe,MAAM,iBAAiB,gBAAgB,QAAO;;AAG/D,OAAI,SAAS,OAAO;AAClB,mBAAe,MAAM,iBAAiB,SAAS,UAAS;AACxD,mBAAe,MAAM,iBAAiB,QAAQ,QAAO;;;EAIzD,MAAM,eAAe;AACnB,OAAI,eAAe,OAAO;AACxB,mBAAe,MAAM,oBAAoB,SAAS,YAAW;AAC7D,mBAAe,MAAM,oBAAoB,gBAAgB,UAAS;AAClE,mBAAe,MAAM,oBAAoB,gBAAgB,QAAO;AAChE,mBAAe,MAAM,oBAAoB,SAAS,UAAS;AAC3D,mBAAe,MAAM,oBAAoB,QAAQ,QAAO;;;AAI5D,eAAA,eACE,uBACM;AACJ,OAAI,QAAQ,SAAS,iBAAiB,MAAM,SAAS,CAAC,MAAM,eAAe,CAAC,MAAM,OAChF,QAAK,gBAAe;KAExB,EAAC,QAAQ,CAAC,eAAe,EAAA,CAC3B;AAEA,GAAA,GAAA,IAAA,OACE;SACQ,MAAM;SACN,MAAM;SACN,MAAM;SACN,MAAM;SACN,MAAM;SACN,MAAM;GACb,QACK;AACJ,WAAO;AACP,SAAK;IAGT;EAEA,MAAM,eAAA,GAAA,IAAA,iBAAiD;GACrD;GACA;GACA,MAAA;GACA,IAAI,WAAW;GACf,SAAS,UAAU;GACnB,QAAQ,SAAS;GAClB,EAAC;AAEF,GAAA,GAAA,IAAA,iBAAgB;AACd,SAAK;AACL,IAAA,GAAA,IAAA,gBAAe;AACb,YAAO;KACR;IACF;AAED,GAAA,GAAA,IAAA,iBAAgB,OAAM;;;gCApgB+D,QAAA;KAA5E,KAAA,GAAA,IAAA,OAAI,WAAU,GAAA;KAAmB,KAAI;KAAe,OAAA,EAAA,WAAA,QAAA;;wBAChB,KAAA,QAAA,WAAA,GAAA,IAAA,iBAAA,GAAA,IAAA,oBAAf,YAAA,MAAW,CAAA,CAAA;yBA6CjB,4BAAA,6BAAA;KA3CnB,KAAA,GAAA,IAAA,OAAI,MAAK,CAAC;KACV,UAAQ,EAAA,GAAA,IAAA,OAAG,MAAK,CAAC,eAAA,GAAA,IAAA,OAAc,MAAK,CAAC;;qCAyCzB,EAAA,GAAA,IAAA,OAtCL,UAAS,KAAA,GAAA,IAAA,OAAI,eAAc,KAAA,GAAA,IAAA,YAAA,GAAA,GAAA,IAAA,aAsCtB,IAAA,aAAA,GAAA,IAAA,YAAA,EAAA,KAAA,GAAA,GAAA,GAAA,IAAA,OArCH,gBAAe,EAAA,EACtB,QAAQ,WAAA,UAAA,GAAA,IAAA,OAAc,MAAK,CAAC,SAAA,CAAA,EAAA;sCAmCvB,EAAA,GAAA,IAAA,iBAAA,GAAA,IAAA,oBAAA,QAAA,GAAA,IAAA,YAAA,EA/BH,KAAA,GAAA,IAAA,OAAI,WAAU,EAAA,GAAA,GAAA,IAAA,OACP,MAAK,EAAA;OACb,KAAI;OACH,OAAO,gBAAA;OACR,MAAK;OACL,UAAS;OACR,QAAA,GAAA,IAAA,OAAO,eAAA;uCAON,OAAA;OAJA,KAAI;OACH,QAAA,GAAA,IAAA,gBAAK,IAAA,GAAA,IAAA,OAAK,MAAK,CAAC,UAAO,YAAA,UAAA,QAAA;OACvB,QAAA,GAAA,IAAA,gBAAO,WAAA,MAAU;OAClB,qBAAA;+CAkBI,OAAA;OAhBD,KAAI;OAAW,OAAM;OAAiC,QAAA,GAAA,IAAA,gBAAO,WAAA,MAAA;yBAChD,MAAK,CAAC,SAAS,MAAM,UAAA,GAAA,IAAA,YAAA,GAAA,GAAA,IAAA,oBAQ7B,OAAA;;OANJ,QAAA,GAAA,IAAA,gBAAK,CAAC,yBAAuB,EAAA,GAAA,IAAA,OACpB,MAAK,CAAC,UAAO,kBAAA,mBAAA,GAAA,IAAA,OAAuC,MAAK,CAAC,WAAU,CAAA,CAAA;8BAItE,KAAA,QAAA,UAAA,GAAA,IAAA,iBAAA,GAAA,IAAA,oBAFoB,YAAA,MAAW,CAAA,QAE/B,EAAA,GAAA,IAAA,kBAAA,GAAA,IAAA,kBAAA,GAAA,IAAA,OADF,MAAK,CAAC,MAAK,EAAA,EAAA,CAAA,CAAA,CAAA,EAAA,EAAA,KAAA,GAAA,IAAA,oBAAA,IAAA,KAAA,GAAA,GAAA,IAAA,OAIH,MAAK,CAAC,WAAO,CAAK,MAAM,SAAK,EAAA,GAAA,IAAA,OAAK,MAAK,CAAC,SAAK,EAAA,GAAA,IAAA,OAAM,MAAK,CAAC,YAAA,GAAA,IAAA,YAAA,GAAA,GAAA,IAAA,oBAGlE,OAAA;;OAFA,QAAA,GAAA,IAAA,gBAAK,EAAA,GAAA,IAAA,OAAG,MAAK,CAAC,UAAO,kBAAA,iBAAA,GAAA,IAAA,OAAqC,MAAK,CAAC,UAAS,CAAA;8BACR,KAAA,QAAA,YAAA,GAAA,IAAA,iBAAA,GAAA,IAAA,oBAAvD,YAAA,MAAW,CAAA,QAA4C,EAAA,GAAA,IAAA,kBAAA,GAAA,IAAA,kBAAA,GAAA,IAAA,OAAvC,MAAK,CAAC,KAAI,IAAA,GAAA,IAAA,kBAAA,GAAA,IAAA,OAAM,MAAK,CAAC,QAAO,EAAA,EAAA,CAAA,CAAA,CAAA,EAAA,EAAA,KAAA,GAAA,IAAA,oBAAA,IAAA,KAAA,CAAA,EAAA,EAAA,CAAA,EAAA,IAAA,WAAA,EAAA,CAAA,CAAA,IAAA,QAAA,GAAA,IAAA,OA5BzD,QAAO,IAAA,CAAK,OAAA,MAAM,CAAA,CAAA,CAAA,CAAA;;;;;;;;;;;AELlC,IAAa,6BAA6B,cAAiC;CACzE,MAAM,CAAC,cAAc,UAAU,MAAM,IAAI;AACzC,SAAQ,YAAR;EACE,KAAK,OACH,QAAO;EACT,KAAK,QACH,QAAO;EACT,QACE,QAAO,cAAc;;;AAG3B,IAAa,yBAAyB,cAAiC;CACrE,MAAM,CAAC,cAAc,UAAU,MAAM,IAAI;AACzC,SAAQ,YAAR;EACE,KAAK,OACH,QAAO;EACT,KAAK,QACH,QAAO;EACT,KAAK,MACH,QAAO;EACT,KAAK,SACH,QAAO;EACT,QACE,QAAO,cAAc;;;AAI3B,IAAa,uBAAuB,WAClC,OAAO,WAAW,YAAY,OAAO,WAAW;AAElD,IAAa,kBACX,QACA,OACoC;AAEpC,KAAI,CADa,oBAAoB,OAAO,CAC7B,QAAO,EAAE;CAExB,MAAM,sBACJ,OAAO,WAAW,eACjB,OAAO,WAAW,YAAY,CAAC,OAAO,SAAS,CAAC,OAAO,WAAW,CAAC,OAAO;AAI7E,KADY,YAAA,iBAAiB,KACjB,MAAM;EAChB,MAAM,YAAY,GAAG,aAAa,QAAQ,IAAI,GAAG,aAAa,sBAAsB;AAGpF,MAAI,WAAW;AACb,MAAG,gBAAgB,QAAQ;AAC3B,MAAG,aAAa,uBAAuB,UAAU;;AAGnD,MAAI,qBAAqB;AACvB,OAAI,UACF,QAAO,EACL,MAAM,WACP;AAEH,UAAO,EAAE;;AAIX,MAAI,OAAO,WAAW,SACpB,QAAO;GACL,OAAO,aAAa,KAAA;GACpB,MAAM;GACP;YAIC,oBAAqB,QAAO,EAAE;AAGpC,KAAI,OAAO,WAAW,SACpB,QAAO,EACL,MAAM,QACP;AAIH,KAAI,QAAQ,QACV,SAAQ,KAAK,uEAAuE;AAEtF,QAAO;EACL,OAAO,QAAQ,QAAQ,QAAQ,QAAQ,KAAA;EACvC,MAAM,QAAQ,OAAO,QAAQ,OAAO,QAAQ,UAAU,QAAQ,UAAU,KAAA;EACzE;;AAGH,IAAa,yBACX,SACA,QACI;CACJ,QAAQ;CACR,YAAY,QAAQ,UAAU;CAC9B,QAAQ,QAAQ,UAAU;CAC1B,OAAO,QAAQ,UAAU;CACzB,OAAO,QAAQ,UAAU;CACzB,OAAO,QAAQ,UAAU;CACzB,QAAQ,QAAQ,UAAU;CAC1B,UAAU,QAAQ,UAAU;CAC5B,MAAM,QAAQ,UAAU;CACxB,WAAW,QAAQ,UAAU,OACzB,SACA,QAAQ,UAAU,QAChB,UACA,QAAQ,UAAU,SAChB,WACA,QAAQ,UAAU,MAChB,QACA,KAAA;CACV,GAAI,OAAO,QAAQ,UAAU,WAAW,QAAQ,QAAQ,KAAA;CACxD,GAAI,QAAQ,UAAU,cAAc,EAAC,gBAAgB,OAAM,GAAG,KAAA;CAC9D,OAAO;CACP,MAAM;CACP;AAqBD,IAAa,QACX,IACA,SACA,UACG;CACH,MAAM,MAAM,YAAA,iBAAiB;AAE7B,KAAI,QAAQ,KAAM;CAElB,MAAM,MAAM,IAAI,cAAc,OAAO;AACrC,KAAI,QAAQ,UAAU,KAAM,KAAI,KAAK,YAAY,IAAI;UAC5C,QAAQ,UAAU,MAAO,IAAG,YAAY,IAAI;KAChD,IAAG,YAAY,aAAa,KAAK,GAAG,YAAY;AACrD,EAAA,GAAA,IAAA,SAAA,GAAA,IAAA,GAAS,kBAAU,MAAM,EAAE,IAAI;AAC/B,IAAG,aAAa;;AAGlB,IAAa,UAAU,OAA0B;CAC/C,MAAM,MAAM,GAAG;AACf,KAAI,CAAC,IAAK;AAGV,EAAA,GAAA,IAAA,QAAO,MAAM,IAAI;AAGjB,KAAI,YAAA,iBAAiB,KAAK,MAAM;AAC9B,SAAO,GAAG;AACV;;AAKF,sBAAqB;AAGnB,MAAI,QAAQ;AAGZ,MAAI,GAAG,eAAe,IACpB,QAAO,GAAG;GAEZ;;AAGJ,IAAa,cAAc,UACzB,UAAU,uBAAuB,iBAAiB,WAAW,MAAM,QAAQ,MAAM;AAEnF,IAAa,kBAAkB,UAC7B,CAAC,WAAW,MAAM"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"floatingUi-DHMrP__c.mjs","names":[],"sources":["../src/composables/useMouse.ts","../src/components/BPopover/BPopover.vue","../src/components/BPopover/BPopover.vue","../src/utils/floatingUi.ts"],"sourcesContent":["import {useMouse as _useMouse, createSharedComposable} from '@vueuse/core'\n\nexport const useMouse = createSharedComposable(_useMouse)\n","<template>\n <span :id=\"computedId + '_placeholder'\" ref=\"_placeholder\" style=\"display: none\" />\n <slot name=\"target\" v-bind=\"sharedSlots\" />\n <ConditionalTeleport\n :to=\"props.teleportTo\"\n :disabled=\"!props.teleportTo || props.teleportDisabled\"\n >\n <Transition\n v-if=\"renderRef || contentShowing\"\n v-bind=\"transitionProps\"\n :appear=\"modelValue || props.visible\"\n >\n <div\n v-show=\"showRef && !hidden\"\n :id=\"computedId\"\n v-bind=\"attrs\"\n ref=\"_element\"\n :class=\"computedClasses\"\n role=\"tooltip\"\n tabindex=\"-1\"\n :style=\"floatingStyles\"\n >\n <div\n ref=\"_arrow\"\n :class=\"`${props.tooltip ? 'tooltip' : 'popover'}-arrow`\"\n :style=\"arrowStyle\"\n data-popper-arrow\n />\n <div ref=\"_content\" class=\"overflow-auto b-floating-size\" :style=\"sizeStyles\">\n <template v-if=\"props.title || slots.title\">\n <div\n class=\"position-sticky top-0\"\n :class=\"[props.tooltip ? 'tooltip-inner' : 'popover-header', props.titleClass]\"\n >\n <slot name=\"title\" v-bind=\"sharedSlots\">\n {{ props.title }}\n </slot>\n </div>\n </template>\n <template v-if=\"(props.tooltip && !slots.title && !props.title) || !props.tooltip\">\n <div :class=\"[props.tooltip ? 'tooltip-inner' : 'popover-body', props.bodyClass]\">\n <slot v-bind=\"sharedSlots\">{{ props.body }}{{ attrs.content }}</slot>\n </div>\n </template>\n </div>\n </div>\n </Transition>\n </ConditionalTeleport>\n</template>\n\n<script setup lang=\"ts\">\nimport {\n type Alignment,\n arrow as arrowMiddleware,\n autoPlacement,\n autoUpdate,\n type Boundary,\n flip,\n type Placement as FloatingPlacement,\n hide as hideMiddleware,\n inline as inlineMiddleware,\n type Middleware,\n offset as offsetMiddleware,\n type ReferenceElement,\n type RootBoundary,\n shift,\n size as sizeMiddleware,\n useFloating,\n} from '@floating-ui/vue'\nimport {onClickOutside, useToNumber} from '@vueuse/core'\nimport {\n computed,\n type ComputedRef,\n type CSSProperties,\n type EmitFn,\n nextTick,\n onBeforeUnmount,\n onMounted,\n ref,\n toRef,\n toValue,\n useAttrs,\n useTemplateRef,\n watch,\n} from 'vue'\nimport {useDefaults} from '../../composables/useDefaults'\nimport {useMouse} from '../../composables/useMouse'\nimport {useId} from '../../composables/useId'\nimport type {BPopoverSlots, ShowHideSlotsData, BPopoverProps, BPopoverEmits} from '../../types'\nimport {isBoundary, isRootBoundary, resolveBootstrapPlacement} from '../../utils/floatingUi'\nimport {getElement} from '../../utils/getElement'\nimport ConditionalTeleport from '../ConditionalTeleport.vue'\nimport {useShowHide} from '../../composables/useShowHide'\nimport {getSafeDocument, getSafeWindow} from '../../utils/dom'\n\ndefineOptions({\n inheritAttrs: false,\n})\n\nconst _props = withDefaults(defineProps<Omit<BPopoverProps, 'modelValue'>>(), {\n boundary: 'clippingAncestors',\n boundaryPadding: undefined,\n bodyClass: undefined,\n click: undefined,\n closeOnHide: false,\n focus: undefined,\n hover: undefined,\n teleportTo: undefined,\n teleportDisabled: false,\n body: undefined,\n delay: () => ({show: 100, hide: 300}),\n floatingMiddleware: undefined,\n hideMargin: 2,\n id: undefined,\n initialAnimation: false,\n inline: false,\n lazy: false,\n manual: false,\n noAutoClose: false,\n noFade: false,\n noFlip: false,\n noHide: false,\n noShift: false,\n noSize: false,\n noninteractive: false,\n offset: null,\n unmountLazy: false,\n placement: 'top',\n realtime: false,\n reference: null,\n strategy: 'absolute',\n target: null,\n title: undefined,\n titleClass: undefined,\n show: false,\n tooltip: false,\n visible: false,\n})\nconst props = useDefaults(_props, 'BPopover')\nconst emit = defineEmits<BPopoverEmits>()\nconst slots = defineSlots<BPopoverSlots>()\nconst attrs = useAttrs()\n\nconst modelValue = defineModel<Exclude<BPopoverProps['modelValue'], undefined>>({\n default: false,\n})\n\nconst computedId = useId(() => props.id, 'popover')\n\nconst hidden = ref(false)\n\nconst floatingElement = useTemplateRef('_element')\nconst content = useTemplateRef('_content')\nconst arrow = useTemplateRef('_arrow')\nconst placeholder = useTemplateRef('_placeholder')\n\nconst referenceElement = ref<HTMLElement | null>(null)\nconst triggerElement = ref<HTMLElement | null>(null)\n\nconst isAutoPlacement = computed(() => props.placement.startsWith('auto'))\nconst offsetNumber = useToNumber(() => props.offset ?? Number.NaN)\n\nconst boundary = computed<Boundary | undefined>(() =>\n isBoundary(props.boundary) ? props.boundary : undefined\n)\nconst rootBoundary = computed<RootBoundary | undefined>(() =>\n isRootBoundary(props.boundary) ? props.boundary : undefined\n)\n\nconst sizeStyles = ref<CSSProperties>({})\nconst floatingMiddleware = computed<readonly Middleware[]>(() => {\n if (props.floatingMiddleware !== undefined) {\n return props.floatingMiddleware\n }\n const off = props.offset !== null ? offsetNumber.value : props.tooltip ? 6 : 8\n const arr: Middleware[] = [offsetMiddleware(off)]\n if (props.noFlip === false && !isAutoPlacement.value) {\n arr.push(\n flip({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (isAutoPlacement.value) {\n arr.push(\n autoPlacement({\n alignment: (props.placement.split('-')[1] as Alignment) || undefined,\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.noShift === false) {\n arr.push(\n shift({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.noHide === false) {\n arr.push(\n hideMiddleware({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.inline === true) {\n arr.push(inlineMiddleware())\n }\n arr.push(arrowMiddleware({element: arrow, padding: 10}))\n if (props.noSize === false) {\n arr.push(\n sizeMiddleware({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n apply({availableWidth, availableHeight}) {\n sizeStyles.value = {\n '--bv-floating-max-height':\n availableHeight >= (content.value?.scrollHeight ?? 0)\n ? undefined\n : availableHeight\n ? `${Math.max(0, availableHeight)}px`\n : undefined,\n '--bv-floating-max-width':\n availableWidth >= (content.value?.scrollWidth ?? 0)\n ? undefined\n : availableWidth\n ? `${Math.max(0, availableWidth)}px`\n : undefined,\n }\n },\n })\n )\n }\n return arr\n})\n\nconst placementRef = computed(() =>\n isAutoPlacement.value ? undefined : (props.placement as FloatingPlacement)\n)\n\nconst {floatingStyles, middlewareData, placement, update} = useFloating(\n referenceElement,\n floatingElement,\n {\n placement: placementRef,\n middleware: floatingMiddleware as ComputedRef<Middleware[]>,\n strategy: toRef(() => props.strategy),\n }\n)\n\nconst arrowStyle = ref<CSSProperties>({position: 'absolute'})\n\nlet cleanup: ReturnType<typeof autoUpdate> | undefined\nconst {\n showRef,\n hide,\n show,\n toggle,\n throttleHide,\n computedNoAnimation,\n transitionProps,\n contentShowing,\n isVisible,\n isActive,\n renderRef,\n localTemporaryHide,\n setLocalTemporaryHide,\n} = useShowHide(modelValue, props, emit as EmitFn, floatingElement, computedId, {\n showFn: () => {\n update()\n nextTick(() => {\n cleanup = autoUpdate(\n referenceElement.value as ReferenceElement,\n floatingElement.value as HTMLElement,\n update,\n {animationFrame: props.realtime}\n )\n })\n },\n hideFn: () => {\n if (cleanup) {\n cleanup()\n cleanup = undefined\n }\n },\n})\n\nwatch(middlewareData, (newValue) => {\n if (props.noHide === false) {\n if (newValue.hide?.referenceHidden && !hidden.value && showRef.value) {\n if (props.closeOnHide && !props.noAutoClose && !props.manual) {\n throttleHide('close-on-hide')\n } else {\n setLocalTemporaryHide(true)\n hidden.value = true\n }\n } else if (localTemporaryHide.value && !newValue.hide?.referenceHidden) {\n setLocalTemporaryHide(false)\n hidden.value = false\n }\n }\n if (newValue.arrow) {\n const {x, y} = newValue.arrow\n arrowStyle.value = {\n position: 'absolute',\n top: y ? `${y}px` : '',\n left: x ? `${x}px` : '',\n }\n }\n})\n\nconst computedClasses = computed(() => {\n const type = props.tooltip ? 'tooltip' : 'popover'\n return [\n type,\n `b-${type}`,\n {\n show: isVisible.value && !hidden.value,\n fade: !computedNoAnimation.value,\n [`bs-${type}-${resolveBootstrapPlacement(placement.value)}`]: placement.value !== undefined,\n },\n ]\n})\n\nconst {x, y} = useMouse()\n\nconst isElementAndTriggerOutside = () => {\n const triggerRect = triggerElement.value?.getBoundingClientRect()\n const elementRect = floatingElement.value?.getBoundingClientRect()\n const margin = Number.parseInt(props.hideMargin as unknown as string, 10) || 0\n const offsetX = getSafeWindow()?.scrollX || 0\n const offsetY = getSafeWindow()?.scrollY || 0\n const triggerIsOutside =\n !triggerRect ||\n x.value < triggerRect.left + offsetX - margin ||\n x.value > triggerRect.right + offsetX + margin ||\n y.value < triggerRect.top + offsetY - margin ||\n y.value > triggerRect.bottom + offsetY + margin\n\n const isOutside =\n !elementRect ||\n x.value < elementRect.left + offsetX - margin ||\n x.value > elementRect.right + offsetX + margin ||\n y.value < elementRect.top + offsetY - margin ||\n y.value > elementRect.bottom + offsetY + margin\n\n return {triggerIsOutside, isOutside}\n}\n\nlet looptimeout: ReturnType<typeof setTimeout> | undefined\nconst tryHide = (e?: Readonly<Event>) => {\n const {triggerIsOutside, isOutside} = isElementAndTriggerOutside()\n const doc = getSafeDocument()\n if (\n (!props.noninteractive &&\n isOutside &&\n triggerIsOutside &&\n doc &&\n !floatingElement.value?.contains(doc.activeElement) &&\n (!computedTriggers.value.focus || !triggerElement.value?.contains(doc.activeElement))) ||\n (props.noninteractive && triggerIsOutside)\n ) {\n hide(e?.type)\n } else {\n if (looptimeout) clearTimeout(looptimeout)\n looptimeout = setTimeout(() => {\n tryHide(e)\n }, 50)\n }\n}\n\nwatch(isVisible, () => {\n update()\n})\n\ndefineExpose({\n hide,\n show,\n toggle,\n})\n\nconst localToggle = (e: Event) => {\n if (showRef.value) {\n hide(e.type === 'click' ? 'click' : 'toggle')\n } else {\n show()\n }\n}\n\nconst localShow = () => {\n show()\n}\n\n// Compute final trigger configuration\nconst computedTriggers = computed(() => {\n // Manual mode disables all automatic triggers\n if (props.manual) {\n return {hover: false, focus: false, click: false}\n }\n\n // If explicit boolean props are set, use them\n if (props.hover !== undefined || props.focus !== undefined || props.click !== undefined) {\n return {\n hover: props.hover ?? false,\n focus: props.focus ?? false,\n click: props.click ?? false,\n }\n }\n\n // If no explicit props, use default behavior: hover + focus\n return {hover: true, focus: true, click: false}\n})\n\nconst bind = () => {\n // TODO: is this the best way to bind the events?\n // we place a span and get the next element sibling for the listeners\n if (props.target) {\n const elem = getElement(toValue(props.target))\n if (elem) {\n triggerElement.value = elem\n } else {\n console.warn('Target element not found', props.target)\n }\n } else {\n triggerElement.value = placeholder.value?.nextElementSibling as HTMLElement\n }\n if (props.reference) {\n const elem = getElement(toValue(props.reference))\n if (elem) {\n referenceElement.value = elem\n } else {\n console.warn('Reference element not found', props.reference)\n }\n } else {\n referenceElement.value = triggerElement.value\n }\n if (!triggerElement.value || props.manual) {\n return\n }\n\n const triggers = computedTriggers.value\n\n if (triggers.click) {\n triggerElement.value.addEventListener('click', localToggle)\n }\n\n if (triggers.hover) {\n triggerElement.value.addEventListener('pointerenter', localShow)\n triggerElement.value.addEventListener('pointerleave', tryHide)\n }\n\n if (triggers.focus) {\n triggerElement.value.addEventListener('focus', localShow)\n triggerElement.value.addEventListener('blur', tryHide)\n }\n}\n\nconst unbind = () => {\n if (triggerElement.value) {\n triggerElement.value.removeEventListener('click', localToggle)\n triggerElement.value.removeEventListener('pointerenter', localShow)\n triggerElement.value.removeEventListener('pointerleave', tryHide)\n triggerElement.value.removeEventListener('focus', localShow)\n triggerElement.value.removeEventListener('blur', tryHide)\n }\n}\n\nonClickOutside(\n floatingElement,\n () => {\n if (showRef.value && computedTriggers.value.click && !props.noAutoClose && !props.manual)\n hide('click-outside')\n },\n {ignore: [triggerElement]}\n)\n\nwatch(\n [\n () => props.click,\n () => props.hover,\n () => props.focus,\n () => props.manual,\n () => props.target,\n () => props.reference,\n ],\n () => {\n unbind()\n bind()\n // update()\n }\n)\n\nconst sharedSlots = computed<ShowHideSlotsData>(() => ({\n toggle,\n show,\n hide,\n id: computedId.value,\n visible: isVisible.value,\n active: isActive.value,\n}))\n\nonMounted(() => {\n bind()\n nextTick(() => {\n update()\n })\n})\n\nonBeforeUnmount(unbind)\n</script>\n","<template>\n <span :id=\"computedId + '_placeholder'\" ref=\"_placeholder\" style=\"display: none\" />\n <slot name=\"target\" v-bind=\"sharedSlots\" />\n <ConditionalTeleport\n :to=\"props.teleportTo\"\n :disabled=\"!props.teleportTo || props.teleportDisabled\"\n >\n <Transition\n v-if=\"renderRef || contentShowing\"\n v-bind=\"transitionProps\"\n :appear=\"modelValue || props.visible\"\n >\n <div\n v-show=\"showRef && !hidden\"\n :id=\"computedId\"\n v-bind=\"attrs\"\n ref=\"_element\"\n :class=\"computedClasses\"\n role=\"tooltip\"\n tabindex=\"-1\"\n :style=\"floatingStyles\"\n >\n <div\n ref=\"_arrow\"\n :class=\"`${props.tooltip ? 'tooltip' : 'popover'}-arrow`\"\n :style=\"arrowStyle\"\n data-popper-arrow\n />\n <div ref=\"_content\" class=\"overflow-auto b-floating-size\" :style=\"sizeStyles\">\n <template v-if=\"props.title || slots.title\">\n <div\n class=\"position-sticky top-0\"\n :class=\"[props.tooltip ? 'tooltip-inner' : 'popover-header', props.titleClass]\"\n >\n <slot name=\"title\" v-bind=\"sharedSlots\">\n {{ props.title }}\n </slot>\n </div>\n </template>\n <template v-if=\"(props.tooltip && !slots.title && !props.title) || !props.tooltip\">\n <div :class=\"[props.tooltip ? 'tooltip-inner' : 'popover-body', props.bodyClass]\">\n <slot v-bind=\"sharedSlots\">{{ props.body }}{{ attrs.content }}</slot>\n </div>\n </template>\n </div>\n </div>\n </Transition>\n </ConditionalTeleport>\n</template>\n\n<script setup lang=\"ts\">\nimport {\n type Alignment,\n arrow as arrowMiddleware,\n autoPlacement,\n autoUpdate,\n type Boundary,\n flip,\n type Placement as FloatingPlacement,\n hide as hideMiddleware,\n inline as inlineMiddleware,\n type Middleware,\n offset as offsetMiddleware,\n type ReferenceElement,\n type RootBoundary,\n shift,\n size as sizeMiddleware,\n useFloating,\n} from '@floating-ui/vue'\nimport {onClickOutside, useToNumber} from '@vueuse/core'\nimport {\n computed,\n type ComputedRef,\n type CSSProperties,\n type EmitFn,\n nextTick,\n onBeforeUnmount,\n onMounted,\n ref,\n toRef,\n toValue,\n useAttrs,\n useTemplateRef,\n watch,\n} from 'vue'\nimport {useDefaults} from '../../composables/useDefaults'\nimport {useMouse} from '../../composables/useMouse'\nimport {useId} from '../../composables/useId'\nimport type {BPopoverSlots, ShowHideSlotsData, BPopoverProps, BPopoverEmits} from '../../types'\nimport {isBoundary, isRootBoundary, resolveBootstrapPlacement} from '../../utils/floatingUi'\nimport {getElement} from '../../utils/getElement'\nimport ConditionalTeleport from '../ConditionalTeleport.vue'\nimport {useShowHide} from '../../composables/useShowHide'\nimport {getSafeDocument, getSafeWindow} from '../../utils/dom'\n\ndefineOptions({\n inheritAttrs: false,\n})\n\nconst _props = withDefaults(defineProps<Omit<BPopoverProps, 'modelValue'>>(), {\n boundary: 'clippingAncestors',\n boundaryPadding: undefined,\n bodyClass: undefined,\n click: undefined,\n closeOnHide: false,\n focus: undefined,\n hover: undefined,\n teleportTo: undefined,\n teleportDisabled: false,\n body: undefined,\n delay: () => ({show: 100, hide: 300}),\n floatingMiddleware: undefined,\n hideMargin: 2,\n id: undefined,\n initialAnimation: false,\n inline: false,\n lazy: false,\n manual: false,\n noAutoClose: false,\n noFade: false,\n noFlip: false,\n noHide: false,\n noShift: false,\n noSize: false,\n noninteractive: false,\n offset: null,\n unmountLazy: false,\n placement: 'top',\n realtime: false,\n reference: null,\n strategy: 'absolute',\n target: null,\n title: undefined,\n titleClass: undefined,\n show: false,\n tooltip: false,\n visible: false,\n})\nconst props = useDefaults(_props, 'BPopover')\nconst emit = defineEmits<BPopoverEmits>()\nconst slots = defineSlots<BPopoverSlots>()\nconst attrs = useAttrs()\n\nconst modelValue = defineModel<Exclude<BPopoverProps['modelValue'], undefined>>({\n default: false,\n})\n\nconst computedId = useId(() => props.id, 'popover')\n\nconst hidden = ref(false)\n\nconst floatingElement = useTemplateRef('_element')\nconst content = useTemplateRef('_content')\nconst arrow = useTemplateRef('_arrow')\nconst placeholder = useTemplateRef('_placeholder')\n\nconst referenceElement = ref<HTMLElement | null>(null)\nconst triggerElement = ref<HTMLElement | null>(null)\n\nconst isAutoPlacement = computed(() => props.placement.startsWith('auto'))\nconst offsetNumber = useToNumber(() => props.offset ?? Number.NaN)\n\nconst boundary = computed<Boundary | undefined>(() =>\n isBoundary(props.boundary) ? props.boundary : undefined\n)\nconst rootBoundary = computed<RootBoundary | undefined>(() =>\n isRootBoundary(props.boundary) ? props.boundary : undefined\n)\n\nconst sizeStyles = ref<CSSProperties>({})\nconst floatingMiddleware = computed<readonly Middleware[]>(() => {\n if (props.floatingMiddleware !== undefined) {\n return props.floatingMiddleware\n }\n const off = props.offset !== null ? offsetNumber.value : props.tooltip ? 6 : 8\n const arr: Middleware[] = [offsetMiddleware(off)]\n if (props.noFlip === false && !isAutoPlacement.value) {\n arr.push(\n flip({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (isAutoPlacement.value) {\n arr.push(\n autoPlacement({\n alignment: (props.placement.split('-')[1] as Alignment) || undefined,\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.noShift === false) {\n arr.push(\n shift({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.noHide === false) {\n arr.push(\n hideMiddleware({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n })\n )\n }\n if (props.inline === true) {\n arr.push(inlineMiddleware())\n }\n arr.push(arrowMiddleware({element: arrow, padding: 10}))\n if (props.noSize === false) {\n arr.push(\n sizeMiddleware({\n boundary: boundary.value,\n rootBoundary: rootBoundary.value,\n padding: props.boundaryPadding,\n apply({availableWidth, availableHeight}) {\n sizeStyles.value = {\n '--bv-floating-max-height':\n availableHeight >= (content.value?.scrollHeight ?? 0)\n ? undefined\n : availableHeight\n ? `${Math.max(0, availableHeight)}px`\n : undefined,\n '--bv-floating-max-width':\n availableWidth >= (content.value?.scrollWidth ?? 0)\n ? undefined\n : availableWidth\n ? `${Math.max(0, availableWidth)}px`\n : undefined,\n }\n },\n })\n )\n }\n return arr\n})\n\nconst placementRef = computed(() =>\n isAutoPlacement.value ? undefined : (props.placement as FloatingPlacement)\n)\n\nconst {floatingStyles, middlewareData, placement, update} = useFloating(\n referenceElement,\n floatingElement,\n {\n placement: placementRef,\n middleware: floatingMiddleware as ComputedRef<Middleware[]>,\n strategy: toRef(() => props.strategy),\n }\n)\n\nconst arrowStyle = ref<CSSProperties>({position: 'absolute'})\n\nlet cleanup: ReturnType<typeof autoUpdate> | undefined\nconst {\n showRef,\n hide,\n show,\n toggle,\n throttleHide,\n computedNoAnimation,\n transitionProps,\n contentShowing,\n isVisible,\n isActive,\n renderRef,\n localTemporaryHide,\n setLocalTemporaryHide,\n} = useShowHide(modelValue, props, emit as EmitFn, floatingElement, computedId, {\n showFn: () => {\n update()\n nextTick(() => {\n cleanup = autoUpdate(\n referenceElement.value as ReferenceElement,\n floatingElement.value as HTMLElement,\n update,\n {animationFrame: props.realtime}\n )\n })\n },\n hideFn: () => {\n if (cleanup) {\n cleanup()\n cleanup = undefined\n }\n },\n})\n\nwatch(middlewareData, (newValue) => {\n if (props.noHide === false) {\n if (newValue.hide?.referenceHidden && !hidden.value && showRef.value) {\n if (props.closeOnHide && !props.noAutoClose && !props.manual) {\n throttleHide('close-on-hide')\n } else {\n setLocalTemporaryHide(true)\n hidden.value = true\n }\n } else if (localTemporaryHide.value && !newValue.hide?.referenceHidden) {\n setLocalTemporaryHide(false)\n hidden.value = false\n }\n }\n if (newValue.arrow) {\n const {x, y} = newValue.arrow\n arrowStyle.value = {\n position: 'absolute',\n top: y ? `${y}px` : '',\n left: x ? `${x}px` : '',\n }\n }\n})\n\nconst computedClasses = computed(() => {\n const type = props.tooltip ? 'tooltip' : 'popover'\n return [\n type,\n `b-${type}`,\n {\n show: isVisible.value && !hidden.value,\n fade: !computedNoAnimation.value,\n [`bs-${type}-${resolveBootstrapPlacement(placement.value)}`]: placement.value !== undefined,\n },\n ]\n})\n\nconst {x, y} = useMouse()\n\nconst isElementAndTriggerOutside = () => {\n const triggerRect = triggerElement.value?.getBoundingClientRect()\n const elementRect = floatingElement.value?.getBoundingClientRect()\n const margin = Number.parseInt(props.hideMargin as unknown as string, 10) || 0\n const offsetX = getSafeWindow()?.scrollX || 0\n const offsetY = getSafeWindow()?.scrollY || 0\n const triggerIsOutside =\n !triggerRect ||\n x.value < triggerRect.left + offsetX - margin ||\n x.value > triggerRect.right + offsetX + margin ||\n y.value < triggerRect.top + offsetY - margin ||\n y.value > triggerRect.bottom + offsetY + margin\n\n const isOutside =\n !elementRect ||\n x.value < elementRect.left + offsetX - margin ||\n x.value > elementRect.right + offsetX + margin ||\n y.value < elementRect.top + offsetY - margin ||\n y.value > elementRect.bottom + offsetY + margin\n\n return {triggerIsOutside, isOutside}\n}\n\nlet looptimeout: ReturnType<typeof setTimeout> | undefined\nconst tryHide = (e?: Readonly<Event>) => {\n const {triggerIsOutside, isOutside} = isElementAndTriggerOutside()\n const doc = getSafeDocument()\n if (\n (!props.noninteractive &&\n isOutside &&\n triggerIsOutside &&\n doc &&\n !floatingElement.value?.contains(doc.activeElement) &&\n (!computedTriggers.value.focus || !triggerElement.value?.contains(doc.activeElement))) ||\n (props.noninteractive && triggerIsOutside)\n ) {\n hide(e?.type)\n } else {\n if (looptimeout) clearTimeout(looptimeout)\n looptimeout = setTimeout(() => {\n tryHide(e)\n }, 50)\n }\n}\n\nwatch(isVisible, () => {\n update()\n})\n\ndefineExpose({\n hide,\n show,\n toggle,\n})\n\nconst localToggle = (e: Event) => {\n if (showRef.value) {\n hide(e.type === 'click' ? 'click' : 'toggle')\n } else {\n show()\n }\n}\n\nconst localShow = () => {\n show()\n}\n\n// Compute final trigger configuration\nconst computedTriggers = computed(() => {\n // Manual mode disables all automatic triggers\n if (props.manual) {\n return {hover: false, focus: false, click: false}\n }\n\n // If explicit boolean props are set, use them\n if (props.hover !== undefined || props.focus !== undefined || props.click !== undefined) {\n return {\n hover: props.hover ?? false,\n focus: props.focus ?? false,\n click: props.click ?? false,\n }\n }\n\n // If no explicit props, use default behavior: hover + focus\n return {hover: true, focus: true, click: false}\n})\n\nconst bind = () => {\n // TODO: is this the best way to bind the events?\n // we place a span and get the next element sibling for the listeners\n if (props.target) {\n const elem = getElement(toValue(props.target))\n if (elem) {\n triggerElement.value = elem\n } else {\n console.warn('Target element not found', props.target)\n }\n } else {\n triggerElement.value = placeholder.value?.nextElementSibling as HTMLElement\n }\n if (props.reference) {\n const elem = getElement(toValue(props.reference))\n if (elem) {\n referenceElement.value = elem\n } else {\n console.warn('Reference element not found', props.reference)\n }\n } else {\n referenceElement.value = triggerElement.value\n }\n if (!triggerElement.value || props.manual) {\n return\n }\n\n const triggers = computedTriggers.value\n\n if (triggers.click) {\n triggerElement.value.addEventListener('click', localToggle)\n }\n\n if (triggers.hover) {\n triggerElement.value.addEventListener('pointerenter', localShow)\n triggerElement.value.addEventListener('pointerleave', tryHide)\n }\n\n if (triggers.focus) {\n triggerElement.value.addEventListener('focus', localShow)\n triggerElement.value.addEventListener('blur', tryHide)\n }\n}\n\nconst unbind = () => {\n if (triggerElement.value) {\n triggerElement.value.removeEventListener('click', localToggle)\n triggerElement.value.removeEventListener('pointerenter', localShow)\n triggerElement.value.removeEventListener('pointerleave', tryHide)\n triggerElement.value.removeEventListener('focus', localShow)\n triggerElement.value.removeEventListener('blur', tryHide)\n }\n}\n\nonClickOutside(\n floatingElement,\n () => {\n if (showRef.value && computedTriggers.value.click && !props.noAutoClose && !props.manual)\n hide('click-outside')\n },\n {ignore: [triggerElement]}\n)\n\nwatch(\n [\n () => props.click,\n () => props.hover,\n () => props.focus,\n () => props.manual,\n () => props.target,\n () => props.reference,\n ],\n () => {\n unbind()\n bind()\n // update()\n }\n)\n\nconst sharedSlots = computed<ShowHideSlotsData>(() => ({\n toggle,\n show,\n hide,\n id: computedId.value,\n visible: isVisible.value,\n active: isActive.value,\n}))\n\nonMounted(() => {\n bind()\n nextTick(() => {\n update()\n })\n})\n\nonBeforeUnmount(unbind)\n</script>\n","import type {Boundary, Placement, RootBoundary} from '@floating-ui/vue'\nexport {autoUpdate} from '@floating-ui/vue'\n\nimport {type DirectiveBinding, h, render} from 'vue'\nimport BPopover from '../components/BPopover/BPopover.vue'\nimport type {BPopoverProps} from '../types'\nimport {getSafeDocument} from './dom'\n\nexport const resolveBootstrapPlacement = (placement: Placement): string => {\n const [_placement] = placement.split('-')\n switch (_placement) {\n case 'left':\n return 'start'\n case 'right':\n return 'end'\n default:\n return _placement || 'start'\n }\n}\nexport const resolveBootstrapCaret = (placement: Placement): string => {\n const [_placement] = placement.split('-')\n switch (_placement) {\n case 'left':\n return 'start'\n case 'right':\n return 'end'\n case 'top':\n return 'up'\n case 'bottom':\n return 'down'\n default:\n return _placement || 'start'\n }\n}\n\nexport const resolveActiveStatus = (values: DirectiveBinding['value']): boolean =>\n typeof values !== 'object' || values.active !== false\n\nexport const resolveContent = (\n values: DirectiveBinding['value'],\n el: HTMLElement\n): {title?: string; body?: string} => {\n const isActive = resolveActiveStatus(values)\n if (!isActive) return {}\n\n const missingBindingValue =\n typeof values === 'undefined' ||\n (typeof values === 'object' && !values.title && !values.content && !values.body)\n\n // SSR guard: skip DOM attribute access on server\n const doc = getSafeDocument()\n if (doc !== null) {\n const titleAttr = el.getAttribute('title') || el.getAttribute('data-original-title')\n\n // Always remove title attribute to prevent native tooltip conflicts\n if (titleAttr) {\n el.removeAttribute('title')\n el.setAttribute('data-original-title', titleAttr)\n }\n\n if (missingBindingValue) {\n if (titleAttr) {\n return {\n body: titleAttr,\n }\n }\n return {}\n }\n\n // For string directive values, use title attribute as popover title\n if (typeof values === 'string') {\n return {\n title: titleAttr || undefined,\n body: values,\n }\n }\n } else {\n // SSR: if no binding value provided, return empty\n if (missingBindingValue) return {}\n }\n\n if (typeof values === 'string') {\n return {\n body: values,\n }\n }\n\n // TODO: deprication remove warning in 2025-07\n if (values?.content)\n console.warn('v-b-popover/v-b-tooltip: `content` is deprecated, use `body` instead')\n\n return {\n title: values?.title ? values?.title : undefined,\n body: values?.body ? values?.body : values?.content ? values?.content : undefined,\n }\n}\n\nexport const resolveDirectiveProps = (\n binding: Readonly<DirectiveBinding>,\n el: Readonly<HTMLElement>\n) => ({\n target: el,\n modelValue: binding.modifiers.show,\n inline: binding.modifiers.inline,\n click: binding.modifiers.click,\n hover: binding.modifiers.hover,\n focus: binding.modifiers.focus,\n manual: binding.modifiers.manual,\n realtime: binding.modifiers.realtime,\n lazy: binding.modifiers.lazy,\n placement: binding.modifiers.left\n ? 'left'\n : binding.modifiers.right\n ? 'right'\n : binding.modifiers.bottom\n ? 'bottom'\n : binding.modifiers.top\n ? 'top'\n : undefined,\n ...(typeof binding.value === 'object' ? binding.value : undefined),\n ...(binding.modifiers.interactive ? {noninteractive: false} : undefined),\n title: null,\n body: null,\n})\n\nexport interface ElementWithPopper extends HTMLElement {\n [key: string]: unknown\n $__element?: HTMLElement\n $__tooltip?: Record<\n number,\n {\n binding: string\n destroying: boolean\n }\n >\n $__popover?: Record<\n number,\n {\n binding: string\n destroying: boolean\n }\n >\n}\n\nexport const bind = (\n el: ElementWithPopper,\n binding: Readonly<DirectiveBinding>,\n props: BPopoverProps\n) => {\n const doc = getSafeDocument()\n // SSR guard: skip DOM manipulation on server\n if (doc === null) return\n\n const div = doc.createElement('span')\n if (binding.modifiers.body) doc.body.appendChild(div)\n else if (binding.modifiers.child) el.appendChild(div)\n else el.parentNode?.insertBefore(div, el.nextSibling)\n render(h(BPopover, props), div)\n el.$__element = div\n}\n\nexport const unbind = (el: ElementWithPopper) => {\n const div = el.$__element\n if (!div) return\n\n // Unmount Vue component immediately\n render(null, div)\n\n // SSR guard: skip DOM cleanup on server\n if (getSafeDocument() !== null) {\n delete el.$__element\n return\n }\n\n // Use microtask instead of setTimeout(0) for more predictable cleanup\n // and better performance\n queueMicrotask(() => {\n // Remove the element in next microtask\n // The directive's beforeUnmount will have already cleaned up UID-specific state\n div.remove()\n // Only delete the reference if it still points to the div we just unmounted\n // This prevents deleting a fresh reference if bind() was called again immediately\n if (el.$__element === div) {\n delete el.$__element\n }\n })\n}\n\nexport const isBoundary = (input: unknown): input is Boundary =>\n input === 'clippingAncestors' || input instanceof Element || Array.isArray(input)\n\nexport const isRootBoundary = (input: Boundary | RootBoundary): input is RootBoundary =>\n !isBoundary(input)\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"useFormCheck-CJvIDxcO.mjs","names":[],"sources":["../src/composables/useFormCheck.ts"],"sourcesContent":["import type {AriaInvalid} from '../types/AriaInvalid'\nimport {computed, type MaybeRefOrGetter, readonly, toRef, toValue} from 'vue'\nimport {useAriaInvalid} from './useAriaInvalid'\nimport {useStateClass} from './useStateClass'\nimport type {Size} from '../types/Size'\nimport type {ButtonVariant} from '../types/ColorTypes'\nimport type {ValidationState} from '../types/CommonTypes'\n\ninterface ClassesItemsInput {\n plain?: boolean\n button?: boolean\n inline?: boolean\n reverse?: boolean\n switch?: boolean\n size?: Size\n hasDefaultSlot?: boolean\n}\n\nconst getClasses = (items: MaybeRefOrGetter<ClassesItemsInput>) =>\n computed(() => {\n const resolvedItems = toValue(items)\n return {\n 'form-check': !resolvedItems.plain && !resolvedItems.button && resolvedItems.hasDefaultSlot,\n 'form-check-reverse': resolvedItems.reverse === true,\n 'form-check-inline': resolvedItems.inline === true,\n 'form-switch': resolvedItems.switch === true,\n [`form-control-${resolvedItems.size}`]:\n resolvedItems.size !== undefined && resolvedItems.size !== 'md' && !resolvedItems.button,\n }\n })\n\ninterface InputClassesItemsInput {\n plain?: boolean\n button?: boolean\n state?: ValidationState\n}\n\nconst getInputClasses = (items: MaybeRefOrGetter<InputClassesItemsInput>) => {\n const resolvedItems = readonly(toRef(items))\n\n const stateClass = useStateClass(() => resolvedItems.value.state ?? null)\n\n return computed(() => [\n stateClass.value,\n {\n 'form-check-input': !resolvedItems.value.plain && !resolvedItems.value.button,\n 'btn-check': resolvedItems.value.button === true,\n },\n ])\n}\n\ninterface LabelClasesItemsInput {\n plain?: boolean\n button?: boolean\n buttonVariant?: ButtonVariant | null\n size?: Size\n}\n\nconst getLabelClasses = (items: MaybeRefOrGetter<LabelClasesItemsInput>) =>\n computed(() => {\n const resolvedItems = toValue(items)\n return {\n 'form-check-label': !resolvedItems.plain && !resolvedItems.button,\n 'btn': resolvedItems.button === true,\n [`btn-${resolvedItems.buttonVariant}`]:\n resolvedItems.button === true &&\n resolvedItems.buttonVariant !== undefined &&\n resolvedItems.buttonVariant !== null,\n [`btn-${resolvedItems.size}`]:\n resolvedItems.button && resolvedItems.size && resolvedItems.size !== 'md',\n }\n })\n\ninterface GroupAttrItemsInput {\n required?: boolean\n ariaInvalid?: AriaInvalid\n state?: ValidationState\n}\n\nconst getGroupAttr = (items: MaybeRefOrGetter<GroupAttrItemsInput>) => {\n const resolvedItems = readonly(toRef(items))\n const computedAriaInvalid = useAriaInvalid(\n () => resolvedItems.value.ariaInvalid,\n () => resolvedItems.value.state\n )\n return computed(() => ({\n 'aria-invalid': computedAriaInvalid.value as Exclude<AriaInvalid, ''> | undefined,\n 'aria-required': resolvedItems.value.required === true ? true : undefined,\n }))\n}\n\ninterface GroupClassesItemsInput {\n validated?: boolean\n buttons?: boolean\n stacked?: boolean\n size?: Size\n}\n\nconst getGroupClasses = (items: MaybeRefOrGetter<GroupClassesItemsInput>) =>\n computed(() => {\n const resolvedItems = toValue(items)\n return {\n 'was-validated': resolvedItems.validated === true,\n 'btn-group': resolvedItems.buttons === true && resolvedItems.stacked === false,\n 'btn-group-vertical': resolvedItems.stacked === true && resolvedItems.buttons === true,\n [`btn-group-${resolvedItems.size}`]: resolvedItems.size !== undefined,\n }\n })\n\nexport {getClasses, getInputClasses, getLabelClasses, getGroupAttr, getGroupClasses}\n"],"mappings":";;;;AAkBA,IAAM,cAAc,UAClB,eAAe;CACb,MAAM,gBAAgB,QAAQ,MAAM;AACpC,QAAO;EACL,cAAc,CAAC,cAAc,SAAS,CAAC,cAAc,UAAU,cAAc;EAC7E,sBAAsB,cAAc,YAAY;EAChD,qBAAqB,cAAc,WAAW;EAC9C,eAAe,cAAc,WAAW;GACvC,gBAAgB,cAAc,SAC7B,cAAc,SAAS,KAAA,KAAa,cAAc,SAAS,QAAQ,CAAC,cAAc;EACrF;EACD;AAQJ,IAAM,mBAAmB,UAAoD;CAC3E,MAAM,gBAAgB,SAAS,MAAM,MAAM,CAAC;CAE5C,MAAM,aAAa,oBAAoB,cAAc,MAAM,SAAS,KAAK;AAEzE,QAAO,eAAe,CACpB,WAAW,OACX;EACE,oBAAoB,CAAC,cAAc,MAAM,SAAS,CAAC,cAAc,MAAM;EACvE,aAAa,cAAc,MAAM,WAAW;EAC7C,CACF,CAAC;;AAUJ,IAAM,mBAAmB,UACvB,eAAe;CACb,MAAM,gBAAgB,QAAQ,MAAM;AACpC,QAAO;EACL,oBAAoB,CAAC,cAAc,SAAS,CAAC,cAAc;EAC3D,OAAO,cAAc,WAAW;GAC/B,OAAO,cAAc,kBACpB,cAAc,WAAW,QACzB,cAAc,kBAAkB,KAAA,KAChC,cAAc,kBAAkB;GACjC,OAAO,cAAc,SACpB,cAAc,UAAU,cAAc,QAAQ,cAAc,SAAS;EACxE;EACD;AAQJ,IAAM,gBAAgB,UAAiD;CACrE,MAAM,gBAAgB,SAAS,MAAM,MAAM,CAAC;CAC5C,MAAM,sBAAsB,qBACpB,cAAc,MAAM,mBACpB,cAAc,MAAM,MAC3B;AACD,QAAO,gBAAgB;EACrB,gBAAgB,oBAAoB;EACpC,iBAAiB,cAAc,MAAM,aAAa,OAAO,OAAO,KAAA;EACjE,EAAE;;AAUL,IAAM,mBAAmB,UACvB,eAAe;CACb,MAAM,gBAAgB,QAAQ,MAAM;AACpC,QAAO;EACL,iBAAiB,cAAc,cAAc;EAC7C,aAAa,cAAc,YAAY,QAAQ,cAAc,YAAY;EACzE,sBAAsB,cAAc,YAAY,QAAQ,cAAc,YAAY;GACjF,aAAa,cAAc,SAAS,cAAc,SAAS,KAAA;EAC7D;EACD"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"useFormCheck-UHNy_iZ0.js","names":[],"sources":["../src/composables/useFormCheck.ts"],"sourcesContent":["import type {AriaInvalid} from '../types/AriaInvalid'\nimport {computed, type MaybeRefOrGetter, readonly, toRef, toValue} from 'vue'\nimport {useAriaInvalid} from './useAriaInvalid'\nimport {useStateClass} from './useStateClass'\nimport type {Size} from '../types/Size'\nimport type {ButtonVariant} from '../types/ColorTypes'\nimport type {ValidationState} from '../types/CommonTypes'\n\ninterface ClassesItemsInput {\n plain?: boolean\n button?: boolean\n inline?: boolean\n reverse?: boolean\n switch?: boolean\n size?: Size\n hasDefaultSlot?: boolean\n}\n\nconst getClasses = (items: MaybeRefOrGetter<ClassesItemsInput>) =>\n computed(() => {\n const resolvedItems = toValue(items)\n return {\n 'form-check': !resolvedItems.plain && !resolvedItems.button && resolvedItems.hasDefaultSlot,\n 'form-check-reverse': resolvedItems.reverse === true,\n 'form-check-inline': resolvedItems.inline === true,\n 'form-switch': resolvedItems.switch === true,\n [`form-control-${resolvedItems.size}`]:\n resolvedItems.size !== undefined && resolvedItems.size !== 'md' && !resolvedItems.button,\n }\n })\n\ninterface InputClassesItemsInput {\n plain?: boolean\n button?: boolean\n state?: ValidationState\n}\n\nconst getInputClasses = (items: MaybeRefOrGetter<InputClassesItemsInput>) => {\n const resolvedItems = readonly(toRef(items))\n\n const stateClass = useStateClass(() => resolvedItems.value.state ?? null)\n\n return computed(() => [\n stateClass.value,\n {\n 'form-check-input': !resolvedItems.value.plain && !resolvedItems.value.button,\n 'btn-check': resolvedItems.value.button === true,\n },\n ])\n}\n\ninterface LabelClasesItemsInput {\n plain?: boolean\n button?: boolean\n buttonVariant?: ButtonVariant | null\n size?: Size\n}\n\nconst getLabelClasses = (items: MaybeRefOrGetter<LabelClasesItemsInput>) =>\n computed(() => {\n const resolvedItems = toValue(items)\n return {\n 'form-check-label': !resolvedItems.plain && !resolvedItems.button,\n 'btn': resolvedItems.button === true,\n [`btn-${resolvedItems.buttonVariant}`]:\n resolvedItems.button === true &&\n resolvedItems.buttonVariant !== undefined &&\n resolvedItems.buttonVariant !== null,\n [`btn-${resolvedItems.size}`]:\n resolvedItems.button && resolvedItems.size && resolvedItems.size !== 'md',\n }\n })\n\ninterface GroupAttrItemsInput {\n required?: boolean\n ariaInvalid?: AriaInvalid\n state?: ValidationState\n}\n\nconst getGroupAttr = (items: MaybeRefOrGetter<GroupAttrItemsInput>) => {\n const resolvedItems = readonly(toRef(items))\n const computedAriaInvalid = useAriaInvalid(\n () => resolvedItems.value.ariaInvalid,\n () => resolvedItems.value.state\n )\n return computed(() => ({\n 'aria-invalid': computedAriaInvalid.value as Exclude<AriaInvalid, ''> | undefined,\n 'aria-required': resolvedItems.value.required === true ? true : undefined,\n }))\n}\n\ninterface GroupClassesItemsInput {\n validated?: boolean\n buttons?: boolean\n stacked?: boolean\n size?: Size\n}\n\nconst getGroupClasses = (items: MaybeRefOrGetter<GroupClassesItemsInput>) =>\n computed(() => {\n const resolvedItems = toValue(items)\n return {\n 'was-validated': resolvedItems.validated === true,\n 'btn-group': resolvedItems.buttons === true && resolvedItems.stacked === false,\n 'btn-group-vertical': resolvedItems.stacked === true && resolvedItems.buttons === true,\n [`btn-group-${resolvedItems.size}`]: resolvedItems.size !== undefined,\n }\n })\n\nexport {getClasses, getInputClasses, getLabelClasses, getGroupAttr, getGroupClasses}\n"],"mappings":";;;;;AAkBA,IAAM,cAAc,WAAA,GAAA,IAAA,gBACH;CACb,MAAM,iBAAA,GAAA,IAAA,SAAwB,MAAM;AACpC,QAAO;EACL,cAAc,CAAC,cAAc,SAAS,CAAC,cAAc,UAAU,cAAc;EAC7E,sBAAsB,cAAc,YAAY;EAChD,qBAAqB,cAAc,WAAW;EAC9C,eAAe,cAAc,WAAW;GACvC,gBAAgB,cAAc,SAC7B,cAAc,SAAS,KAAA,KAAa,cAAc,SAAS,QAAQ,CAAC,cAAc;EACrF;EACD;AAQJ,IAAM,mBAAmB,UAAoD;CAC3E,MAAM,iBAAA,GAAA,IAAA,WAAA,GAAA,IAAA,OAA+B,MAAM,CAAC;CAE5C,MAAM,aAAa,sBAAA,oBAAoB,cAAc,MAAM,SAAS,KAAK;AAEzE,SAAA,GAAA,IAAA,gBAAsB,CACpB,WAAW,OACX;EACE,oBAAoB,CAAC,cAAc,MAAM,SAAS,CAAC,cAAc,MAAM;EACvE,aAAa,cAAc,MAAM,WAAW;EAC7C,CACF,CAAC;;AAUJ,IAAM,mBAAmB,WAAA,GAAA,IAAA,gBACR;CACb,MAAM,iBAAA,GAAA,IAAA,SAAwB,MAAM;AACpC,QAAO;EACL,oBAAoB,CAAC,cAAc,SAAS,CAAC,cAAc;EAC3D,OAAO,cAAc,WAAW;GAC/B,OAAO,cAAc,kBACpB,cAAc,WAAW,QACzB,cAAc,kBAAkB,KAAA,KAChC,cAAc,kBAAkB;GACjC,OAAO,cAAc,SACpB,cAAc,UAAU,cAAc,QAAQ,cAAc,SAAS;EACxE;EACD;AAQJ,IAAM,gBAAgB,UAAiD;CACrE,MAAM,iBAAA,GAAA,IAAA,WAAA,GAAA,IAAA,OAA+B,MAAM,CAAC;CAC5C,MAAM,sBAAsB,uBAAA,qBACpB,cAAc,MAAM,mBACpB,cAAc,MAAM,MAC3B;AACD,SAAA,GAAA,IAAA,iBAAuB;EACrB,gBAAgB,oBAAoB;EACpC,iBAAiB,cAAc,MAAM,aAAa,OAAO,OAAO,KAAA;EACjE,EAAE;;AAUL,IAAM,mBAAmB,WAAA,GAAA,IAAA,gBACR;CACb,MAAM,iBAAA,GAAA,IAAA,SAAwB,MAAM;AACpC,QAAO;EACL,iBAAiB,cAAc,cAAc;EAC7C,aAAa,cAAc,YAAY,QAAQ,cAAc,YAAY;EACzE,sBAAsB,cAAc,YAAY,QAAQ,cAAc,YAAY;GACjF,aAAa,cAAc,SAAS,cAAc,SAAS,KAAA;EAC7D;EACD"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils-CaC78Zdk.js","names":[],"sources":["../src/directives/utils.ts"],"sourcesContent":["import type {ComponentInternalInstance, Directive, DirectiveBinding, Ref, VNode} from 'vue'\nimport type {BPopoverProps} from '../types/ComponentProps'\nimport {\n bind,\n type ElementWithPopper,\n resolveActiveStatus,\n resolveContent,\n resolveDirectiveProps,\n unbind,\n} from '../utils/floatingUi'\nimport {defaultsKey} from '../utils/keys'\n\ninterface _ComponentInternalInstance extends ComponentInternalInstance {\n provides?: Record<string, unknown>\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setupState?: any\n}\n\ninterface _VNode extends VNode {\n ctx?: _ComponentInternalInstance | null\n ssContent?: VNode | null\n}\n\n/**\n * Represents per-instance state for directives using UID namespacing\n */\nexport interface DirectiveInstanceState {\n binding: string // JSON.stringify cache for change detection\n destroying: boolean // Flag to prevent race conditions during cleanup\n}\n\n/**\n * Gets the component instance UID from a directive binding\n * @throws Error if binding.instance is not available\n */\nexport function getDirectiveUid(binding: DirectiveBinding): number {\n if (!binding.instance) {\n throw new Error('[Bootstrap-Vue-Next] Directive binding.instance is not available')\n }\n return binding.instance.$.uid\n}\n\n/**\n * Initializes UID-namespaced storage on an element for a directive\n * @param el - The HTML element\n * @param propertyName - The property name (e.g., '$__tooltip', '$__popover')\n * @param uid - The component instance UID\n * @param binding - The directive binding value to cache\n * @returns The initialized instance state\n */\nexport function initDirectiveInstance(\n el: HTMLElement & Record<string, unknown>,\n propertyName: string,\n uid: number,\n binding: DirectiveBinding\n): DirectiveInstanceState {\n // Initialize UID namespace for this directive\n const elWithProps = el as Record<string, unknown>\n elWithProps[propertyName] = elWithProps[propertyName] ?? Object.create(null)\n\n // Store per-instance state with JSON cache for change detection\n const state: DirectiveInstanceState = {\n binding: JSON.stringify([binding.modifiers, binding.value]),\n destroying: false,\n }\n\n ;(elWithProps[propertyName] as Record<string, unknown>)[uid] = state\n return state\n}\n\n/**\n * Gets the instance state for a directive, if it exists\n * @param el - The HTML element\n * @param propertyName - The property name (e.g., '$__tooltip', '$__popover')\n * @param uid - The component instance UID\n * @returns The instance state or undefined if not found\n */\nexport function getDirectiveInstance(\n el: HTMLElement & Record<string, unknown>,\n propertyName: string,\n uid: number\n): DirectiveInstanceState | undefined {\n const elWithProps = el as Record<string, unknown>\n return (elWithProps[propertyName] as Record<string, unknown> | undefined)?.[uid] as\n | DirectiveInstanceState\n | undefined\n}\n\n/**\n * Checks if the directive binding has changed for this instance\n * @param instance - The directive instance state\n * @param binding - The current directive binding\n * @returns true if the binding has changed, false otherwise\n */\nexport function hasBindingChanged(\n instance: DirectiveInstanceState,\n binding: DirectiveBinding\n): boolean {\n const newBinding = JSON.stringify([binding.modifiers, binding.value])\n return instance.binding !== newBinding\n}\n\n/**\n * Updates the cached binding value for a directive instance\n * @param instance - The directive instance state\n * @param binding - The new directive binding\n */\nexport function updateBindingCache(\n instance: DirectiveInstanceState,\n binding: DirectiveBinding\n): void {\n instance.binding = JSON.stringify([binding.modifiers, binding.value])\n}\n\n/**\n * Cleans up a directive instance\n * @param el - The HTML element\n * @param propertyName - The property name (e.g., '$__tooltip', '$__popover')\n * @param uid - The component instance UID\n */\nexport function cleanupDirectiveInstance(\n el: HTMLElement & Record<string, unknown>,\n propertyName: string,\n uid: number\n): void {\n const elWithProps = el as Record<string, unknown>\n const instance = (elWithProps[propertyName] as Record<string, unknown> | undefined)?.[uid] as\n | DirectiveInstanceState\n | undefined\n if (instance) {\n instance.destroying = true\n delete (elWithProps[propertyName] as Record<string, unknown>)[uid]\n }\n}\n\n// taken from vuetify https://github.com/vuetifyjs/vuetify/blob/master/packages/vuetify/src/composables/directiveComponent.ts\n\nexport function findProvides(binding: DirectiveBinding, vnode: _VNode): Record<string, unknown> {\n const provides =\n (vnode.ctx === binding.instance!.$\n ? findComponentParent(vnode, binding.instance!.$)?.provides\n : vnode.ctx?.provides) ?? binding.instance!.$.provides\n\n return provides\n}\n\nexport function findComponentParent(\n vnode: VNode,\n root: ComponentInternalInstance\n): _ComponentInternalInstance | null {\n // Walk the tree from root until we find the child vnode\n const stack = new Set<VNode>()\n const walk = (children: _VNode[]): boolean => {\n for (const child of children) {\n if (!child) continue\n\n if (child === vnode || (child.el && vnode.el && child.el === vnode.el)) {\n return true\n }\n\n stack.add(child)\n let result\n if (child.suspense) {\n result = walk([child.ssContent!])\n } else if (Array.isArray(child.children)) {\n result = walk(child.children as VNode[])\n } else if (child.component?.vnode) {\n result = walk([child.component?.subTree])\n }\n if (result) {\n return result\n }\n stack.delete(child)\n }\n\n return false\n }\n if (!walk([root.subTree])) {\n console.error('Could not find original vnode, will not inherit provides')\n return root\n }\n\n // Return the first component parent\n const result = Array.from(stack).reverse()\n for (const child of result) {\n if (child.component) {\n return child.component\n }\n }\n return root\n}\n\n/**\n * Creates a floating UI directive (tooltip or popover) with UID-namespaced state management\n * @param propertyName - The property name for storing state (e.g., '$__tooltip', '$__popover')\n * @param componentDefaultsKey - The key for accessing component defaults (e.g., 'BTooltip', 'BPopover')\n * @param buildProps - Optional function to customize the props passed to bind()\n * @returns A Vue directive object\n */\nexport function createFloatingDirective(\n propertyName: string,\n componentDefaultsKey: string,\n buildProps?: (\n text: {title?: string; body?: string},\n defaults: unknown,\n binding: Readonly<DirectiveBinding>,\n el: Readonly<HTMLElement>\n ) => BPopoverProps\n): Directive<ElementWithPopper> {\n return {\n mounted(el, binding, vnode) {\n const uid = getDirectiveUid(binding)\n const defaultsMap = (findProvides(binding, vnode) as Record<symbol, Ref>)[defaultsKey]\n ?.value as Record<string, unknown> | undefined\n const isActive = resolveActiveStatus(binding.value)\n if (!isActive) return\n\n const text = resolveContent(binding.value, el)\n\n if (!text.body && !text.title) return\n\n // Initialize per-instance state with UID namespacing\n initDirectiveInstance(el, propertyName, uid, binding)\n\n const props = buildProps\n ? buildProps(text, defaultsMap?.[componentDefaultsKey], binding, el)\n : {\n ...(defaultsMap?.[componentDefaultsKey] || undefined),\n ...resolveDirectiveProps(binding, el),\n ...text,\n }\n\n bind(el, binding, props)\n },\n\n updated(el, binding, vnode) {\n const uid = getDirectiveUid(binding)\n let instance = getDirectiveInstance(el, propertyName, uid)\n\n const defaultsMap = (findProvides(binding, vnode) as Record<symbol, Ref>)[defaultsKey]\n ?.value as Record<string, unknown> | undefined\n\n const isActive = resolveActiveStatus(binding.value)\n\n // If inactive, clean up existing instance if present\n if (!isActive) {\n if (instance && el.$__element) {\n unbind(el)\n cleanupDirectiveInstance(el, propertyName, uid)\n }\n return\n }\n\n const text = resolveContent(binding.value, el)\n\n if (!text.body && !text.title) {\n // Clean up if no content\n if (instance && el.$__element) {\n unbind(el)\n cleanupDirectiveInstance(el, propertyName, uid)\n }\n return\n }\n\n // If instance doesn't exist, this is a transition from inactive/no-content to active\n // Initialize the instance now (similar to mounted)\n if (!instance) {\n instance = initDirectiveInstance(el, propertyName, uid, binding)\n\n const props = buildProps\n ? buildProps(text, defaultsMap?.[componentDefaultsKey], binding, el)\n : {\n ...(defaultsMap?.[componentDefaultsKey] || undefined),\n ...resolveDirectiveProps(binding, el),\n ...text,\n }\n\n bind(el, binding, props)\n return\n }\n\n // Check if binding changed for THIS instance\n if (!hasBindingChanged(instance, binding)) return\n\n // Prevent race conditions during update\n if (instance.destroying) return\n\n unbind(el)\n\n const props = buildProps\n ? buildProps(text, defaultsMap?.[componentDefaultsKey], binding, el)\n : {\n ...(defaultsMap?.[componentDefaultsKey] || undefined),\n ...resolveDirectiveProps(binding, el),\n ...text,\n }\n\n bind(el, binding, props)\n\n // Update THIS instance's cache\n updateBindingCache(instance, binding)\n },\n\n beforeUnmount(el, binding) {\n const uid = getDirectiveUid(binding)\n const instance = getDirectiveInstance(el, propertyName, uid)\n\n if (!instance) return\n\n unbind(el)\n cleanupDirectiveInstance(el, propertyName, uid)\n },\n }\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils-CgwCsk6U.mjs","names":[],"sources":["../src/directives/utils.ts"],"sourcesContent":["import type {ComponentInternalInstance, Directive, DirectiveBinding, Ref, VNode} from 'vue'\nimport type {BPopoverProps} from '../types/ComponentProps'\nimport {\n bind,\n type ElementWithPopper,\n resolveActiveStatus,\n resolveContent,\n resolveDirectiveProps,\n unbind,\n} from '../utils/floatingUi'\nimport {defaultsKey} from '../utils/keys'\n\ninterface _ComponentInternalInstance extends ComponentInternalInstance {\n provides?: Record<string, unknown>\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setupState?: any\n}\n\ninterface _VNode extends VNode {\n ctx?: _ComponentInternalInstance | null\n ssContent?: VNode | null\n}\n\n/**\n * Represents per-instance state for directives using UID namespacing\n */\nexport interface DirectiveInstanceState {\n binding: string // JSON.stringify cache for change detection\n destroying: boolean // Flag to prevent race conditions during cleanup\n}\n\n/**\n * Gets the component instance UID from a directive binding\n * @throws Error if binding.instance is not available\n */\nexport function getDirectiveUid(binding: DirectiveBinding): number {\n if (!binding.instance) {\n throw new Error('[Bootstrap-Vue-Next] Directive binding.instance is not available')\n }\n return binding.instance.$.uid\n}\n\n/**\n * Initializes UID-namespaced storage on an element for a directive\n * @param el - The HTML element\n * @param propertyName - The property name (e.g., '$__tooltip', '$__popover')\n * @param uid - The component instance UID\n * @param binding - The directive binding value to cache\n * @returns The initialized instance state\n */\nexport function initDirectiveInstance(\n el: HTMLElement & Record<string, unknown>,\n propertyName: string,\n uid: number,\n binding: DirectiveBinding\n): DirectiveInstanceState {\n // Initialize UID namespace for this directive\n const elWithProps = el as Record<string, unknown>\n elWithProps[propertyName] = elWithProps[propertyName] ?? Object.create(null)\n\n // Store per-instance state with JSON cache for change detection\n const state: DirectiveInstanceState = {\n binding: JSON.stringify([binding.modifiers, binding.value]),\n destroying: false,\n }\n\n ;(elWithProps[propertyName] as Record<string, unknown>)[uid] = state\n return state\n}\n\n/**\n * Gets the instance state for a directive, if it exists\n * @param el - The HTML element\n * @param propertyName - The property name (e.g., '$__tooltip', '$__popover')\n * @param uid - The component instance UID\n * @returns The instance state or undefined if not found\n */\nexport function getDirectiveInstance(\n el: HTMLElement & Record<string, unknown>,\n propertyName: string,\n uid: number\n): DirectiveInstanceState | undefined {\n const elWithProps = el as Record<string, unknown>\n return (elWithProps[propertyName] as Record<string, unknown> | undefined)?.[uid] as\n | DirectiveInstanceState\n | undefined\n}\n\n/**\n * Checks if the directive binding has changed for this instance\n * @param instance - The directive instance state\n * @param binding - The current directive binding\n * @returns true if the binding has changed, false otherwise\n */\nexport function hasBindingChanged(\n instance: DirectiveInstanceState,\n binding: DirectiveBinding\n): boolean {\n const newBinding = JSON.stringify([binding.modifiers, binding.value])\n return instance.binding !== newBinding\n}\n\n/**\n * Updates the cached binding value for a directive instance\n * @param instance - The directive instance state\n * @param binding - The new directive binding\n */\nexport function updateBindingCache(\n instance: DirectiveInstanceState,\n binding: DirectiveBinding\n): void {\n instance.binding = JSON.stringify([binding.modifiers, binding.value])\n}\n\n/**\n * Cleans up a directive instance\n * @param el - The HTML element\n * @param propertyName - The property name (e.g., '$__tooltip', '$__popover')\n * @param uid - The component instance UID\n */\nexport function cleanupDirectiveInstance(\n el: HTMLElement & Record<string, unknown>,\n propertyName: string,\n uid: number\n): void {\n const elWithProps = el as Record<string, unknown>\n const instance = (elWithProps[propertyName] as Record<string, unknown> | undefined)?.[uid] as\n | DirectiveInstanceState\n | undefined\n if (instance) {\n instance.destroying = true\n delete (elWithProps[propertyName] as Record<string, unknown>)[uid]\n }\n}\n\n// taken from vuetify https://github.com/vuetifyjs/vuetify/blob/master/packages/vuetify/src/composables/directiveComponent.ts\n\nexport function findProvides(binding: DirectiveBinding, vnode: _VNode): Record<string, unknown> {\n const provides =\n (vnode.ctx === binding.instance!.$\n ? findComponentParent(vnode, binding.instance!.$)?.provides\n : vnode.ctx?.provides) ?? binding.instance!.$.provides\n\n return provides\n}\n\nexport function findComponentParent(\n vnode: VNode,\n root: ComponentInternalInstance\n): _ComponentInternalInstance | null {\n // Walk the tree from root until we find the child vnode\n const stack = new Set<VNode>()\n const walk = (children: _VNode[]): boolean => {\n for (const child of children) {\n if (!child) continue\n\n if (child === vnode || (child.el && vnode.el && child.el === vnode.el)) {\n return true\n }\n\n stack.add(child)\n let result\n if (child.suspense) {\n result = walk([child.ssContent!])\n } else if (Array.isArray(child.children)) {\n result = walk(child.children as VNode[])\n } else if (child.component?.vnode) {\n result = walk([child.component?.subTree])\n }\n if (result) {\n return result\n }\n stack.delete(child)\n }\n\n return false\n }\n if (!walk([root.subTree])) {\n console.error('Could not find original vnode, will not inherit provides')\n return root\n }\n\n // Return the first component parent\n const result = Array.from(stack).reverse()\n for (const child of result) {\n if (child.component) {\n return child.component\n }\n }\n return root\n}\n\n/**\n * Creates a floating UI directive (tooltip or popover) with UID-namespaced state management\n * @param propertyName - The property name for storing state (e.g., '$__tooltip', '$__popover')\n * @param componentDefaultsKey - The key for accessing component defaults (e.g., 'BTooltip', 'BPopover')\n * @param buildProps - Optional function to customize the props passed to bind()\n * @returns A Vue directive object\n */\nexport function createFloatingDirective(\n propertyName: string,\n componentDefaultsKey: string,\n buildProps?: (\n text: {title?: string; body?: string},\n defaults: unknown,\n binding: Readonly<DirectiveBinding>,\n el: Readonly<HTMLElement>\n ) => BPopoverProps\n): Directive<ElementWithPopper> {\n return {\n mounted(el, binding, vnode) {\n const uid = getDirectiveUid(binding)\n const defaultsMap = (findProvides(binding, vnode) as Record<symbol, Ref>)[defaultsKey]\n ?.value as Record<string, unknown> | undefined\n const isActive = resolveActiveStatus(binding.value)\n if (!isActive) return\n\n const text = resolveContent(binding.value, el)\n\n if (!text.body && !text.title) return\n\n // Initialize per-instance state with UID namespacing\n initDirectiveInstance(el, propertyName, uid, binding)\n\n const props = buildProps\n ? buildProps(text, defaultsMap?.[componentDefaultsKey], binding, el)\n : {\n ...(defaultsMap?.[componentDefaultsKey] || undefined),\n ...resolveDirectiveProps(binding, el),\n ...text,\n }\n\n bind(el, binding, props)\n },\n\n updated(el, binding, vnode) {\n const uid = getDirectiveUid(binding)\n let instance = getDirectiveInstance(el, propertyName, uid)\n\n const defaultsMap = (findProvides(binding, vnode) as Record<symbol, Ref>)[defaultsKey]\n ?.value as Record<string, unknown> | undefined\n\n const isActive = resolveActiveStatus(binding.value)\n\n // If inactive, clean up existing instance if present\n if (!isActive) {\n if (instance && el.$__element) {\n unbind(el)\n cleanupDirectiveInstance(el, propertyName, uid)\n }\n return\n }\n\n const text = resolveContent(binding.value, el)\n\n if (!text.body && !text.title) {\n // Clean up if no content\n if (instance && el.$__element) {\n unbind(el)\n cleanupDirectiveInstance(el, propertyName, uid)\n }\n return\n }\n\n // If instance doesn't exist, this is a transition from inactive/no-content to active\n // Initialize the instance now (similar to mounted)\n if (!instance) {\n instance = initDirectiveInstance(el, propertyName, uid, binding)\n\n const props = buildProps\n ? buildProps(text, defaultsMap?.[componentDefaultsKey], binding, el)\n : {\n ...(defaultsMap?.[componentDefaultsKey] || undefined),\n ...resolveDirectiveProps(binding, el),\n ...text,\n }\n\n bind(el, binding, props)\n return\n }\n\n // Check if binding changed for THIS instance\n if (!hasBindingChanged(instance, binding)) return\n\n // Prevent race conditions during update\n if (instance.destroying) return\n\n unbind(el)\n\n const props = buildProps\n ? buildProps(text, defaultsMap?.[componentDefaultsKey], binding, el)\n : {\n ...(defaultsMap?.[componentDefaultsKey] || undefined),\n ...resolveDirectiveProps(binding, el),\n ...text,\n }\n\n bind(el, binding, props)\n\n // Update THIS instance's cache\n updateBindingCache(instance, binding)\n },\n\n beforeUnmount(el, binding) {\n const uid = getDirectiveUid(binding)\n const instance = getDirectiveInstance(el, propertyName, uid)\n\n if (!instance) return\n\n unbind(el)\n cleanupDirectiveInstance(el, propertyName, uid)\n },\n }\n}\n"],"mappings":"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"}