@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
@@ -12,6 +12,7 @@ import { Transition } from 'react-transition-group'
12
12
 
13
13
  import { CBackdrop } from '../backdrop'
14
14
  import { CConditionalPortal } from '../conditional-portal'
15
+ import { CFocusTrap } from '../focus-trap'
15
16
  import { CModalContent } from './CModalContent'
16
17
  import { CModalContext } from './CModalContext'
17
18
  import { CModalDialog } from './CModalDialog'
@@ -118,7 +119,6 @@ export const CModal = forwardRef<HTMLDivElement, CModalProps>(
118
119
  },
119
120
  ref
120
121
  ) => {
121
- const activeElementRef = useRef<HTMLElement | null>(null)
122
122
  const modalRef = useRef<HTMLDivElement>(null)
123
123
  const modalContentRef = useRef<HTMLDivElement>(null)
124
124
  const forkedRef = useForkedRef(ref, modalRef)
@@ -137,11 +137,8 @@ export const CModal = forwardRef<HTMLDivElement, CModalProps>(
137
137
 
138
138
  useEffect(() => {
139
139
  if (_visible) {
140
- activeElementRef.current = document.activeElement as HTMLElement | null
141
140
  document.addEventListener('mouseup', handleClickOutside)
142
141
  document.addEventListener('keydown', handleKeyDown)
143
- } else {
144
- activeElementRef.current?.focus()
145
142
  }
146
143
 
147
144
  return () => {
@@ -159,7 +156,7 @@ export const CModal = forwardRef<HTMLDivElement, CModalProps>(
159
156
  }
160
157
 
161
158
  useLayoutEffect(() => {
162
- onClosePrevented && onClosePrevented()
159
+ onClosePrevented?.()
163
160
  setTimeout(() => setStaticBackdrop(false), duration)
164
161
  }, [staticBackdrop])
165
162
 
@@ -172,13 +169,6 @@ export const CModal = forwardRef<HTMLDivElement, CModalProps>(
172
169
  document.body.style.overflow = 'hidden'
173
170
  document.body.style.paddingRight = '0px'
174
171
  }
175
-
176
- setTimeout(
177
- () => {
178
- focus && modalRef.current?.focus()
179
- },
180
- transition ? duration : 0
181
- )
182
172
  } else {
183
173
  document.body.classList.remove('modal-open')
184
174
 
@@ -249,7 +239,9 @@ export const CModal = forwardRef<HTMLDivElement, CModalProps>(
249
239
  scrollable={scrollable}
250
240
  size={size}
251
241
  >
252
- <CModalContent ref={modalContentRef}>{children}</CModalContent>
242
+ <CFocusTrap active={focus && state === 'entered'} restoreFocus>
243
+ <CModalContent ref={modalContentRef}>{children}</CModalContent>
244
+ </CFocusTrap>
253
245
  </CModalDialog>
254
246
  </div>
255
247
  </CModalContext.Provider>
@@ -16,7 +16,7 @@ export const CModalBody = forwardRef<HTMLDivElement, CModalBodyProps>(
16
16
  {children}
17
17
  </div>
18
18
  )
19
- },
19
+ }
20
20
  )
21
21
 
22
22
  CModalBody.propTypes = {
@@ -16,7 +16,7 @@ export const CModalContent = forwardRef<HTMLDivElement, CModalContentProps>(
16
16
  {children}
17
17
  </div>
18
18
  )
19
- },
19
+ }
20
20
  )
21
21
 
22
22
  CModalContent.propTypes = {
@@ -39,7 +39,7 @@ export const CModalDialog = forwardRef<HTMLDivElement, CModalDialogProps>(
39
39
  'modal-dialog-scrollable': scrollable,
40
40
  [`modal-${size}`]: size,
41
41
  },
42
- className,
42
+ className
43
43
  )}
44
44
  {...rest}
45
45
  ref={ref}
@@ -47,7 +47,7 @@ export const CModalDialog = forwardRef<HTMLDivElement, CModalDialogProps>(
47
47
  {children}
48
48
  </div>
49
49
  )
