@coreui/react 5.7.0 → 5.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (848) hide show
  1. package/README.md +1 -1
  2. package/dist/cjs/components/accordion/CAccordion.js +5 -5
  3. package/dist/cjs/components/accordion/CAccordion.js.map +1 -1
  4. package/dist/cjs/components/accordion/CAccordionBody.js +4 -4
  5. package/dist/cjs/components/accordion/CAccordionBody.js.map +1 -1
  6. package/dist/cjs/components/accordion/CAccordionButton.js +4 -4
  7. package/dist/cjs/components/accordion/CAccordionButton.js.map +1 -1
  8. package/dist/cjs/components/accordion/CAccordionContext.js +1 -1
  9. package/dist/cjs/components/accordion/CAccordionContext.js.map +1 -1
  10. package/dist/cjs/components/accordion/CAccordionHeader.js +3 -3
  11. package/dist/cjs/components/accordion/CAccordionHeader.js.map +1 -1
  12. package/dist/cjs/components/accordion/CAccordionItem.js +11 -11
  13. package/dist/cjs/components/accordion/CAccordionItem.js.map +1 -1
  14. package/dist/cjs/components/accordion/CAccordionItemContext.js +1 -1
  15. package/dist/cjs/components/accordion/CAccordionItemContext.js.map +1 -1
  16. package/dist/cjs/components/alert/CAlert.js +8 -8
  17. package/dist/cjs/components/alert/CAlert.js.map +1 -1
  18. package/dist/cjs/components/alert/CAlertHeading.js +3 -3
  19. package/dist/cjs/components/alert/CAlertHeading.js.map +1 -1
  20. package/dist/cjs/components/alert/CAlertLink.js +3 -3
  21. package/dist/cjs/components/alert/CAlertLink.js.map +1 -1
  22. package/dist/cjs/components/avatar/CAvatar.js +8 -9
  23. package/dist/cjs/components/avatar/CAvatar.js.map +1 -1
  24. package/dist/cjs/components/backdrop/CBackdrop.js +6 -6
  25. package/dist/cjs/components/backdrop/CBackdrop.js.map +1 -1
  26. package/dist/cjs/components/badge/CBadge.js +13 -14
  27. package/dist/cjs/components/badge/CBadge.js.map +1 -1
  28. package/dist/cjs/components/breadcrumb/CBreadcrumb.js +3 -3
  29. package/dist/cjs/components/breadcrumb/CBreadcrumb.js.map +1 -1
  30. package/dist/cjs/components/breadcrumb/CBreadcrumbItem.js +3 -3
  31. package/dist/cjs/components/breadcrumb/CBreadcrumbItem.js.map +1 -1
  32. package/dist/cjs/components/button/CButton.js +8 -7
  33. package/dist/cjs/components/button/CButton.js.map +1 -1
  34. package/dist/cjs/components/button-group/CButtonGroup.js +3 -4
  35. package/dist/cjs/components/button-group/CButtonGroup.js.map +1 -1
  36. package/dist/cjs/components/button-group/CButtonToolbar.js +3 -3
  37. package/dist/cjs/components/button-group/CButtonToolbar.js.map +1 -1
  38. package/dist/cjs/components/callout/CCallout.js +5 -6
  39. package/dist/cjs/components/callout/CCallout.js.map +1 -1
  40. package/dist/cjs/components/card/CCard.js +7 -8
  41. package/dist/cjs/components/card/CCard.js.map +1 -1
  42. package/dist/cjs/components/card/CCardBody.js +3 -3
  43. package/dist/cjs/components/card/CCardBody.js.map +1 -1
  44. package/dist/cjs/components/card/CCardFooter.js +3 -3
  45. package/dist/cjs/components/card/CCardFooter.js.map +1 -1
  46. package/dist/cjs/components/card/CCardGroup.js +3 -3
  47. package/dist/cjs/components/card/CCardGroup.js.map +1 -1
  48. package/dist/cjs/components/card/CCardHeader.js +3 -3
  49. package/dist/cjs/components/card/CCardHeader.js.map +1 -1
  50. package/dist/cjs/components/card/CCardImage.js +3 -3
  51. package/dist/cjs/components/card/CCardImage.js.map +1 -1
  52. package/dist/cjs/components/card/CCardImageOverlay.js +3 -3
  53. package/dist/cjs/components/card/CCardImageOverlay.js.map +1 -1
  54. package/dist/cjs/components/card/CCardLink.js +3 -3
  55. package/dist/cjs/components/card/CCardLink.js.map +1 -1
  56. package/dist/cjs/components/card/CCardSubtitle.js +3 -3
  57. package/dist/cjs/components/card/CCardSubtitle.js.map +1 -1
  58. package/dist/cjs/components/card/CCardText.js +3 -3
  59. package/dist/cjs/components/card/CCardText.js.map +1 -1
  60. package/dist/cjs/components/card/CCardTitle.js +3 -3
  61. package/dist/cjs/components/card/CCardTitle.js.map +1 -1
  62. package/dist/cjs/components/carousel/CCarousel.js +41 -41
  63. package/dist/cjs/components/carousel/CCarousel.js.map +1 -1
  64. package/dist/cjs/components/carousel/CCarouselCaption.js +3 -3
  65. package/dist/cjs/components/carousel/CCarouselCaption.js.map +1 -1
  66. package/dist/cjs/components/carousel/CCarouselContext.js +1 -1
  67. package/dist/cjs/components/carousel/CCarouselContext.js.map +1 -1
  68. package/dist/cjs/components/carousel/CCarouselItem.js +21 -21
  69. package/dist/cjs/components/carousel/CCarouselItem.js.map +1 -1
  70. package/dist/cjs/components/close-button/CCloseButton.js +3 -3
  71. package/dist/cjs/components/close-button/CCloseButton.js.map +1 -1
  72. package/dist/cjs/components/collapse/CCollapse.js +16 -16
  73. package/dist/cjs/components/collapse/CCollapse.js.map +1 -1
  74. package/dist/cjs/components/conditional-portal/CConditionalPortal.js +4 -5
  75. package/dist/cjs/components/conditional-portal/CConditionalPortal.js.map +1 -1
  76. package/dist/cjs/components/dropdown/CDropdown.d.ts +20 -9
  77. package/dist/cjs/components/dropdown/CDropdown.js +127 -93
  78. package/dist/cjs/components/dropdown/CDropdown.js.map +1 -1
  79. package/dist/cjs/components/dropdown/CDropdownContext.d.ts +3 -2
  80. package/dist/cjs/components/dropdown/CDropdownContext.js +1 -1
  81. package/dist/cjs/components/dropdown/CDropdownContext.js.map +1 -1
  82. package/dist/cjs/components/dropdown/CDropdownDivider.js +3 -3
  83. package/dist/cjs/components/dropdown/CDropdownDivider.js.map +1 -1
  84. package/dist/cjs/components/dropdown/CDropdownHeader.js +3 -3
  85. package/dist/cjs/components/dropdown/CDropdownHeader.js.map +1 -1
  86. package/dist/cjs/components/dropdown/CDropdownItem.js +3 -3
  87. package/dist/cjs/components/dropdown/CDropdownItem.js.map +1 -1
  88. package/dist/cjs/components/dropdown/CDropdownItemPlain.js +3 -3
  89. package/dist/cjs/components/dropdown/CDropdownItemPlain.js.map +1 -1
  90. package/dist/cjs/components/dropdown/CDropdownMenu.js +6 -6
  91. package/dist/cjs/components/dropdown/CDropdownMenu.js.map +1 -1
  92. package/dist/cjs/components/dropdown/CDropdownToggle.d.ts +7 -3
  93. package/dist/cjs/components/dropdown/CDropdownToggle.js +30 -23
  94. package/dist/cjs/components/dropdown/CDropdownToggle.js.map +1 -1
  95. package/dist/cjs/components/dropdown/utils.js +7 -7
  96. package/dist/cjs/components/dropdown/utils.js.map +1 -1
  97. package/dist/cjs/components/focus-trap/CFocusTrap.d.ts +59 -0
  98. package/dist/cjs/components/focus-trap/CFocusTrap.js +162 -0
  99. package/dist/cjs/components/focus-trap/CFocusTrap.js.map +1 -0
  100. package/dist/cjs/components/focus-trap/index.d.ts +2 -0
  101. package/dist/cjs/components/focus-trap/utils.d.ts +36 -0
  102. package/dist/cjs/components/focus-trap/utils.js +113 -0
  103. package/dist/cjs/components/focus-trap/utils.js.map +1 -0
  104. package/dist/cjs/components/footer/CFooter.js +3 -4
  105. package/dist/cjs/components/footer/CFooter.js.map +1 -1
  106. package/dist/cjs/components/form/CForm.js +3 -3
  107. package/dist/cjs/components/form/CForm.js.map +1 -1
  108. package/dist/cjs/components/form/CFormCheck.js +16 -19
  109. package/dist/cjs/components/form/CFormCheck.js.map +1 -1
  110. package/dist/cjs/components/form/CFormControlValidation.js +2 -4
  111. package/dist/cjs/components/form/CFormControlValidation.js.map +1 -1
  112. package/dist/cjs/components/form/CFormControlWrapper.js +3 -5
  113. package/dist/cjs/components/form/CFormControlWrapper.js.map +1 -1
  114. package/dist/cjs/components/form/CFormFeedback.js +6 -7
  115. package/dist/cjs/components/form/CFormFeedback.js.map +1 -1
  116. package/dist/cjs/components/form/CFormFloating.js +3 -3
  117. package/dist/cjs/components/form/CFormFloating.js.map +1 -1
  118. package/dist/cjs/components/form/CFormInput.js +13 -14
  119. package/dist/cjs/components/form/CFormInput.js.map +1 -1
  120. package/dist/cjs/components/form/CFormLabel.js +3 -3
  121. package/dist/cjs/components/form/CFormLabel.js.map +1 -1
  122. package/dist/cjs/components/form/CFormRange.js +3 -3
  123. package/dist/cjs/components/form/CFormRange.js.map +1 -1
  124. package/dist/cjs/components/form/CFormSelect.js +10 -11
  125. package/dist/cjs/components/form/CFormSelect.js.map +1 -1
  126. package/dist/cjs/components/form/CFormSwitch.js +10 -12
  127. package/dist/cjs/components/form/CFormSwitch.js.map +1 -1
  128. package/dist/cjs/components/form/CFormText.js +3 -3
  129. package/dist/cjs/components/form/CFormText.js.map +1 -1
  130. package/dist/cjs/components/form/CFormTextarea.js +4 -4
  131. package/dist/cjs/components/form/CFormTextarea.js.map +1 -1
  132. package/dist/cjs/components/form/CInputGroup.js +5 -6
  133. package/dist/cjs/components/form/CInputGroup.js.map +1 -1
  134. package/dist/cjs/components/form/CInputGroupText.js +3 -3
  135. package/dist/cjs/components/form/CInputGroupText.js.map +1 -1
  136. package/dist/cjs/components/grid/CCol.js +16 -16
  137. package/dist/cjs/components/grid/CCol.js.map +1 -1
  138. package/dist/cjs/components/grid/CContainer.js +8 -8
  139. package/dist/cjs/components/grid/CContainer.js.map +1 -1
  140. package/dist/cjs/components/grid/CRow.js +13 -13
  141. package/dist/cjs/components/grid/CRow.js.map +1 -1
  142. package/dist/cjs/components/header/CHeader.js +3 -4
  143. package/dist/cjs/components/header/CHeader.js.map +1 -1
  144. package/dist/cjs/components/header/CHeaderBrand.js +3 -3
  145. package/dist/cjs/components/header/CHeaderBrand.js.map +1 -1
  146. package/dist/cjs/components/header/CHeaderDivider.js +3 -3
  147. package/dist/cjs/components/header/CHeaderDivider.js.map +1 -1
  148. package/dist/cjs/components/header/CHeaderNav.js +3 -3
  149. package/dist/cjs/components/header/CHeaderNav.js.map +1 -1
  150. package/dist/cjs/components/header/CHeaderText.js +3 -3
  151. package/dist/cjs/components/header/CHeaderText.js.map +1 -1
  152. package/dist/cjs/components/header/CHeaderToggler.js +3 -3
  153. package/dist/cjs/components/header/CHeaderToggler.js.map +1 -1
  154. package/dist/cjs/components/image/CImage.js +9 -10
  155. package/dist/cjs/components/image/CImage.js.map +1 -1
  156. package/dist/cjs/components/index.d.ts +1 -0
  157. package/dist/cjs/components/link/CLink.js +5 -5
  158. package/dist/cjs/components/link/CLink.js.map +1 -1
  159. package/dist/cjs/components/list-group/CListGroup.js +6 -8
  160. package/dist/cjs/components/list-group/CListGroup.js.map +1 -1
  161. package/dist/cjs/components/list-group/CListGroupItem.js +13 -14
  162. package/dist/cjs/components/list-group/CListGroupItem.js.map +1 -1
  163. package/dist/cjs/components/modal/CModal.js +26 -34
  164. package/dist/cjs/components/modal/CModal.js.map +1 -1
  165. package/dist/cjs/components/modal/CModalBody.js +3 -3
  166. package/dist/cjs/components/modal/CModalBody.js.map +1 -1
  167. package/dist/cjs/components/modal/CModalContent.js +3 -3
  168. package/dist/cjs/components/modal/CModalContent.js.map +1 -1
  169. package/dist/cjs/components/modal/CModalContext.js +1 -1
  170. package/dist/cjs/components/modal/CModalContext.js.map +1 -1
  171. package/dist/cjs/components/modal/CModalDialog.js +9 -11
  172. package/dist/cjs/components/modal/CModalDialog.js.map +1 -1
  173. package/dist/cjs/components/modal/CModalFooter.js +3 -3
  174. package/dist/cjs/components/modal/CModalFooter.js.map +1 -1
  175. package/dist/cjs/components/modal/CModalHeader.js +5 -5
  176. package/dist/cjs/components/modal/CModalHeader.js.map +1 -1
  177. package/dist/cjs/components/modal/CModalTitle.js +3 -3
  178. package/dist/cjs/components/modal/CModalTitle.js.map +1 -1
  179. package/dist/cjs/components/nav/CNav.js +7 -7
  180. package/dist/cjs/components/nav/CNav.js.map +1 -1
  181. package/dist/cjs/components/nav/CNavGroup.js +24 -24
  182. package/dist/cjs/components/nav/CNavGroup.js.map +1 -1
  183. package/dist/cjs/components/nav/CNavGroupItems.js +3 -3
  184. package/dist/cjs/components/nav/CNavGroupItems.js.map +1 -1
  185. package/dist/cjs/components/nav/CNavItem.js +3 -3
  186. package/dist/cjs/components/nav/CNavItem.js.map +1 -1
  187. package/dist/cjs/components/nav/CNavLink.js +7 -7
  188. package/dist/cjs/components/nav/CNavLink.js.map +1 -1
  189. package/dist/cjs/components/nav/CNavTitle.js +3 -3
  190. package/dist/cjs/components/nav/CNavTitle.js.map +1 -1
  191. package/dist/cjs/components/navbar/CNavbar.js +6 -7
  192. package/dist/cjs/components/navbar/CNavbar.js.map +1 -1
  193. package/dist/cjs/components/navbar/CNavbarBrand.js +4 -4
  194. package/dist/cjs/components/navbar/CNavbarBrand.js.map +1 -1
  195. package/dist/cjs/components/navbar/CNavbarNav.js +3 -3
  196. package/dist/cjs/components/navbar/CNavbarNav.js.map +1 -1
  197. package/dist/cjs/components/navbar/CNavbarText.js +3 -3
  198. package/dist/cjs/components/navbar/CNavbarText.js.map +1 -1
  199. package/dist/cjs/components/navbar/CNavbarToggler.js +3 -3
  200. package/dist/cjs/components/navbar/CNavbarToggler.js.map +1 -1
  201. package/dist/cjs/components/offcanvas/COffcanvas.js +20 -21
  202. package/dist/cjs/components/offcanvas/COffcanvas.js.map +1 -1
  203. package/dist/cjs/components/offcanvas/COffcanvasBody.js +3 -3
  204. package/dist/cjs/components/offcanvas/COffcanvasBody.js.map +1 -1
  205. package/dist/cjs/components/offcanvas/COffcanvasHeader.js +3 -3
  206. package/dist/cjs/components/offcanvas/COffcanvasHeader.js.map +1 -1
  207. package/dist/cjs/components/offcanvas/COffcanvasTitle.js +3 -3
  208. package/dist/cjs/components/offcanvas/COffcanvasTitle.js.map +1 -1
  209. package/dist/cjs/components/pagination/CPagination.js +7 -8
  210. package/dist/cjs/components/pagination/CPagination.js.map +1 -1
  211. package/dist/cjs/components/pagination/CPaginationItem.js +5 -5
  212. package/dist/cjs/components/pagination/CPaginationItem.js.map +1 -1
  213. package/dist/cjs/components/placeholder/CPlaceholder.js +13 -14
  214. package/dist/cjs/components/placeholder/CPlaceholder.js.map +1 -1
  215. package/dist/cjs/components/popover/CPopover.js +29 -29
  216. package/dist/cjs/components/popover/CPopover.js.map +1 -1
  217. package/dist/cjs/components/progress/CProgress.js +8 -8
  218. package/dist/cjs/components/progress/CProgress.js.map +1 -1
  219. package/dist/cjs/components/progress/CProgressBar.js +8 -9
  220. package/dist/cjs/components/progress/CProgressBar.js.map +1 -1
  221. package/dist/cjs/components/progress/CProgressStacked.js +3 -3
  222. package/dist/cjs/components/progress/CProgressStacked.js.map +1 -1
  223. package/dist/cjs/components/progress/CProgressStackedContext.js +1 -1
  224. package/dist/cjs/components/progress/CProgressStackedContext.js.map +1 -1
  225. package/dist/cjs/components/sidebar/CSidebar.js +34 -37
  226. package/dist/cjs/components/sidebar/CSidebar.js.map +1 -1
  227. package/dist/cjs/components/sidebar/CSidebarBrand.js +3 -3
  228. package/dist/cjs/components/sidebar/CSidebarBrand.js.map +1 -1
  229. package/dist/cjs/components/sidebar/CSidebarFooter.js +3 -3
  230. package/dist/cjs/components/sidebar/CSidebarFooter.js.map +1 -1
  231. package/dist/cjs/components/sidebar/CSidebarHeader.js +3 -3
  232. package/dist/cjs/components/sidebar/CSidebarHeader.js.map +1 -1
  233. package/dist/cjs/components/sidebar/CSidebarNav.js +14 -14
  234. package/dist/cjs/components/sidebar/CSidebarNav.js.map +1 -1
  235. package/dist/cjs/components/sidebar/CSidebarNavContext.js +1 -1
  236. package/dist/cjs/components/sidebar/CSidebarNavContext.js.map +1 -1
  237. package/dist/cjs/components/sidebar/CSidebarToggler.js +3 -3
  238. package/dist/cjs/components/sidebar/CSidebarToggler.js.map +1 -1
  239. package/dist/cjs/components/spinner/CSpinner.js +6 -7
  240. package/dist/cjs/components/spinner/CSpinner.js.map +1 -1
  241. package/dist/cjs/components/table/CTable.js +25 -26
  242. package/dist/cjs/components/table/CTable.js.map +1 -1
  243. package/dist/cjs/components/table/CTableBody.js +5 -6
  244. package/dist/cjs/components/table/CTableBody.js.map +1 -1
  245. package/dist/cjs/components/table/CTableCaption.js +3 -3
  246. package/dist/cjs/components/table/CTableCaption.js.map +1 -1
  247. package/dist/cjs/components/table/CTableDataCell.js +8 -9
  248. package/dist/cjs/components/table/CTableDataCell.js.map +1 -1
  249. package/dist/cjs/components/table/CTableFoot.js +5 -6
  250. package/dist/cjs/components/table/CTableFoot.js.map +1 -1
  251. package/dist/cjs/components/table/CTableHead.js +5 -6
  252. package/dist/cjs/components/table/CTableHead.js.map +1 -1
  253. package/dist/cjs/components/table/CTableHeaderCell.js +5 -6
  254. package/dist/cjs/components/table/CTableHeaderCell.js.map +1 -1
  255. package/dist/cjs/components/table/CTableResponsiveWrapper.js +3 -3
  256. package/dist/cjs/components/table/CTableResponsiveWrapper.js.map +1 -1
  257. package/dist/cjs/components/table/CTableRow.js +7 -8
  258. package/dist/cjs/components/table/CTableRow.js.map +1 -1
  259. package/dist/cjs/components/table/utils.js +9 -13
  260. package/dist/cjs/components/table/utils.js.map +1 -1
  261. package/dist/cjs/components/tabs/CTab.js +6 -6
  262. package/dist/cjs/components/tabs/CTab.js.map +1 -1
  263. package/dist/cjs/components/tabs/CTabContent.js +3 -3
  264. package/dist/cjs/components/tabs/CTabContent.js.map +1 -1
  265. package/dist/cjs/components/tabs/CTabList.js +13 -13
  266. package/dist/cjs/components/tabs/CTabList.js.map +1 -1
  267. package/dist/cjs/components/tabs/CTabPane.js +6 -6
  268. package/dist/cjs/components/tabs/CTabPane.js.map +1 -1
  269. package/dist/cjs/components/tabs/CTabPanel.js +10 -10
  270. package/dist/cjs/components/tabs/CTabPanel.js.map +1 -1
  271. package/dist/cjs/components/tabs/CTabs.js +7 -8
  272. package/dist/cjs/components/tabs/CTabs.js.map +1 -1
  273. package/dist/cjs/components/tabs/CTabsContext.js +1 -1
  274. package/dist/cjs/components/tabs/CTabsContext.js.map +1 -1
  275. package/dist/cjs/components/toast/CToast.js +21 -25
  276. package/dist/cjs/components/toast/CToast.js.map +1 -1
  277. package/dist/cjs/components/toast/CToastBody.js +3 -3
  278. package/dist/cjs/components/toast/CToastBody.js.map +1 -1
  279. package/dist/cjs/components/toast/CToastClose.js +5 -5
  280. package/dist/cjs/components/toast/CToastClose.js.map +1 -1
  281. package/dist/cjs/components/toast/CToastContext.js +1 -1
  282. package/dist/cjs/components/toast/CToastContext.js.map +1 -1
  283. package/dist/cjs/components/toast/CToastHeader.js +3 -3
  284. package/dist/cjs/components/toast/CToastHeader.js.map +1 -1
  285. package/dist/cjs/components/toast/CToaster.js +12 -13
  286. package/dist/cjs/components/toast/CToaster.js.map +1 -1
  287. package/dist/cjs/components/tooltip/CTooltip.js +30 -30
  288. package/dist/cjs/components/tooltip/CTooltip.js.map +1 -1
  289. package/dist/cjs/components/widgets/CWidgetStatsA.js +3 -4
  290. package/dist/cjs/components/widgets/CWidgetStatsA.js.map +1 -1
  291. package/dist/cjs/components/widgets/CWidgetStatsB.js +4 -4
  292. package/dist/cjs/components/widgets/CWidgetStatsB.js.map +1 -1
  293. package/dist/cjs/components/widgets/CWidgetStatsC.js +4 -4
  294. package/dist/cjs/components/widgets/CWidgetStatsC.js.map +1 -1
  295. package/dist/cjs/components/widgets/CWidgetStatsD.js +7 -8
  296. package/dist/cjs/components/widgets/CWidgetStatsD.js.map +1 -1
  297. package/dist/cjs/components/widgets/CWidgetStatsE.js +3 -3
  298. package/dist/cjs/components/widgets/CWidgetStatsE.js.map +1 -1
  299. package/dist/cjs/components/widgets/CWidgetStatsF.js +6 -6
  300. package/dist/cjs/components/widgets/CWidgetStatsF.js.map +1 -1
  301. package/dist/cjs/hooks/useClipboard.js +21 -33
  302. package/dist/cjs/hooks/useClipboard.js.map +1 -1
  303. package/dist/cjs/hooks/useColorModes.js +15 -20
  304. package/dist/cjs/hooks/useColorModes.js.map +1 -1
  305. package/dist/cjs/hooks/useForkedRef.js +6 -10
  306. package/dist/cjs/hooks/useForkedRef.js.map +1 -1
  307. package/dist/cjs/hooks/usePopper.js +11 -11
  308. package/dist/cjs/hooks/usePopper.js.map +1 -1
  309. package/dist/cjs/index.js +2 -0
  310. package/dist/cjs/index.js.map +1 -1
  311. package/dist/cjs/node_modules/@babel/runtime/helpers/esm/extends.js.map +1 -1
  312. package/dist/cjs/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js.map +1 -1
  313. package/dist/cjs/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js.map +1 -1
  314. package/dist/cjs/node_modules/classnames/index.js.map +1 -1
  315. package/dist/cjs/node_modules/dom-helpers/esm/removeClass.js.map +1 -1
  316. package/dist/cjs/node_modules/react-transition-group/esm/CSSTransition.js.map +1 -1
  317. package/dist/cjs/node_modules/react-transition-group/esm/Transition.js.map +1 -1
  318. package/dist/cjs/node_modules/tslib/tslib.es6.js +0 -51
  319. package/dist/cjs/node_modules/tslib/tslib.es6.js.map +1 -1
  320. package/dist/cjs/props.js +6 -6
  321. package/dist/cjs/props.js.map +1 -1
  322. package/dist/cjs/utils/executeAfterTransition.js +8 -10
  323. package/dist/cjs/utils/executeAfterTransition.js.map +1 -1
  324. package/dist/cjs/utils/getNextActiveElement.js +3 -3
  325. package/dist/cjs/utils/getNextActiveElement.js.map +1 -1
  326. package/dist/cjs/utils/getRTLPlacement.js +1 -1
  327. package/dist/cjs/utils/getRTLPlacement.js.map +1 -1
  328. package/dist/cjs/utils/getTransitionDurationFromElement.js +4 -4
  329. package/dist/cjs/utils/getTransitionDurationFromElement.js.map +1 -1
  330. package/dist/cjs/utils/isInViewport.js +2 -2
  331. package/dist/cjs/utils/isInViewport.js.map +1 -1
  332. package/dist/cjs/utils/isRTL.js +1 -1
  333. package/dist/cjs/utils/isRTL.js.map +1 -1
  334. package/dist/esm/components/accordion/CAccordion.js +6 -6
  335. package/dist/esm/components/accordion/CAccordion.js.map +1 -1
  336. package/dist/esm/components/accordion/CAccordionBody.js +5 -5
  337. package/dist/esm/components/accordion/CAccordionBody.js.map +1 -1
  338. package/dist/esm/components/accordion/CAccordionButton.js +5 -5
  339. package/dist/esm/components/accordion/CAccordionButton.js.map +1 -1
  340. package/dist/esm/components/accordion/CAccordionContext.js +1 -1
  341. package/dist/esm/components/accordion/CAccordionContext.js.map +1 -1
  342. package/dist/esm/components/accordion/CAccordionHeader.js +4 -4
  343. package/dist/esm/components/accordion/CAccordionHeader.js.map +1 -1
  344. package/dist/esm/components/accordion/CAccordionItem.js +12 -12
  345. package/dist/esm/components/accordion/CAccordionItem.js.map +1 -1
  346. package/dist/esm/components/accordion/CAccordionItemContext.js +1 -1
  347. package/dist/esm/components/accordion/CAccordionItemContext.js.map +1 -1
  348. package/dist/esm/components/alert/CAlert.js +9 -9
  349. package/dist/esm/components/alert/CAlert.js.map +1 -1
  350. package/dist/esm/components/alert/CAlertHeading.js +4 -4
  351. package/dist/esm/components/alert/CAlertHeading.js.map +1 -1
  352. package/dist/esm/components/alert/CAlertLink.js +4 -4
  353. package/dist/esm/components/alert/CAlertLink.js.map +1 -1
  354. package/dist/esm/components/avatar/CAvatar.js +9 -10
  355. package/dist/esm/components/avatar/CAvatar.js.map +1 -1
  356. package/dist/esm/components/backdrop/CBackdrop.js +7 -7
  357. package/dist/esm/components/backdrop/CBackdrop.js.map +1 -1
  358. package/dist/esm/components/badge/CBadge.js +14 -15
  359. package/dist/esm/components/badge/CBadge.js.map +1 -1
  360. package/dist/esm/components/breadcrumb/CBreadcrumb.js +4 -4
  361. package/dist/esm/components/breadcrumb/CBreadcrumb.js.map +1 -1
  362. package/dist/esm/components/breadcrumb/CBreadcrumbItem.js +4 -4
  363. package/dist/esm/components/breadcrumb/CBreadcrumbItem.js.map +1 -1
  364. package/dist/esm/components/button/CButton.js +9 -8
  365. package/dist/esm/components/button/CButton.js.map +1 -1
  366. package/dist/esm/components/button-group/CButtonGroup.js +4 -5
  367. package/dist/esm/components/button-group/CButtonGroup.js.map +1 -1
  368. package/dist/esm/components/button-group/CButtonToolbar.js +4 -4
  369. package/dist/esm/components/button-group/CButtonToolbar.js.map +1 -1
  370. package/dist/esm/components/callout/CCallout.js +6 -7
  371. package/dist/esm/components/callout/CCallout.js.map +1 -1
  372. package/dist/esm/components/card/CCard.js +8 -9
  373. package/dist/esm/components/card/CCard.js.map +1 -1
  374. package/dist/esm/components/card/CCardBody.js +4 -4
  375. package/dist/esm/components/card/CCardBody.js.map +1 -1
  376. package/dist/esm/components/card/CCardFooter.js +4 -4
  377. package/dist/esm/components/card/CCardFooter.js.map +1 -1
  378. package/dist/esm/components/card/CCardGroup.js +4 -4
  379. package/dist/esm/components/card/CCardGroup.js.map +1 -1
  380. package/dist/esm/components/card/CCardHeader.js +4 -4
  381. package/dist/esm/components/card/CCardHeader.js.map +1 -1
  382. package/dist/esm/components/card/CCardImage.js +4 -4
  383. package/dist/esm/components/card/CCardImage.js.map +1 -1
  384. package/dist/esm/components/card/CCardImageOverlay.js +4 -4
  385. package/dist/esm/components/card/CCardImageOverlay.js.map +1 -1
  386. package/dist/esm/components/card/CCardLink.js +4 -4
  387. package/dist/esm/components/card/CCardLink.js.map +1 -1
  388. package/dist/esm/components/card/CCardSubtitle.js +4 -4
  389. package/dist/esm/components/card/CCardSubtitle.js.map +1 -1
  390. package/dist/esm/components/card/CCardText.js +4 -4
  391. package/dist/esm/components/card/CCardText.js.map +1 -1
  392. package/dist/esm/components/card/CCardTitle.js +4 -4
  393. package/dist/esm/components/card/CCardTitle.js.map +1 -1
  394. package/dist/esm/components/carousel/CCarousel.js +42 -42
  395. package/dist/esm/components/carousel/CCarousel.js.map +1 -1
  396. package/dist/esm/components/carousel/CCarouselCaption.js +4 -4
  397. package/dist/esm/components/carousel/CCarouselCaption.js.map +1 -1
  398. package/dist/esm/components/carousel/CCarouselContext.js +1 -1
  399. package/dist/esm/components/carousel/CCarouselContext.js.map +1 -1
  400. package/dist/esm/components/carousel/CCarouselItem.js +22 -22
  401. package/dist/esm/components/carousel/CCarouselItem.js.map +1 -1
  402. package/dist/esm/components/close-button/CCloseButton.js +4 -4
  403. package/dist/esm/components/close-button/CCloseButton.js.map +1 -1
  404. package/dist/esm/components/collapse/CCollapse.js +17 -17
  405. package/dist/esm/components/collapse/CCollapse.js.map +1 -1
  406. package/dist/esm/components/conditional-portal/CConditionalPortal.js +4 -5
  407. package/dist/esm/components/conditional-portal/CConditionalPortal.js.map +1 -1
  408. package/dist/esm/components/dropdown/CDropdown.d.ts +20 -9
  409. package/dist/esm/components/dropdown/CDropdown.js +129 -95
  410. package/dist/esm/components/dropdown/CDropdown.js.map +1 -1
  411. package/dist/esm/components/dropdown/CDropdownContext.d.ts +3 -2
  412. package/dist/esm/components/dropdown/CDropdownContext.js +1 -1
  413. package/dist/esm/components/dropdown/CDropdownContext.js.map +1 -1
  414. package/dist/esm/components/dropdown/CDropdownDivider.js +4 -4
  415. package/dist/esm/components/dropdown/CDropdownDivider.js.map +1 -1
  416. package/dist/esm/components/dropdown/CDropdownHeader.js +4 -4
  417. package/dist/esm/components/dropdown/CDropdownHeader.js.map +1 -1
  418. package/dist/esm/components/dropdown/CDropdownItem.js +4 -4
  419. package/dist/esm/components/dropdown/CDropdownItem.js.map +1 -1
  420. package/dist/esm/components/dropdown/CDropdownItemPlain.js +4 -4
  421. package/dist/esm/components/dropdown/CDropdownItemPlain.js.map +1 -1
  422. package/dist/esm/components/dropdown/CDropdownMenu.js +7 -7
  423. package/dist/esm/components/dropdown/CDropdownMenu.js.map +1 -1
  424. package/dist/esm/components/dropdown/CDropdownToggle.d.ts +7 -3
  425. package/dist/esm/components/dropdown/CDropdownToggle.js +31 -24
  426. package/dist/esm/components/dropdown/CDropdownToggle.js.map +1 -1
  427. package/dist/esm/components/dropdown/utils.js +7 -7
  428. package/dist/esm/components/dropdown/utils.js.map +1 -1
  429. package/dist/esm/components/focus-trap/CFocusTrap.d.ts +59 -0
  430. package/dist/esm/components/focus-trap/CFocusTrap.js +160 -0
  431. package/dist/esm/components/focus-trap/CFocusTrap.js.map +1 -0
  432. package/dist/esm/components/focus-trap/index.d.ts +2 -0
  433. package/dist/esm/components/focus-trap/utils.d.ts +36 -0
  434. package/dist/esm/components/focus-trap/utils.js +107 -0
  435. package/dist/esm/components/focus-trap/utils.js.map +1 -0
  436. package/dist/esm/components/footer/CFooter.js +4 -5
  437. package/dist/esm/components/footer/CFooter.js.map +1 -1
  438. package/dist/esm/components/form/CForm.js +4 -4
  439. package/dist/esm/components/form/CForm.js.map +1 -1
  440. package/dist/esm/components/form/CFormCheck.js +17 -20
  441. package/dist/esm/components/form/CFormCheck.js.map +1 -1
  442. package/dist/esm/components/form/CFormControlValidation.js +2 -4
  443. package/dist/esm/components/form/CFormControlValidation.js.map +1 -1
  444. package/dist/esm/components/form/CFormControlWrapper.js +3 -5
  445. package/dist/esm/components/form/CFormControlWrapper.js.map +1 -1
  446. package/dist/esm/components/form/CFormFeedback.js +7 -8
  447. package/dist/esm/components/form/CFormFeedback.js.map +1 -1
  448. package/dist/esm/components/form/CFormFloating.js +4 -4
  449. package/dist/esm/components/form/CFormFloating.js.map +1 -1
  450. package/dist/esm/components/form/CFormInput.js +14 -15
  451. package/dist/esm/components/form/CFormInput.js.map +1 -1
  452. package/dist/esm/components/form/CFormLabel.js +4 -4
  453. package/dist/esm/components/form/CFormLabel.js.map +1 -1
  454. package/dist/esm/components/form/CFormRange.js +4 -4
  455. package/dist/esm/components/form/CFormRange.js.map +1 -1
  456. package/dist/esm/components/form/CFormSelect.js +11 -12
  457. package/dist/esm/components/form/CFormSelect.js.map +1 -1
  458. package/dist/esm/components/form/CFormSwitch.js +11 -13
  459. package/dist/esm/components/form/CFormSwitch.js.map +1 -1
  460. package/dist/esm/components/form/CFormText.js +4 -4
  461. package/dist/esm/components/form/CFormText.js.map +1 -1
  462. package/dist/esm/components/form/CFormTextarea.js +5 -5
  463. package/dist/esm/components/form/CFormTextarea.js.map +1 -1
  464. package/dist/esm/components/form/CInputGroup.js +6 -7
  465. package/dist/esm/components/form/CInputGroup.js.map +1 -1
  466. package/dist/esm/components/form/CInputGroupText.js +4 -4
  467. package/dist/esm/components/form/CInputGroupText.js.map +1 -1
  468. package/dist/esm/components/grid/CCol.js +17 -17
  469. package/dist/esm/components/grid/CCol.js.map +1 -1
  470. package/dist/esm/components/grid/CContainer.js +9 -9
  471. package/dist/esm/components/grid/CContainer.js.map +1 -1
  472. package/dist/esm/components/grid/CRow.js +14 -14
  473. package/dist/esm/components/grid/CRow.js.map +1 -1
  474. package/dist/esm/components/header/CHeader.js +4 -5
  475. package/dist/esm/components/header/CHeader.js.map +1 -1
  476. package/dist/esm/components/header/CHeaderBrand.js +4 -4
  477. package/dist/esm/components/header/CHeaderBrand.js.map +1 -1
  478. package/dist/esm/components/header/CHeaderDivider.js +4 -4
  479. package/dist/esm/components/header/CHeaderDivider.js.map +1 -1
  480. package/dist/esm/components/header/CHeaderNav.js +4 -4
  481. package/dist/esm/components/header/CHeaderNav.js.map +1 -1
  482. package/dist/esm/components/header/CHeaderText.js +4 -4
  483. package/dist/esm/components/header/CHeaderText.js.map +1 -1
  484. package/dist/esm/components/header/CHeaderToggler.js +4 -4
  485. package/dist/esm/components/header/CHeaderToggler.js.map +1 -1
  486. package/dist/esm/components/image/CImage.js +10 -11
  487. package/dist/esm/components/image/CImage.js.map +1 -1
  488. package/dist/esm/components/index.d.ts +1 -0
  489. package/dist/esm/components/link/CLink.js +6 -6
  490. package/dist/esm/components/link/CLink.js.map +1 -1
  491. package/dist/esm/components/list-group/CListGroup.js +7 -9
  492. package/dist/esm/components/list-group/CListGroup.js.map +1 -1
  493. package/dist/esm/components/list-group/CListGroupItem.js +14 -15
  494. package/dist/esm/components/list-group/CListGroupItem.js.map +1 -1
  495. package/dist/esm/components/modal/CModal.js +27 -35
  496. package/dist/esm/components/modal/CModal.js.map +1 -1
  497. package/dist/esm/components/modal/CModalBody.js +4 -4
  498. package/dist/esm/components/modal/CModalBody.js.map +1 -1
  499. package/dist/esm/components/modal/CModalContent.js +4 -4
  500. package/dist/esm/components/modal/CModalContent.js.map +1 -1
  501. package/dist/esm/components/modal/CModalContext.js +1 -1
  502. package/dist/esm/components/modal/CModalContext.js.map +1 -1
  503. package/dist/esm/components/modal/CModalDialog.js +10 -12
  504. package/dist/esm/components/modal/CModalDialog.js.map +1 -1
  505. package/dist/esm/components/modal/CModalFooter.js +4 -4
  506. package/dist/esm/components/modal/CModalFooter.js.map +1 -1
  507. package/dist/esm/components/modal/CModalHeader.js +6 -6
  508. package/dist/esm/components/modal/CModalHeader.js.map +1 -1
  509. package/dist/esm/components/modal/CModalTitle.js +4 -4
  510. package/dist/esm/components/modal/CModalTitle.js.map +1 -1
  511. package/dist/esm/components/nav/CNav.js +8 -8
  512. package/dist/esm/components/nav/CNav.js.map +1 -1
  513. package/dist/esm/components/nav/CNavGroup.js +25 -25
  514. package/dist/esm/components/nav/CNavGroup.js.map +1 -1
  515. package/dist/esm/components/nav/CNavGroupItems.js +4 -4
  516. package/dist/esm/components/nav/CNavGroupItems.js.map +1 -1
  517. package/dist/esm/components/nav/CNavItem.js +4 -4
  518. package/dist/esm/components/nav/CNavItem.js.map +1 -1
  519. package/dist/esm/components/nav/CNavLink.js +8 -8
  520. package/dist/esm/components/nav/CNavLink.js.map +1 -1
  521. package/dist/esm/components/nav/CNavTitle.js +4 -4
  522. package/dist/esm/components/nav/CNavTitle.js.map +1 -1
  523. package/dist/esm/components/navbar/CNavbar.js +7 -8
  524. package/dist/esm/components/navbar/CNavbar.js.map +1 -1
  525. package/dist/esm/components/navbar/CNavbarBrand.js +5 -5
  526. package/dist/esm/components/navbar/CNavbarBrand.js.map +1 -1
  527. package/dist/esm/components/navbar/CNavbarNav.js +4 -4
  528. package/dist/esm/components/navbar/CNavbarNav.js.map +1 -1
  529. package/dist/esm/components/navbar/CNavbarText.js +4 -4
  530. package/dist/esm/components/navbar/CNavbarText.js.map +1 -1
  531. package/dist/esm/components/navbar/CNavbarToggler.js +4 -4
  532. package/dist/esm/components/navbar/CNavbarToggler.js.map +1 -1
  533. package/dist/esm/components/offcanvas/COffcanvas.js +21 -22
  534. package/dist/esm/components/offcanvas/COffcanvas.js.map +1 -1
  535. package/dist/esm/components/offcanvas/COffcanvasBody.js +4 -4
  536. package/dist/esm/components/offcanvas/COffcanvasBody.js.map +1 -1
  537. package/dist/esm/components/offcanvas/COffcanvasHeader.js +4 -4
  538. package/dist/esm/components/offcanvas/COffcanvasHeader.js.map +1 -1
  539. package/dist/esm/components/offcanvas/COffcanvasTitle.js +4 -4
  540. package/dist/esm/components/offcanvas/COffcanvasTitle.js.map +1 -1
  541. package/dist/esm/components/pagination/CPagination.js +8 -9
  542. package/dist/esm/components/pagination/CPagination.js.map +1 -1
  543. package/dist/esm/components/pagination/CPaginationItem.js +6 -6
  544. package/dist/esm/components/pagination/CPaginationItem.js.map +1 -1
  545. package/dist/esm/components/placeholder/CPlaceholder.js +14 -15
  546. package/dist/esm/components/placeholder/CPlaceholder.js.map +1 -1
  547. package/dist/esm/components/popover/CPopover.js +30 -30
  548. package/dist/esm/components/popover/CPopover.js.map +1 -1
  549. package/dist/esm/components/progress/CProgress.js +9 -9
  550. package/dist/esm/components/progress/CProgress.js.map +1 -1
  551. package/dist/esm/components/progress/CProgressBar.js +9 -10
  552. package/dist/esm/components/progress/CProgressBar.js.map +1 -1
  553. package/dist/esm/components/progress/CProgressStacked.js +4 -4
  554. package/dist/esm/components/progress/CProgressStacked.js.map +1 -1
  555. package/dist/esm/components/progress/CProgressStackedContext.js +1 -1
  556. package/dist/esm/components/progress/CProgressStackedContext.js.map +1 -1
  557. package/dist/esm/components/sidebar/CSidebar.js +35 -38
  558. package/dist/esm/components/sidebar/CSidebar.js.map +1 -1
  559. package/dist/esm/components/sidebar/CSidebarBrand.js +4 -4
  560. package/dist/esm/components/sidebar/CSidebarBrand.js.map +1 -1
  561. package/dist/esm/components/sidebar/CSidebarFooter.js +4 -4
  562. package/dist/esm/components/sidebar/CSidebarFooter.js.map +1 -1
  563. package/dist/esm/components/sidebar/CSidebarHeader.js +4 -4
  564. package/dist/esm/components/sidebar/CSidebarHeader.js.map +1 -1
  565. package/dist/esm/components/sidebar/CSidebarNav.js +15 -15
  566. package/dist/esm/components/sidebar/CSidebarNav.js.map +1 -1
  567. package/dist/esm/components/sidebar/CSidebarNavContext.js +1 -1
  568. package/dist/esm/components/sidebar/CSidebarNavContext.js.map +1 -1
  569. package/dist/esm/components/sidebar/CSidebarToggler.js +4 -4
  570. package/dist/esm/components/sidebar/CSidebarToggler.js.map +1 -1
  571. package/dist/esm/components/spinner/CSpinner.js +7 -8
  572. package/dist/esm/components/spinner/CSpinner.js.map +1 -1
  573. package/dist/esm/components/table/CTable.js +26 -27
  574. package/dist/esm/components/table/CTable.js.map +1 -1
  575. package/dist/esm/components/table/CTableBody.js +6 -7
  576. package/dist/esm/components/table/CTableBody.js.map +1 -1
  577. package/dist/esm/components/table/CTableCaption.js +4 -4
  578. package/dist/esm/components/table/CTableCaption.js.map +1 -1
  579. package/dist/esm/components/table/CTableDataCell.js +9 -10
  580. package/dist/esm/components/table/CTableDataCell.js.map +1 -1
  581. package/dist/esm/components/table/CTableFoot.js +6 -7
  582. package/dist/esm/components/table/CTableFoot.js.map +1 -1
  583. package/dist/esm/components/table/CTableHead.js +6 -7
  584. package/dist/esm/components/table/CTableHead.js.map +1 -1
  585. package/dist/esm/components/table/CTableHeaderCell.js +6 -7
  586. package/dist/esm/components/table/CTableHeaderCell.js.map +1 -1
  587. package/dist/esm/components/table/CTableResponsiveWrapper.js +4 -4
  588. package/dist/esm/components/table/CTableResponsiveWrapper.js.map +1 -1
  589. package/dist/esm/components/table/CTableRow.js +8 -9
  590. package/dist/esm/components/table/CTableRow.js.map +1 -1
  591. package/dist/esm/components/table/utils.js +9 -13
  592. package/dist/esm/components/table/utils.js.map +1 -1
  593. package/dist/esm/components/tabs/CTab.js +7 -7
  594. package/dist/esm/components/tabs/CTab.js.map +1 -1
  595. package/dist/esm/components/tabs/CTabContent.js +4 -4
  596. package/dist/esm/components/tabs/CTabContent.js.map +1 -1
  597. package/dist/esm/components/tabs/CTabList.js +14 -14
  598. package/dist/esm/components/tabs/CTabList.js.map +1 -1
  599. package/dist/esm/components/tabs/CTabPane.js +7 -7
  600. package/dist/esm/components/tabs/CTabPane.js.map +1 -1
  601. package/dist/esm/components/tabs/CTabPanel.js +11 -11
  602. package/dist/esm/components/tabs/CTabPanel.js.map +1 -1
  603. package/dist/esm/components/tabs/CTabs.js +7 -8
  604. package/dist/esm/components/tabs/CTabs.js.map +1 -1
  605. package/dist/esm/components/tabs/CTabsContext.js +1 -1
  606. package/dist/esm/components/tabs/CTabsContext.js.map +1 -1
  607. package/dist/esm/components/toast/CToast.js +22 -26
  608. package/dist/esm/components/toast/CToast.js.map +1 -1
  609. package/dist/esm/components/toast/CToastBody.js +4 -4
  610. package/dist/esm/components/toast/CToastBody.js.map +1 -1
  611. package/dist/esm/components/toast/CToastClose.js +6 -6
  612. package/dist/esm/components/toast/CToastClose.js.map +1 -1
  613. package/dist/esm/components/toast/CToastContext.js +1 -1
  614. package/dist/esm/components/toast/CToastContext.js.map +1 -1
  615. package/dist/esm/components/toast/CToastHeader.js +4 -4
  616. package/dist/esm/components/toast/CToastHeader.js.map +1 -1
  617. package/dist/esm/components/toast/CToaster.js +13 -14
  618. package/dist/esm/components/toast/CToaster.js.map +1 -1
  619. package/dist/esm/components/tooltip/CTooltip.js +31 -31
  620. package/dist/esm/components/tooltip/CTooltip.js.map +1 -1
  621. package/dist/esm/components/widgets/CWidgetStatsA.js +4 -5
  622. package/dist/esm/components/widgets/CWidgetStatsA.js.map +1 -1
  623. package/dist/esm/components/widgets/CWidgetStatsB.js +5 -5
  624. package/dist/esm/components/widgets/CWidgetStatsB.js.map +1 -1
  625. package/dist/esm/components/widgets/CWidgetStatsC.js +5 -5
  626. package/dist/esm/components/widgets/CWidgetStatsC.js.map +1 -1
  627. package/dist/esm/components/widgets/CWidgetStatsD.js +8 -9
  628. package/dist/esm/components/widgets/CWidgetStatsD.js.map +1 -1
  629. package/dist/esm/components/widgets/CWidgetStatsE.js +4 -4
  630. package/dist/esm/components/widgets/CWidgetStatsE.js.map +1 -1
  631. package/dist/esm/components/widgets/CWidgetStatsF.js +7 -7
  632. package/dist/esm/components/widgets/CWidgetStatsF.js.map +1 -1
  633. package/dist/esm/hooks/useClipboard.js +22 -34
  634. package/dist/esm/hooks/useClipboard.js.map +1 -1
  635. package/dist/esm/hooks/useColorModes.js +15 -20
  636. package/dist/esm/hooks/useColorModes.js.map +1 -1
  637. package/dist/esm/hooks/useForkedRef.js +6 -10
  638. package/dist/esm/hooks/useForkedRef.js.map +1 -1
  639. package/dist/esm/hooks/usePopper.js +11 -11
  640. package/dist/esm/hooks/usePopper.js.map +1 -1
  641. package/dist/esm/index.js +1 -0
  642. package/dist/esm/index.js.map +1 -1
  643. package/dist/esm/node_modules/@babel/runtime/helpers/esm/extends.js.map +1 -1
  644. package/dist/esm/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js.map +1 -1
  645. package/dist/esm/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js.map +1 -1
  646. package/dist/esm/node_modules/classnames/index.js.map +1 -1
  647. package/dist/esm/node_modules/dom-helpers/esm/removeClass.js.map +1 -1
  648. package/dist/esm/node_modules/react-transition-group/esm/CSSTransition.js.map +1 -1
  649. package/dist/esm/node_modules/react-transition-group/esm/Transition.js.map +1 -1
  650. package/dist/esm/node_modules/tslib/tslib.es6.js +1 -50
  651. package/dist/esm/node_modules/tslib/tslib.es6.js.map +1 -1
  652. package/dist/esm/props.js +6 -6
  653. package/dist/esm/props.js.map +1 -1
  654. package/dist/esm/utils/executeAfterTransition.js +8 -10
  655. package/dist/esm/utils/executeAfterTransition.js.map +1 -1
  656. package/dist/esm/utils/getNextActiveElement.js +3 -3
  657. package/dist/esm/utils/getNextActiveElement.js.map +1 -1
  658. package/dist/esm/utils/getRTLPlacement.js +1 -1
  659. package/dist/esm/utils/getRTLPlacement.js.map +1 -1
  660. package/dist/esm/utils/getTransitionDurationFromElement.js +4 -4
  661. package/dist/esm/utils/getTransitionDurationFromElement.js.map +1 -1
  662. package/dist/esm/utils/isInViewport.js +2 -2
  663. package/dist/esm/utils/isInViewport.js.map +1 -1
  664. package/dist/esm/utils/isRTL.js +1 -1
  665. package/dist/esm/utils/isRTL.js.map +1 -1
  666. package/package.json +13 -13
  667. package/src/components/accordion/CAccordion.tsx +1 -1
  668. package/src/components/accordion/CAccordionHeader.tsx +1 -1
  669. package/src/components/alert/CAlert.tsx +3 -3
  670. package/src/components/alert/CAlertHeading.tsx +1 -1
  671. package/src/components/alert/CAlertLink.tsx +1 -1
  672. package/src/components/alert/__tests__/CAlertHeading.spec.tsx +1 -1
  673. package/src/components/alert/__tests__/CAlertLink.spec.tsx +1 -1
  674. package/src/components/avatar/CAvatar.tsx +2 -2
  675. package/src/components/avatar/__tests__/CAvatar.spec.tsx +2 -2
  676. package/src/components/backdrop/CBackdrop.tsx +1 -1
  677. package/src/components/backdrop/__tests__/CBackdrop.spec.tsx +1 -1
  678. package/src/components/badge/CBadge.tsx +3 -3
  679. package/src/components/badge/__tests__/CBadge.spec.tsx +1 -1
  680. package/src/components/breadcrumb/CBreadcrumb.tsx +1 -1
  681. package/src/components/breadcrumb/CBreadcrumbItem.tsx +2 -2
  682. package/src/components/breadcrumb/__tests__/CBreadcrumb.spec.tsx +1 -1
  683. package/src/components/breadcrumb/__tests__/CBreadcrumbItem.spec.tsx +1 -1
  684. package/src/components/button/CButton.tsx +3 -2
  685. package/src/components/button/__tests__/CButton.spec.tsx +2 -2
  686. package/src/components/button-group/CButtonGroup.tsx +2 -2
  687. package/src/components/button-group/CButtonToolbar.tsx +1 -1
  688. package/src/components/button-group/__tests__/CButtonGroup.spec.tsx +2 -2
  689. package/src/components/button-group/__tests__/CButtonToolbar.spec.tsx +1 -1
  690. package/src/components/callout/CCallout.tsx +2 -2
  691. package/src/components/callout/__tests__/CCallout.spec.tsx +1 -1
  692. package/src/components/card/CCard.tsx +2 -2
  693. package/src/components/card/CCardBody.tsx +1 -1
  694. package/src/components/card/CCardFooter.tsx +1 -1
  695. package/src/components/card/CCardGroup.tsx +1 -1
  696. package/src/components/card/CCardImageOverlay.tsx +1 -1
  697. package/src/components/card/CCardLink.tsx +1 -1
  698. package/src/components/card/CCardSubtitle.tsx +1 -1
  699. package/src/components/card/__tests__/CCard.spec.tsx +1 -1
  700. package/src/components/card/__tests__/CCardGroup.spec.tsx +1 -1
  701. package/src/components/card/__tests__/CCardHeader.spec.tsx +1 -1
  702. package/src/components/card/__tests__/CCardLink.spec.tsx +1 -1
  703. package/src/components/card/__tests__/CCardSubtitle.spec.tsx +1 -1
  704. package/src/components/card/__tests__/CCardText.spec.tsx +1 -1
  705. package/src/components/card/__tests__/CCardTitle.spec.tsx +1 -1
  706. package/src/components/carousel/__tests__/CCarousel.spec.tsx +3 -3
  707. package/src/components/close-button/CCloseButton.tsx +2 -2
  708. package/src/components/collapse/CCollapse.tsx +1 -1
  709. package/src/components/dropdown/CDropdown.tsx +175 -107
  710. package/src/components/dropdown/CDropdownContext.ts +3 -3
  711. package/src/components/dropdown/CDropdownToggle.tsx +43 -31
  712. package/src/components/dropdown/__tests__/CDropdown.spec.tsx +3 -3
  713. package/src/components/dropdown/__tests__/CDropdownHeader.spec.tsx +1 -1
  714. package/src/components/dropdown/__tests__/CDropdownItem.spec.tsx +1 -1
  715. package/src/components/dropdown/__tests__/CDropdownItemPlain.spec.tsx +1 -1
  716. package/src/components/dropdown/__tests__/CDropdownMenu.spec.tsx +1 -1
  717. package/src/components/dropdown/__tests__/CDropdownToggle.spec.tsx +1 -1
  718. package/src/components/dropdown/utils.ts +2 -2
  719. package/src/components/focus-trap/CFocusTrap.tsx +254 -0
  720. package/src/components/focus-trap/__tests__/CFocusTrap.spec.tsx +232 -0
  721. package/src/components/focus-trap/__tests__/__snapshots__/CFocusTrap.spec.tsx.snap +21 -0
  722. package/src/components/focus-trap/index.ts +3 -0
  723. package/src/components/focus-trap/utils.ts +121 -0
  724. package/src/components/footer/CFooter.tsx +1 -1
  725. package/src/components/footer/__tests__/CFooter.spec.tsx +1 -1
  726. package/src/components/form/CForm.tsx +1 -1
  727. package/src/components/form/CFormCheck.tsx +5 -5
  728. package/src/components/form/CFormFeedback.tsx +2 -2
  729. package/src/components/form/CFormFloating.tsx +1 -1
  730. package/src/components/form/CFormInput.tsx +4 -4
  731. package/src/components/form/CFormLabel.tsx +1 -1
  732. package/src/components/form/CFormRange.tsx +1 -1
  733. package/src/components/form/CFormSelect.tsx +3 -3
  734. package/src/components/form/CFormSwitch.tsx +2 -2
  735. package/src/components/form/CFormTextarea.tsx +3 -3
  736. package/src/components/form/CInputGroup.tsx +2 -2
  737. package/src/components/form/CInputGroupText.tsx +1 -1
  738. package/src/components/form/__tests__/CForm.spec.tsx +2 -2
  739. package/src/components/form/__tests__/CFormCheck.spec.tsx +2 -2
  740. package/src/components/form/__tests__/CFormControl.spec.tsx +1 -1
  741. package/src/components/form/__tests__/CFormFeedback.spec.tsx +2 -2
  742. package/src/components/form/__tests__/CFormInput.spec.tsx +1 -1
  743. package/src/components/form/__tests__/CFormRange.spec.tsx +1 -1
  744. package/src/components/form/__tests__/CFormSelect.spec.tsx +1 -1
  745. package/src/components/form/__tests__/CFormSwitch.spec.tsx +1 -1
  746. package/src/components/form/__tests__/CFormText.spec.tsx +1 -1
  747. package/src/components/form/__tests__/CFormTextarea.spec.tsx +1 -1
  748. package/src/components/form/__tests__/CInputGroup.spec.tsx +1 -1
  749. package/src/components/form/__tests__/CInputGroupText.spec.tsx +1 -1
  750. package/src/components/grid/CCol.tsx +2 -2
  751. package/src/components/grid/CContainer.tsx +2 -2
  752. package/src/components/grid/CRow.tsx +1 -1
  753. package/src/components/grid/__tests__/CCol.spec.tsx +2 -2
  754. package/src/components/grid/__tests__/CContainer.spec.tsx +2 -2
  755. package/src/components/grid/__tests__/CRow.spec.tsx +5 -5
  756. package/src/components/header/CHeader.tsx +1 -1
  757. package/src/components/header/CHeaderDivider.tsx +1 -1
  758. package/src/components/header/CHeaderText.tsx +1 -1
  759. package/src/components/header/CHeaderToggler.tsx +1 -1
  760. package/src/components/header/__tests__/CHeader.spec.tsx +1 -1
  761. package/src/components/header/__tests__/CHeaderBrand.spec.tsx +1 -1
  762. package/src/components/header/__tests__/CHeaderNav.spec.tsx +1 -1
  763. package/src/components/image/CImage.tsx +2 -2
  764. package/src/components/image/__tests__/CImage.spec.tsx +1 -1
  765. package/src/components/index.ts +1 -0
  766. package/src/components/link/__tests__/CLink.spec.tsx +3 -3
  767. package/src/components/list-group/CListGroup.tsx +1 -1
  768. package/src/components/list-group/CListGroupItem.tsx +2 -2
  769. package/src/components/list-group/__tests__/CListGroup.spec.tsx +2 -2
  770. package/src/components/list-group/__tests__/CListGroupItem.spec.tsx +1 -1
  771. package/src/components/modal/CModal.tsx +5 -13
  772. package/src/components/modal/CModalBody.tsx +1 -1
  773. package/src/components/modal/CModalContent.tsx +1 -1
  774. package/src/components/modal/CModalDialog.tsx +2 -2
  775. package/src/components/modal/CModalFooter.tsx +1 -1
  776. package/src/components/modal/CModalHeader.tsx +1 -1
  777. package/src/components/modal/__tests__/CModal.spec.tsx +2 -2
  778. package/src/components/modal/__tests__/CModalDialog.spec.tsx +1 -1
  779. package/src/components/modal/__tests__/CModalTitle.spec.tsx +1 -1
  780. package/src/components/nav/CNavGroup.tsx +2 -2
  781. package/src/components/nav/CNavGroupItems.tsx +1 -1
  782. package/src/components/nav/__tests__/CNavGroup.spec.tsx +1 -1
  783. package/src/components/nav/__tests__/CNavItem.spec.tsx +1 -1
  784. package/src/components/nav/__tests__/CNavLink.spec.tsx +1 -1
  785. package/src/components/navbar/CNavbar.tsx +3 -3
  786. package/src/components/navbar/CNavbarText.tsx +1 -1
  787. package/src/components/navbar/CNavbarToggler.tsx +1 -1
  788. package/src/components/navbar/__tests__/CNavbar.spec.tsx +2 -2
  789. package/src/components/navbar/__tests__/CNavbarBrand.spec.tsx +1 -1
  790. package/src/components/navbar/__tests__/CNavbarNav.spec.tsx +1 -1
  791. package/src/components/offcanvas/COffcanvas.tsx +26 -24
  792. package/src/components/offcanvas/COffcanvasBody.tsx +1 -1
  793. package/src/components/offcanvas/COffcanvasHeader.tsx +1 -1
  794. package/src/components/offcanvas/COffcanvasTitle.tsx +1 -1
  795. package/src/components/offcanvas/__tests__/COffcanvasTitle.spec.tsx +1 -1
  796. package/src/components/pagination/CPagination.tsx +2 -2
  797. package/src/components/pagination/CPaginationItem.tsx +2 -2
  798. package/src/components/pagination/__tests__/CPagination.spec.tsx +2 -2
  799. package/src/components/pagination/__tests__/CPaginationItem.spec.tsx +1 -1
  800. package/src/components/placeholder/CPlaceholder.tsx +2 -2
  801. package/src/components/placeholder/__tests__/CPlaceholder.spec.tsx +1 -1
  802. package/src/components/progress/CProgress.tsx +3 -3
  803. package/src/components/progress/CProgressBar.tsx +2 -2
  804. package/src/components/progress/__tests__/CProgress.spec.tsx +1 -1
  805. package/src/components/progress/__tests__/CProgressBar.spec.tsx +1 -1
  806. package/src/components/sidebar/CSidebarFooter.tsx +1 -1
  807. package/src/components/sidebar/CSidebarHeader.tsx +1 -1
  808. package/src/components/sidebar/CSidebarToggler.tsx +1 -1
  809. package/src/components/sidebar/__tests__/CSidebar.spec.tsx +2 -2
  810. package/src/components/spinner/CSpinner.tsx +3 -3
  811. package/src/components/spinner/__tests__/CSpinner.spec.tsx +1 -1
  812. package/src/components/table/CTable.tsx +3 -3
  813. package/src/components/table/CTableBody.tsx +2 -2
  814. package/src/components/table/CTableDataCell.tsx +2 -2
  815. package/src/components/table/CTableFoot.tsx +2 -2
  816. package/src/components/table/CTableHead.tsx +2 -2
  817. package/src/components/table/CTableHeaderCell.tsx +2 -2
  818. package/src/components/table/CTableRow.tsx +2 -2
  819. package/src/components/table/__tests__/CTable.spec.tsx +2 -2
  820. package/src/components/table/__tests__/CTableBody.spec.tsx +1 -1
  821. package/src/components/table/__tests__/CTableDataCell.spec.tsx +2 -2
  822. package/src/components/table/__tests__/CTableFoot.spec.tsx +1 -1
  823. package/src/components/table/__tests__/CTableHead.spec.tsx +1 -1
  824. package/src/components/table/__tests__/CTableHeaderCell.spec.tsx +2 -2
  825. package/src/components/table/__tests__/CTableRow.spec.tsx +2 -2
  826. package/src/components/tabs/CTab.tsx +2 -2
  827. package/src/components/tabs/CTabContent.tsx +1 -1
  828. package/src/components/tabs/CTabPane.tsx +2 -2
  829. package/src/components/tabs/CTabPanel.tsx +2 -2
  830. package/src/components/toast/CToastBody.tsx +1 -1
  831. package/src/components/toast/CToastHeader.tsx +1 -1
  832. package/src/components/toast/__tests__/CToaster.spec.tsx +2 -2
  833. package/src/components/widgets/CWidgetStatsA.tsx +1 -1
  834. package/src/components/widgets/CWidgetStatsB.tsx +1 -1
  835. package/src/components/widgets/CWidgetStatsC.tsx +2 -2
  836. package/src/components/widgets/CWidgetStatsD.tsx +2 -2
  837. package/src/components/widgets/CWidgetStatsE.tsx +1 -1
  838. package/src/components/widgets/CWidgetStatsF.tsx +1 -1
  839. package/src/components/widgets/__tests__/CWidgetStatsA.spec.tsx +1 -1
  840. package/src/components/widgets/__tests__/CWidgetStatsB.spec.tsx +1 -1
  841. package/src/components/widgets/__tests__/CWidgetStatsC.spec.tsx +1 -1
  842. package/src/components/widgets/__tests__/CWidgetStatsD.spec.tsx +1 -1
  843. package/src/components/widgets/__tests__/CWidgetStatsE.spec.tsx +1 -1
  844. package/src/components/widgets/__tests__/CWidgetStatsF.spec.tsx +2 -2
  845. package/src/helpers/polymorphicComponent.ts +1 -1
  846. package/src/utils/executeAfterTransition.ts +1 -1
  847. package/src/utils/getNextActiveElement.ts +1 -1
  848. package/src/utils/mergeClassNames.ts +1 -1