50
- },
50
+ }
51
51
  )
52
52
 
53
53
  CModalDialog.propTypes = {
@@ -16,7 +16,7 @@ export const CModalFooter = forwardRef<HTMLDivElement, CModalFooterProps>(
16
16
  {children}
17
17
  </div>
18
18
  )
19
- },
19
+ }
20
20
  )
21
21
 
22
22
  CModalFooter.propTypes = {
@@ -26,7 +26,7 @@ export const CModalHeader = forwardRef<HTMLDivElement, CModalHeaderProps>(
26
26
  {closeButton && <CCloseButton onClick={() => setVisible(false)} />}
27
27
  </div>
28
28
  )
29
- },
29
+ }
30
30
  )
31
31
 
32
32
  CModalHeader.propTypes = {
@@ -20,7 +20,7 @@ test('CModal customize', async () => {
20
20
  visible={true}
21
21
  >
22
22
  Test
23
- </CModal>,
23
+ </CModal>
24
24
  )
25
25
  expect(container).toMatchSnapshot()
26
26
  })
@@ -30,7 +30,7 @@ test('CModal dialog close on press ESC', async () => {
30
30
  render(
31
31
  <CModal onClose={onClose} portal={false} visible>
32
32
  Test
33
- </CModal>,
33
+ </CModal>
34
34
  )
35
35
  expect(onClose).toHaveBeenCalledTimes(0)
36
36
 
@@ -18,7 +18,7 @@ test('CModalDialog customize', async () => {
18
18
  size="xl"
19
19
  >
20
20
  Test
21
- </CModalDialog>,
21
+ </CModalDialog>
22
22
  )
23
23
  expect(container).toMatchSnapshot()
24
24
  expect(container.firstChild).toHaveClass('bazinga')
@@ -12,7 +12,7 @@ test('CModalTitle customize', async () => {
12
12
  const { container } = render(
13
13
  <CModalTitle className="bazinga" as="h3">
14
14
  Test
15
- </CModalTitle>,
15
+ </CModalTitle>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('bazinga')
@@ -65,7 +65,7 @@ export const CNavGroup: PolymorphicRefForwardingComponent<'li', CNavGroupProps>
65
65
  const { visibleGroup, setVisibleGroup } = useContext(CSidebarNavContext)
66
66
 
67
67
  const [_visible, setVisible] = useState(
68
- Boolean(visible || (idx && visibleGroup && isInVisibleGroup(visibleGroup, idx))),
68
+ Boolean(visible || (idx && visibleGroup && isInVisibleGroup(visibleGroup, idx)))
69
69
  )
70
70
 
71
71
  useEffect(() => {
@@ -75,7 +75,7 @@ export const CNavGroup: PolymorphicRefForwardingComponent<'li', CNavGroupProps>
75
75
  const handleTogglerOnCLick = (event: React.MouseEvent<HTMLElement>) => {
76
76
  event.preventDefault()
77
77
  setVisibleGroup(
78
- _visible ? (idx?.toString().includes('.') ? idx.slice(0, idx.lastIndexOf('.')) : '') : idx,
78
+ _visible ? (idx?.toString().includes('.') ? idx.slice(0, idx.lastIndexOf('.')) : '') : idx
79
79
  )
80
80
  setVisible(!_visible)
81
81
  }
@@ -25,7 +25,7 @@ export const CNavGroupItems: PolymorphicRefForwardingComponent<'ul', CNavGroupIt
25
25
  {children}
26
26
  </Component>
27
27
  )
28
- },
28
+ }
29
29
  )
30
30
 
31
31
  CNavGroupItems.propTypes = {
@@ -10,7 +10,7 @@ test('loads and displays CNavGroup component', async () => {
10
10
 
11
11
  test('CNavGroup customize', async () => {
12
12
  const { container } = render(
13
- <CNavGroup className="bazinga" toggler="anchorText" visible={true} idx="1" />,
13
+ <CNavGroup className="bazinga" toggler="anchorText" visible={true} idx="1" />
14
14
  )
15
15
  expect(container).toMatchSnapshot()
16
16
  expect(container.firstChild).toHaveClass('nav-group')
@@ -12,7 +12,7 @@ test('CNavItem customize', async () => {
12
12
  const { container } = render(
13
13
  <CNavItem active={true} className="bazinga" as="h3" disabled={true} href="/bazinga">
14
14
  Test
15
- </CNavItem>,
15
+ </CNavItem>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild?.firstChild).toHaveClass('nav-link')
@@ -12,7 +12,7 @@ test('CNavLink customize', async () => {
12
12
  const { container } = render(
13
13
  <CNavLink active={true} className="bazinga" as="h3" disabled={true} href="/bazinga">
14
14
  Test
15
- </CNavLink>,
15
+ </CNavLink>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('nav-link')
@@ -55,7 +55,7 @@ export const CNavbar: PolymorphicRefForwardingComponent<'nav', CNavbarProps> = f
55
55
  placement,
56
56
  ...rest
57
57
  },
58
- ref,
58
+ ref
59
59
  ) => {
60
60
  return (
61
61
  <Component
@@ -66,7 +66,7 @@ export const CNavbar: PolymorphicRefForwardingComponent<'nav', CNavbarProps> = f
66
66
  [typeof expand === 'boolean' ? 'navbar-expand' : `navbar-expand-${expand}`]: expand,
67
67
  },
68
68
  placement,
69
- className,
69
+ className
70
70
  )}
71
71
  {...(colorScheme && { 'data-coreui-theme': colorScheme })}
72
72
  {...rest}
@@ -81,7 +81,7 @@ export const CNavbar: PolymorphicRefForwardingComponent<'nav', CNavbarProps> = f
81
81
  )}
82
82
  </Component>
83
83
  )
84
- },
84
+ }
85
85
  )
86
86
 
87
87
  CNavbar.propTypes = {
@@ -16,7 +16,7 @@ export const CNavbarText = forwardRef<HTMLSpanElement, CNavbarTextProps>(
16
16
  {children}
17
17
  </span>
18
18
  )
19
- },
19
+ }
20
20
  )
21
21
 
22
22
  CNavbarText.propTypes = {
@@ -16,7 +16,7 @@ export const CNavbarToggler = forwardRef<HTMLButtonElement, CNavbarTogglerProps>
16
16
  {children ?? <span className="navbar-toggler-icon"></span>}
17
17
  </button>
18
18
  )
19
- },
19
+ }
20
20
  )