@@ -1,4 +1,13 @@
1
- import React, { ElementType, forwardRef, HTMLAttributes, useEffect, useRef, useState } from 'react'
1
+ import React, {
2
+ ElementType,
3
+ forwardRef,
4
+ HTMLAttributes,
5
+ useCallback,
6
+ useEffect,
7
+ useMemo,
8
+ useRef,
9
+ useState,
10
+ } from 'react'
2
11
  import PropTypes from 'prop-types'
3
12
  import classNames from 'classnames'
4
13
  import type { Options } from '@popperjs/core'
@@ -28,12 +37,15 @@ export interface CDropdownProps extends HTMLAttributes<HTMLDivElement | HTMLLIEl
28
37
  * </CDropdownMenu>
29
38
  * </CDropdown>
30
39
  *
31
- * @type 'start' | 'end' | { xs: 'start' | 'end' } | { sm: 'start' | 'end' } | { md: 'start' | 'end' } | { lg: 'start' | 'end' } | { xl: 'start' | 'end'} | { xxl: 'start' | 'end'}
40
+ * @type 'start' | 'end' | { xs: 'start' | 'end' } | { sm: 'start' | 'end' } |
41
+ * { md: 'start' | 'end' } | { lg: 'start' | 'end' } | { xl: 'start' | 'end'} |
42
+ * { xxl: 'start' | 'end'}
32
43
  */
33
44
  alignment?: Alignments
34
45
 
35
46
  /**
36
- * Determines the root node component (native HTML element or a custom React component) for the React Dropdown.
47
+ * Determines the root node component (native HTML element or a custom React
48
+ * component) for the React Dropdown.
37
49
  */
38
50
  as?: ElementType
39
51
 
@@ -56,7 +68,8 @@ export interface CDropdownProps extends HTMLAttributes<HTMLDivElement | HTMLLIEl
56
68
  className?: string
57
69
 
58
70
  /**
59
- * Appends the React Dropdown Menu to a specific element. You can pass an HTML element or a function returning an element. Defaults to `document.body`.
71
+ * Appends the React Dropdown Menu to a specific element. You can pass an HTML
72
+ * element or a function returning an element. Defaults to `document.body`.
60
73
  *
61
74
  * @example
62
75
  * // Append the menu to a custom container
@@ -69,7 +82,8 @@ export interface CDropdownProps extends HTMLAttributes<HTMLDivElement | HTMLLIEl
69
82
  container?: DocumentFragment | Element | (() => DocumentFragment | Element | null) | null
70
83
 
71
84
  /**
72
- * Applies a darker color scheme to the React Dropdown Menu, often used within dark navbars.
85
+ * Applies a darker color scheme to the React Dropdown Menu, often used within
86
+ * dark navbars.
73
87
  */