21
21
 
22
22
  CNavbarToggler.propTypes = {
@@ -20,7 +20,7 @@ test('CNavbar customize', async () => {
20
20
  placement="fixed-bottom"
21
21
  >
22
22
  Test
23
- </CNavbar>,
23
+ </CNavbar>
24
24
  )
25
25
  expect(container).toMatchSnapshot()
26
26
  expect(container.firstChild).toHaveClass('bazinga')
@@ -37,7 +37,7 @@ test('CNavbar customize - container and expand are boolean', async () => {
37
37
  const { container } = render(
38
38
  <CNavbar container={true} expand={true}>
39
39
  Test
40
- </CNavbar>,
40
+ </CNavbar>
41
41
  )
42
42
  expect(container).toMatchSnapshot()
43
43
  expect(container.firstChild).toHaveClass('navbar-expand')
@@ -17,7 +17,7 @@ test('CNavbarBrand customize', async () => {
17
17
  const { container } = render(
18
18
  <CNavbarBrand className="bazinga" as="h3" href="/bazinga">
19
19
  Test
20
- </CNavbarBrand>,
20
+ </CNavbarBrand>
21
21
  )
22
22
  expect(container).toMatchSnapshot()
23
23
  expect(container.firstChild).toHaveClass('navbar-brand')
@@ -12,7 +12,7 @@ test('CNavbarNav customize', async () => {
12
12
  const { container } = render(
13
13
  <CNavbarNav className="bazinga" as="h3">
14
14
  Test
15
- </CNavbarNav>,
15
+ </CNavbarNav>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('bazinga')
@@ -5,6 +5,7 @@ import { Transition } from 'react-transition-group'
5
5
 
6
6
  import { CBackdrop } from '../backdrop'
7
7
  import { CConditionalPortal } from '../conditional-portal'
8
+ import { CFocusTrap } from '../focus-trap'
8
9
 
9
10
  import { useForkedRef } from '../../hooks'
10
11
 
@@ -74,7 +75,7 @@ export const COffcanvas = forwardRef<HTMLDivElement, COffcanvasProps>(
74
75
  visible = false,
75
76
  ...rest
76
77
  },
77
- ref,
78
+ ref
78
79
  ) => {
79
80
  const [_visible, setVisible] = useState<boolean>(visible)
80
81
  const offcanvasRef = useRef<HTMLDivElement>(null)
@@ -119,33 +120,34 @@ export const COffcanvas = forwardRef<HTMLDivElement, COffcanvasProps>(
119
120
  in={_visible}
120
121
  nodeRef={offcanvasRef}
121
122
  onEnter={onShow}
122
- onEntered={() => offcanvasRef.current?.focus()}
123
123
  onExit={onHide}
124
124
  timeout={300}
125
125
  >
126
126
  {(state) => (
127
127
  <CConditionalPortal portal={portal}>
128
- <div
129
- className={classNames(
130
- {
131
- [`offcanvas${typeof responsive === 'string' ? '-' + responsive : ''}`]:
132
- responsive,
133
- [`offcanvas-${placement}`]: placement,
134
- showing: state === 'entering',
135
- show: state === 'entered',
136
- 'show hiding': state === 'exiting',
137
- },
138
- className,
139
- )}
140
- role="dialog"
141
- tabIndex={-1}
142
- onKeyDown={handleKeyDown}
143
- {...(dark && { 'data-coreui-theme': 'dark' })}
144
- {...rest}
145
- ref={forkedRef}
146
- >
147
- {children}
148
- </div>
128
+ <CFocusTrap active={_visible && Boolean(backdrop)} restoreFocus>
129
+ <div
130
+ className={classNames(
131
+ {
132
+ [`offcanvas${typeof responsive === 'string' ? '-' + responsive : ''}`]:
133
+ responsive,
134
+ [`offcanvas-${placement}`]: placement,
135
+ showing: state === 'entering',
136
+ show: state === 'entered',
137
+ 'show hiding': state === 'exiting',
138
+ },
139
+ className
140
+ )}
141
+ role="dialog"
142
+ tabIndex={-1}
143
+ onKeyDown={handleKeyDown}
144
+ {...(dark && { 'data-coreui-theme': 'dark' })}
145
+ {...rest}
146
+ ref={forkedRef}
147
+ >
148
+ {children}
149
+ </div>
150
+ </CFocusTrap>
149
151
  </CConditionalPortal>
150
152
  )}
151
153
  </Transition>
@@ -160,7 +162,7 @@ export const COffcanvas = forwardRef<HTMLDivElement, COffcanvasProps>(
160
162
  )}
161
163
  </>
162
164
  )
163
- },
165
+ }
164
166
  )
165
167
 
166
168
  COffcanvas.propTypes = {
@@ -16,7 +16,7 @@ export const COffcanvasBody = forwardRef<HTMLDivElement, COffcanvasBodyProps>(
16
16
  {children}
17
17
  </div>
18
18
  )
19
- },
19
+ }
20
20
  )
21
21
 
22
22
  COffcanvasBody.propTypes = {
@@ -16,7 +16,7 @@ export const COffcanvasHeader = forwardRef<HTMLDivElement, COffcanvasHeaderProps
16
16
  {children}
17
17
  </div>
18
18
  )
19
- },
19
+ }
20
20
  )
21
21
 
22
22
  COffcanvasHeader.propTypes = {
@@ -23,7 +23,7 @@ export const COffcanvasTitle: PolymorphicRefForwardingComponent<'h5', COffcanvas
23
23
  {children}
24
24
  </Component>
25
25
  )
26
- },
26
+ }
27
27
  )
28
28
 
29
29
  COffcanvasTitle.propTypes = {
@@ -12,7 +12,7 @@ test('COffcanvasTitle customize', async () => {
12
12
  const { container } = render(
13
13
  <COffcanvasTitle className="bazinga" as="div">
14
14
  Test
15
- </COffcanvasTitle>,
15
+ </COffcanvasTitle>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('offcanvas-title')
@@ -28,14 +28,14 @@ export const CPagination = forwardRef<HTMLUListElement, CPaginationProps>(
28
28
  [`justify-content-${align}`]: align,
29
29
  [`pagination-${size}`]: size,
30
30
  },
31
- className,
31
+ className
32
32
  )}
33
33
  >
34
34
  {children}
35
35
  </ul>
36
36
  </nav>
37
37
  )
38
- },
38
+ }
39
39
  )
40
40
 
41
41
  CPagination.propTypes = {
@@ -34,7 +34,7 @@ export const CPaginationItem: PolymorphicRefForwardingComponent<'a', CPagination
34
34
  active: rest.active,
35
35
  disabled: rest.disabled,
36
36
  },