74
88
  dark?: boolean
75
89
 
@@ -79,7 +93,8 @@ export interface CDropdownProps extends HTMLAttributes<HTMLDivElement | HTMLLIEl
79
93
  direction?: 'center' | 'dropup' | 'dropup-center' | 'dropend' | 'dropstart'
80
94
 
81
95
  /**
82
- * Defines x and y offsets ([x, y]) for the React Dropdown Menu relative to its target.
96
+ * Defines x and y offsets ([x, y]) for the React Dropdown Menu relative to
97
+ * its target.
83
98
  *
84
99
  * @example
85
100
  * // Offset the menu 10px in X and 5px in Y direction
@@ -102,19 +117,23 @@ export interface CDropdownProps extends HTMLAttributes<HTMLDivElement | HTMLLIEl
102
117
  onShow?: () => void
103
118
 
104
119
  /**
105
- * Determines the placement of the React Dropdown Menu after Popper.js modifiers.
120
+ * Determines the placement of the React Dropdown Menu after Popper.js
121
+ * modifiers.
106
122
  *
107
123
  * @type 'auto' | 'auto-start' | 'auto-end' | 'top-end' | 'top' | 'top-start' | 'bottom-end' | 'bottom' | 'bottom-start' | 'right-start' | 'right' | 'right-end' | 'left-start' | 'left' | 'left-end'
108
124
  */