37
- className,
37
+ className
38
38
  )}
39
39
  {...(rest.active && { 'aria-current': 'page' })}
40
40
  >
@@ -49,7 +49,7 @@ export const CPaginationItem: PolymorphicRefForwardingComponent<'a', CPagination
49
49
  )}
50
50
  </li>
51
51
  )
52
- },
52
+ }
53
53
  )
54
54
 
55
55
  CPaginationItem.propTypes = {
@@ -12,7 +12,7 @@ test('CPagination customize', async () => {
12
12
  const { container } = render(
13
13
  <CPagination className="bazinga" aria-label="ariaLabel" size="lg">
14
14
  Test
15
- </CPagination>,
15
+ </CPagination>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  let element = container.firstChild
@@ -32,7 +32,7 @@ test('CPagination example', async () => {
32
32
  <CPaginationItem>A</CPaginationItem>
33
33
  <CPaginationItem>B</CPaginationItem>
34
34
  <CPaginationItem>C</CPaginationItem>
35
- </CPagination>,
35
+ </CPagination>
36
36
  )
37
37
  expect(container).toMatchSnapshot()
38
38
  })
@@ -12,7 +12,7 @@ test('CPaginationItem customize', async () => {
12
12
  const { container } = render(
13
13
  <CPaginationItem className="bazinga" active={true} as="h3" disabled={true}>
14
14
  Test
15
- </CPaginationItem>,
15
+ </CPaginationItem>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('bazinga')
@@ -93,7 +93,7 @@ export const CPlaceholder: PolymorphicRefForwardingComponent<'span', CPlaceholde
93
93
  [`placeholder-${size}`]: size,
94
94
  },
95
95
  repsonsiveClassNames,
96
- className,
96
+ className
97
97
  )}
98
98
  {...rest}
99
99
  ref={ref}
@@ -101,7 +101,7 @@ export const CPlaceholder: PolymorphicRefForwardingComponent<'span', CPlaceholde
101
101
  {children}
102
102
  </Component>
103
103
  )
104
- },
104
+ }
105
105
  )
106
106
 