109
125
  placement?: Placements
110
126
 
111
127
  /**
112
- * Enables or disables dynamic positioning via Popper.js for the React Dropdown Menu.
128
+ * Enables or disables dynamic positioning via Popper.js for the React
129
+ * Dropdown Menu.
113
130
  */
114
131
  popper?: boolean
115
132
 
116
133
  /**
117
- * Provides a custom Popper.js configuration or a function that returns a modified Popper.js configuration for advanced positioning of the React Dropdown Menu. [Read more](https://popper.js.org/docs/v2/constructors/#options)
134
+ * Provides a custom Popper.js configuration or a function that returns a
135
+ * modified Popper.js configuration for advanced positioning of the React
136
+ * Dropdown Menu. [Read more](https://popper.js.org/docs/v2/constructors/#options)
118
137
  *
119
138
  * @example
120
139
  * // Providing a custom popper config
@@ -134,7 +153,8 @@ export interface CDropdownProps extends HTMLAttributes<HTMLDivElement | HTMLLIEl
134
153
  popperConfig?: Partial<Options> | ((defaultPopperConfig: Partial<Options>) => Partial<Options>)
135
154
 
136
155
  /**
137
- * Renders the React Dropdown Menu using a React Portal, allowing it to escape the DOM hierarchy for improved positioning.
156
+ * Renders the React Dropdown Menu using a React Portal, allowing it to escape
157
+ * the DOM hierarchy for improved positioning.
138
158
  *
139
159
  * @since 4.8.0
140
160
  */
@@ -190,136 +210,184 @@ export const CDropdown: PolymorphicRefForwardingComponent<'div', CDropdownProps>
190
210
  ref
191
211
  ) => {
192
212
  const dropdownRef = useRef<HTMLDivElement>(null)
193
- const dropdownToggleRef = useRef<HTMLElement>(null)
194
213
  const dropdownMenuRef = useRef<HTMLDivElement | HTMLUListElement>(null)
195
214
  const forkedRef = useForkedRef(ref, dropdownRef)
215
+ const [dropdownToggleElement, setDropdownToggleElement] = useState<HTMLElement | null>(null)
216
+ const [pendingKeyDownEvent, setPendingKeyDownEvent] = useState<KeyboardEvent | null>(null)
196
217
  const [_visible, setVisible] = useState(visible)
197
218
  const { initPopper, destroyPopper } = usePopper()
198
219
 
199
- const Component = variant === 'nav-item' ? 'li' : as
200
-
201
- // Disable popper if responsive aligment is set.
202
- if (typeof alignment === 'object') {
203
- popper = false
204
- }
220
+ const dropdownToggleRef = useCallback((node: HTMLElement | null) => {
221
+ if (node) {
222
+ setDropdownToggleElement(node)
223
+ }
224
+ }, [])
205
225
 
206
- const contextValues = {
207
- alignment,
208
- container,
209
- dark,
210
- dropdownToggleRef,
211
- dropdownMenuRef,
212
- popper,
213
- portal,
214
- variant,
215
- visible: _visible,
216
- setVisible,
217
- }
226
+ const allowPopperUse = popper && typeof alignment !== 'object'
227
+ const Component = variant === 'nav-item' ? 'li' : as
218
228
 
219
- const defaultPopperConfig = {
220
- modifiers: [
221
- {
222
- name: 'offset',
223
- options: {
224
- offset: offset,
229
+ const computedPopperConfig: Partial<Options> = useMemo(() => {
230
+ const defaultPopperConfig = {
231
+ modifiers: [
232
+ {
233
+ name: 'offset',
234
+ options: {
235
+ offset,
236
+ },
225
237
  },
226
- },
227
- ],
228
- placement: getPlacement(placement, direction, alignment, isRTL(dropdownMenuRef.current)),
229
- }
238
+ ],
239
+ placement: getPlacement(placement, direction, alignment, isRTL(dropdownMenuRef.current)),
240
+ }
230
241
 
231
- const computedPopperConfig: Partial<Options> = {
232
- ...defaultPopperConfig,
233
- ...(typeof popperConfig === 'function' ? popperConfig(defaultPopperConfig) : popperConfig),
234
- }
242
+ return {
243
+ ...defaultPopperConfig,
244
+ ...(typeof popperConfig === 'function' ? popperConfig(defaultPopperConfig) : popperConfig),
245
+ }
246
+ }, [offset, placement, direction, alignment, popperConfig])
235
247
 
236
248
  useEffect(() => {
237
- setVisible(visible)
249
+ if (visible) {
250
+ handleShow()
251
+ } else {
252
+ handleHide()
253
+ }
238
254
  }, [visible])
239
255
 
240
256
  useEffect(() => {
241
- const toggleElement = dropdownToggleRef.current
257
+ const toggleElement = dropdownToggleElement
242
258
  const menuElement = dropdownMenuRef.current
259
+ if (allowPopperUse && menuElement && toggleElement && _visible) {
260
+ initPopper(toggleElement, menuElement, computedPopperConfig)
261
+ }
262
+ }, [dropdownToggleElement])
243
263
 
244
- if (_visible && toggleElement && menuElement) {
245
- if (popper) {
246
- initPopper(toggleElement, menuElement, computedPopperConfig)
247
- }
264
+ useEffect(() => {
265
+ if (pendingKeyDownEvent !== null) {
266
+ handleKeydown(pendingKeyDownEvent)
267
+ setPendingKeyDownEvent(null)
268
+ }
269
+ }, [pendingKeyDownEvent])
248
270
 
249
- toggleElement.focus()
250
- toggleElement.addEventListener('keydown', handleKeydown)
251
- menuElement.addEventListener('keydown', handleKeydown)
271
+ const handleHide = useCallback(() => {
272
+ setVisible(false)
252
273
 
253
- window.addEventListener('mouseup', handleMouseUp)
254
- window.addEventListener('keyup', handleKeyup)
274
+ const toggleElement = dropdownToggleElement
275
+ const menuElement = dropdownMenuRef.current
255
276
 
256
- onShow?.()
277
+ if (allowPopperUse) {
278
+ destroyPopper()
257
279
  }
258
280
 
259
- return () => {
260
- if (popper) {
261
- destroyPopper()
262
- }
281
+ toggleElement?.removeEventListener('keydown', handleKeydown)
282
+ menuElement?.removeEventListener('keydown', handleKeydown)
263
283
 
264
- toggleElement?.removeEventListener('keydown', handleKeydown)
265
- menuElement?.removeEventListener('keydown', handleKeydown)
284
+ window.removeEventListener('mouseup', handleMouseUp)
285
+ window.removeEventListener('keyup', handleKeyup)
266
286
 
267
- window.removeEventListener('mouseup', handleMouseUp)
268
- window.removeEventListener('keyup', handleKeyup)
287
+ onHide?.()
288
+ }, [dropdownToggleElement, allowPopperUse, destroyPopper, onHide])
269
289
 
270
- onHide?.()
271
- }
272
- }, [
273
- computedPopperConfig,
274
- destroyPopper,
275
- dropdownMenuRef,
276
- dropdownToggleRef,
277
- initPopper,
278
- _visible,
279
- ])
280
-
281
- const handleKeydown = (event: KeyboardEvent) => {
282
- if (
283
- _visible &&
284
- dropdownMenuRef.current &&
285
- (event.key === 'ArrowDown' || event.key === 'ArrowUp')
286
- ) {
290
+ const handleKeydown = useCallback((event: KeyboardEvent) => {
291
+ if (dropdownMenuRef.current && (event.key === 'ArrowDown' || event.key === 'ArrowUp')) {
287
292
  event.preventDefault()
288
293
  const target = event.target as HTMLElement
289
- const items: HTMLElement[] = Array.from(
290
- dropdownMenuRef.current.querySelectorAll('.dropdown-item:not(.disabled):not(:disabled)')
291
- )
294
+ const items = [
295
+ ...dropdownMenuRef.current.querySelectorAll(
296
+ '.dropdown-item:not(.disabled):not(:disabled)'
297
+ ),
298
+ ] as HTMLElement[]
292
299
  getNextActiveElement(items, target, event.key === 'ArrowDown', true).focus()
293
300
  }
294
- }
301
+ }, [])
295
302
 
296
- const handleKeyup = (event: KeyboardEvent) => {
297
- if (autoClose === false) {
298
- return
299
- }
303
+ const handleKeyup = useCallback(
304
+ (event: KeyboardEvent) => {
305
+ if (autoClose === false) {
306
+ return
307
+ }
300
308
 
301
- if (event.key === 'Escape') {
302
- setVisible(false)
303
- }
304
- }
309
+ if (event.key === 'Escape') {
310
+ handleHide()
311
+ dropdownToggleElement?.focus()
312
+ }
313
+ },
314
+ [autoClose, handleHide]
315
+ )
305
316
 
306
- const handleMouseUp = (event: Event) => {
307
- if (!dropdownToggleRef.current || !dropdownMenuRef.current) {
308
- return
309
- }
317
+ const handleMouseUp = useCallback(
318
+ (event: Event) => {
319
+ if (!dropdownToggleElement || !dropdownMenuRef.current) {
320
+ return
321
+ }
310
322
 
311
- if (dropdownToggleRef.current.contains(event.target as HTMLElement)) {
312
- return
313
- }
323
+ if (dropdownToggleElement.contains(event.target as HTMLElement)) {
324
+ return
325
+ }
314
326
 
315
- if (
316
- autoClose === true ||
317
- (autoClose === 'inside' && dropdownMenuRef.current.contains(event.target as HTMLElement)) ||
318
- (autoClose === 'outside' && !dropdownMenuRef.current.contains(event.target as HTMLElement))
319
- ) {
320
- setTimeout(() => setVisible(false), 1)
321
- return
322
- }
327
+ if (
328
+ autoClose === true ||
329
+ (autoClose === 'inside' &&
330
+ dropdownMenuRef.current.contains(event.target as HTMLElement)) ||
331
+ (autoClose === 'outside' &&
332
+ !dropdownMenuRef.current.contains(event.target as HTMLElement))
333
+ ) {
334
+ setTimeout(() => handleHide(), 1)
335
+ return
336
+ }
337
+ },
338
+ [autoClose, dropdownToggleElement, handleHide]
339
+ )
340
+
341
+ const handleShow = useCallback(
342
+ (event?: KeyboardEvent) => {
343
+ const toggleElement = dropdownToggleElement
344
+ const menuElement = dropdownMenuRef.current
345
+
346
+ if (toggleElement && menuElement) {
347
+ setVisible(true)
348
+
349
+ if (allowPopperUse) {
350
+ initPopper(toggleElement, menuElement, computedPopperConfig)
351
+ }
352
+
353
+ toggleElement.focus()
354
+ toggleElement.addEventListener('keydown', handleKeydown)
355
+ menuElement.addEventListener('keydown', handleKeydown)
356
+
357
+ window.addEventListener('mouseup', handleMouseUp)
358
+ window.addEventListener('keyup', handleKeyup)
359
+
360
+ if (event && (event.key === 'ArrowDown' || event.key === 'ArrowUp')) {
361
+ setPendingKeyDownEvent(event)
362
+ }
363
+
364
+ onShow?.()
365
+ }
366
+ },
367
+ [
368
+ dropdownToggleElement,
369
+ allowPopperUse,
370
+ initPopper,
371
+ computedPopperConfig,
372
+ handleKeydown,
373
+ handleMouseUp,
374
+ handleKeyup,
375
+ onShow,
376
+ ]
377
+ )
378
+
379
+ const contextValues = {
380
+ alignment,
381
+ container,
382
+ dark,
383
+ dropdownMenuRef,
384
+ dropdownToggleRef,
385
+ handleHide,
386
+ handleShow,
387
+ popper: allowPopperUse,
388
+ portal,
389
+ variant,
390
+ visible: _visible,
323
391
  }
324
392
 
325
393
  return (
@@ -5,10 +5,10 @@ export interface CDropdownContextProps {
5
5
  alignment?: Alignments
6
6
  container?: DocumentFragment | Element | (() => DocumentFragment | Element | null) | null
7
7
  dark?: boolean
8
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
9
- dropdownToggleRef: RefObject<any | null>
10
8
  dropdownMenuRef: RefObject<HTMLDivElement | HTMLUListElement | null>
11
- setVisible: React.Dispatch<React.SetStateAction<boolean | undefined>>
9
+ dropdownToggleRef: (node: HTMLElement | null) => void
10
+ handleHide?: () => void
11
+ handleShow?: (event?: KeyboardEvent) => void
12
12
  popper?: boolean
13
13
  portal?: boolean
14
14
  variant?: 'btn-group' | 'dropdown' | 'input-group' | 'nav-item'
@@ -18,17 +18,21 @@ export interface CDropdownToggleProps extends Omit<CButtonProps, 'type'> {
18
18
  */
19
19
  custom?: boolean
20
20
  /**
21
- * If a dropdown `variant` is set to `nav-item` then render the toggler as a link instead of a button.
21
+ * If a dropdown `variant` is set to `nav-item` then render the toggler as a
22
+ * link instead of a button.
22
23
  *
23
24
  * @since 5.0.0
24
25
  */
25
26
  navLink?: boolean
26
27
  /**
27
- * Similarly, create split button dropdowns with virtually the same markup as single button dropdowns, but with the addition of `.dropdown-toggle-split` className for proper spacing around the dropdown caret.
28
+ * Similarly, create split button dropdowns with virtually the same markup as
29
+ * single button dropdowns, but with the addition of `.dropdown-toggle-split`
30
+ * className for proper spacing around the dropdown caret.
28
31
  */
29
32
  split?: boolean
30
33
  /**
31
- * Sets which event handlers youd like provided to your toggle prop. You can specify one trigger or an array of them.
34
+ * Sets which event handlers you'd like provided to your toggle prop. You can
35
+ * specify one trigger or an array of them.
32
36
  *
33
37
  * @type 'hover' | 'focus' | 'click'
34
38
  */
@@ -45,19 +49,31 @@ export const CDropdownToggle: FC<CDropdownToggleProps> = ({
45
49
  trigger = 'click',
46
50
  ...rest
47
51
  }) => {
48
- const { dropdownToggleRef, variant, visible, setVisible } = useContext(CDropdownContext)
52
+ const { dropdownToggleRef, handleHide, handleShow, variant, visible } =
53
+ useContext(CDropdownContext)
49
54
 
50
55
  const triggers = {
51
56
  ...((trigger === 'click' || trigger.includes('click')) && {
52
57
  onClick: (event: React.MouseEvent<HTMLElement>) => {
53
58
  event.preventDefault()
54
- setVisible(!visible)
59
+
60
+ if (visible) {
61
+ handleHide?.()
62
+ } else {
63
+ handleShow?.()
64
+ }
55
65
  },
56
66
  }),
57
67
  ...((trigger === 'focus' || trigger.includes('focus')) && {
58
- onFocus: () => setVisible(true),
59
- onBlur: () => setVisible(false),
68
+ onFocus: () => handleShow?.(),
69
+ onBlur: () => handleHide?.(),
60
70
  }),
71
+ onKeyDown: (event: React.KeyboardEvent) => {
72
+ if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {
73
+ event.preventDefault()
74
+ handleShow?.(event.nativeEvent)
75
+ }
76
+ },
61
77
  }
62
78
 
63
79
  const togglerProps = {
@@ -74,36 +90,32 @@ export const CDropdownToggle: FC<CDropdownToggleProps> = ({
74
90
  ...(!rest.disabled && { ...triggers }),
75
91
  }
76
92
 
77
- const Toggler = () => {
78
- if (custom && React.isValidElement(children)) {
79
- return (
80
- <>
81
- {React.cloneElement(children as React.ReactElement<any>, {
82
- 'aria-expanded': visible,
83
- ...(!rest.disabled && { ...triggers }),
84
- ref: dropdownToggleRef,
85
- })}
86
- </>
87
- )
88
- }
89
-
90
- if (variant === 'nav-item' && navLink) {
91
- return (
92
- <a href="#" {...togglerProps} role="button" {...rest} ref={dropdownToggleRef}>
93
- {children}
94
- </a>
95
- )
96
- }
93
+ if (custom && React.isValidElement(children)) {
94
+ return (
95
+ <>
96
+ {React.cloneElement(children as React.ReactElement<any>, {
97
+ 'aria-expanded': visible,
98
+ ...(!rest.disabled && { ...triggers }),
99
+ ref: dropdownToggleRef,
100
+ })}
101
+ </>
102
+ )
103
+ }
97
104
 
105
+ if (variant === 'nav-item' && navLink) {
98
106
  return (
99
- <CButton {...togglerProps} tabIndex={0} {...rest} ref={dropdownToggleRef}>
107
+ <a href="#" {...togglerProps} role="button" {...rest} ref={dropdownToggleRef}>
100
108
  {children}
101
- {split && <span className="visually-hidden">Toggle Dropdown</span>}
102
- </CButton>
109
+ </a>
103
110
  )
104
111
  }
105
112
 
106
- return <Toggler />
113
+ return (
114
+ <CButton {...togglerProps} tabIndex={0} {...rest} ref={dropdownToggleRef}>
115
+ {children}
116
+ {split && <span className="visually-hidden">Toggle Dropdown</span>}
117
+ </CButton>
118
+ )
107
119
  }
108
120
 
109
121
  CDropdownToggle.propTypes = {
@@ -30,7 +30,7 @@ test('CDropdown customize', async () => {
30
30
  visible={true}
31
31
  >
32
32
  Test
33
- </CDropdown>,
33
+ </CDropdown>
34
34
  )
35
35
  expect(container).toMatchSnapshot()
36
36
  expect(container.firstChild).toHaveClass('bazinga')
@@ -66,7 +66,7 @@ test('CDropdown opens on toggle click and closes on clicking outside', async ()
66
66
  <CDropdownItem>B</CDropdownItem>
67
67
  </CDropdownMenu>
68
68
  </CDropdown>
69
- </div>,
69
+ </div>
70
70
  )
71
71
 
72
72
  // Ensure the dropdown is initially closed
@@ -110,7 +110,7 @@ test('CDropdown example', async () => {
110
110
  <CDropdownDivider />
111
111
  <CDropdownItem>D</CDropdownItem>
112
112
  </CDropdownMenu>
113
- </CDropdown>,
113
+ </CDropdown>
114
114
  )
115
115
  expect(container).toMatchSnapshot()
116
116
  })
@@ -12,7 +12,7 @@ test('CDropdownHeader customize', async () => {
12
12
  const { container } = render(
13
13
  <CDropdownHeader className="bazinga" as="h3">
14
14
  Test
15
- </CDropdownHeader>,
15
+ </CDropdownHeader>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('bazinga')
@@ -12,7 +12,7 @@ test('CDropdownItem customize', async () => {
12
12
  const { container } = render(
13
13
  <CDropdownItem className="bazinga" as="div">
14
14
  Test
15
- </CDropdownItem>,
15
+ </CDropdownItem>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('bazinga')
@@ -12,7 +12,7 @@ test('CDropdownItemPlain customize', async () => {
12
12
  const { container } = render(
13
13
  <CDropdownItemPlain className="bazinga" as="div">
14
14
  Test
15
- </CDropdownItemPlain>,
15
+ </CDropdownItemPlain>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('bazinga')
@@ -14,7 +14,7 @@ test('CDropdownMenu customize', async () => {
14
14
  <CDropdownMenu className="bazinga" as="div">
15
15
  Test
16
16
  </CDropdownMenu>
17
- </CDropdown>,
17
+ </CDropdown>
18
18
  )
19
19
  expect(container).toMatchSnapshot()
20
20
  expect(container.firstChild?.firstChild).toHaveClass('bazinga')
@@ -12,7 +12,7 @@ test('CDropdownToggle customize', async () => {
12
12
  const { container } = render(
13
13
  <CDropdownToggle caret={true} color="primary" split={true} trigger="focus">
14
14
  Test
15
- </CDropdownToggle>,
15
+ </CDropdownToggle>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('dropdown-toggle')
@@ -7,7 +7,7 @@ export const getAlignmentClassNames = (alignment: Alignments) => {
7
7
  if (typeof alignment === 'object') {
8
8
  for (const key in alignment) {
9
9
  classNames.push(
10
- `dropdown-menu${key === 'xs' ? '' : `-${key}`}-${alignment[key as keyof Breakpoints]}`,
10
+ `dropdown-menu${key === 'xs' ? '' : `-${key}`}-${alignment[key as keyof Breakpoints]}`
11
11
  )
12
12
  }
13
13
  }
@@ -23,7 +23,7 @@ export const getPlacement = (
23
23
  placement: Placement,
24
24
  direction: string | undefined,
25
25
  alignment: Alignments | string | undefined,
26
- isRTL: boolean,
26
+ isRTL: boolean
27
27
  ): Placements => {
28
28
  let _placement = placement
29
29