107
107
  CPlaceholder.propTypes = {
@@ -10,7 +10,7 @@ test('loads and displays CPlaceholder component', async () => {
10
10
 
11
11
  test('CPlaceholder customize', async () => {
12
12
  const { container } = render(
13
- <CPlaceholder animation="glow" className="bazinga" color="secondary" size="lg" sm={7} />,
13
+ <CPlaceholder animation="glow" className="bazinga" color="secondary" size="lg" sm={7} />
14
14
  )
15
15
  expect(container).toMatchSnapshot()
16
16
  expect(container.firstChild).toHaveClass('bazinga')
@@ -48,7 +48,7 @@ export const CProgress = forwardRef<HTMLDivElement, CProgressProps>(
48
48
  'progress-thin': thin,
49
49
  'progress-white': white,
50
50
  },
51
- className,
51
+ className
52
52
  )}
53
53
  {...(value !== undefined && {
54
54
  role: 'progressbar',
@@ -64,7 +64,7 @@ export const CProgress = forwardRef<HTMLDivElement, CProgressProps>(
64
64
  >
65
65
  {React.Children.toArray(children).some(
66
66
  // @ts-expect-error displayName is set in the CProgressBar component
67
- (child) => child.type && child.type.displayName === 'CProgressBar',
67
+ (child) => child.type && child.type.displayName === 'CProgressBar'
68
68
  ) ? (
69
69
  React.Children.map(children, (child) => {
70
70
  // @ts-expect-error displayName is set in the CProgressBar component
@@ -88,7 +88,7 @@ export const CProgress = forwardRef<HTMLDivElement, CProgressProps>(
88
88
  )}
89
89
  </div>
90
90
  )
91
- },
91
+ }
92
92
  )
93
93
 
94
94
  CProgress.propTypes = {
@@ -45,7 +45,7 @@ export const CProgressBar = forwardRef<HTMLDivElement, CProgressBarProps>(
45
45
  [`progress-bar-${variant}`]: variant,
46
46
  'progress-bar-animated': animated,
47
47
  },
48
- className,
48
+ className
49
49
  )}
50
50
  {...(!stacked && { style: { width: `${value}%` } })}
51
51
  {...rest}
@@ -54,7 +54,7 @@ export const CProgressBar = forwardRef<HTMLDivElement, CProgressBarProps>(
54
54
  {children}
55
55
  </div>
56
56
  )
57
- },
57
+ }
58
58
  )
59
59
  CProgressBar.propTypes = {
60
60
  animated: PropTypes.bool,
@@ -12,7 +12,7 @@ test('CProgress customize', async () => {
12
12
  const { container } = render(
13
13
  <CProgress className="bazinga" height={100} color="warning" value={50}>
14
14
  Test
15
- </CProgress>,
15
+ </CProgress>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('bazinga')
@@ -12,7 +12,7 @@ test('CProgressBar customize', async () => {
12
12
  const { container } = render(
13
13
  <CProgressBar color="warning" className="bazinga" animated={true} value={50} variant="striped">
14
14
  Test
15
- </CProgressBar>,
15
+ </CProgressBar>
16
16
  )
17
17
  expect(container).toMatchSnapshot()
18
18
  expect(container.firstChild).toHaveClass('bazinga')
@@ -16,7 +16,7 @@ export const CSidebarFooter = forwardRef<HTMLDivElement, CSidebarFooterProps>(
16
16
  {children}
17
17
  </div>
18
18
  )
19
- },
19
+ }
20
20
  )
21
21
 
22
22
  CSidebarFooter.propTypes = {
@@ -16,7 +16,7 @@ export const CSidebarHeader = forwardRef<HTMLDivElement, CSidebarHeaderProps>(
16
16
  {children}
17
17
  </div>
18
18
  )
19
- },
19
+ }
20
20
  )
21
21
 
22
22
  CSidebarHeader.propTypes = {
@@ -16,7 +16,7 @@ export const CSidebarToggler = forwardRef<HTMLButtonElement, CSidebarTogglerProp
16
16
  {children}
17
17
  </button>
18
18
  )
19
- },
19
+ }
20
20
  )
21
21
 
22
22
  CSidebarToggler.propTypes = {
@@ -21,7 +21,7 @@ test('CSidebar customize show', async () => {
21
21
  overlaid={true}
22
22
  >
23
23
  Test
24
- </CSidebar>,
24
+ </CSidebar>
25
25
  )
26
26
  expect(container).toMatchSnapshot()
27
27
  expect(container.firstChild).toHaveClass('bazinga')
@@ -37,7 +37,7 @@ test('CSidebar customize hide', async () => {
37
37
  const { container } = render(
38
38
  <CSidebar className="bazinga" position="sticky" visible={false} overlaid={false}>
39
39
  Test
40
- </CSidebar>,
40
+ </CSidebar>
41
41
  )
42
42
  expect(container).toMatchSnapshot()
43
43
  expect(container.firstChild).toHaveClass('bazinga')