@coreui/react 5.5.0 → 5.7.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 (556) hide show
  1. package/README.md +1 -1
  2. package/dist/cjs/components/accordion/CAccordion.d.ts +0 -6
  3. package/dist/cjs/components/accordion/CAccordion.js +4 -5
  4. package/dist/cjs/components/accordion/CAccordion.js.map +1 -1
  5. package/dist/cjs/components/accordion/CAccordionBody.js +2 -2
  6. package/dist/cjs/components/accordion/CAccordionBody.js.map +1 -1
  7. package/dist/cjs/components/accordion/CAccordionButton.js +2 -2
  8. package/dist/cjs/components/accordion/CAccordionButton.js.map +1 -1
  9. package/dist/cjs/components/accordion/CAccordionContext.d.ts +6 -0
  10. package/dist/cjs/components/accordion/CAccordionContext.js +8 -0
  11. package/dist/cjs/components/accordion/CAccordionContext.js.map +1 -0
  12. package/dist/cjs/components/accordion/CAccordionItem.d.ts +0 -6
  13. package/dist/cjs/components/accordion/CAccordionItem.js +7 -7
  14. package/dist/cjs/components/accordion/CAccordionItem.js.map +1 -1
  15. package/dist/cjs/components/accordion/CAccordionItemContext.d.ts +6 -0
  16. package/dist/cjs/components/accordion/CAccordionItemContext.js +8 -0
  17. package/dist/cjs/components/accordion/CAccordionItemContext.js.map +1 -0
  18. package/dist/cjs/components/alert/CAlert.js +1 -1
  19. package/dist/cjs/components/alert/CAlert.js.map +1 -1
  20. package/dist/cjs/components/alert/CAlertHeading.js +1 -1
  21. package/dist/cjs/components/alert/CAlertHeading.js.map +1 -1
  22. package/dist/cjs/components/backdrop/CBackdrop.js +1 -1
  23. package/dist/cjs/components/backdrop/CBackdrop.js.map +1 -1
  24. package/dist/cjs/components/badge/CBadge.js +5 -5
  25. package/dist/cjs/components/badge/CBadge.js.map +1 -1
  26. package/dist/cjs/components/button/CButton.js +2 -3
  27. package/dist/cjs/components/button/CButton.js.map +1 -1
  28. package/dist/cjs/components/card/CCardHeader.js +1 -1
  29. package/dist/cjs/components/card/CCardHeader.js.map +1 -1
  30. package/dist/cjs/components/card/CCardImage.js +1 -1
  31. package/dist/cjs/components/card/CCardImage.js.map +1 -1
  32. package/dist/cjs/components/card/CCardSubtitle.js +1 -1
  33. package/dist/cjs/components/card/CCardSubtitle.js.map +1 -1
  34. package/dist/cjs/components/card/CCardText.js +1 -1
  35. package/dist/cjs/components/card/CCardText.js.map +1 -1
  36. package/dist/cjs/components/card/CCardTitle.js +1 -1
  37. package/dist/cjs/components/card/CCardTitle.js.map +1 -1
  38. package/dist/cjs/components/carousel/CCarousel.d.ts +0 -5
  39. package/dist/cjs/components/carousel/CCarousel.js +3 -4
  40. package/dist/cjs/components/carousel/CCarousel.js.map +1 -1
  41. package/dist/cjs/components/carousel/CCarouselContext.d.ts +5 -0
  42. package/dist/cjs/components/carousel/CCarouselContext.js +8 -0
  43. package/dist/cjs/components/carousel/CCarouselContext.js.map +1 -0
  44. package/dist/cjs/components/carousel/CCarouselItem.js +9 -9
  45. package/dist/cjs/components/carousel/CCarouselItem.js.map +1 -1
  46. package/dist/cjs/components/dropdown/CDropdown.d.ts +1 -9
  47. package/dist/cjs/components/dropdown/CDropdown.js +27 -19
  48. package/dist/cjs/components/dropdown/CDropdown.js.map +1 -1
  49. package/dist/cjs/components/dropdown/CDropdownContext.d.ts +15 -0
  50. package/dist/cjs/components/dropdown/CDropdownContext.js +8 -0
  51. package/dist/cjs/components/dropdown/CDropdownContext.js.map +1 -0
  52. package/dist/cjs/components/dropdown/CDropdownHeader.js +1 -1
  53. package/dist/cjs/components/dropdown/CDropdownHeader.js.map +1 -1
  54. package/dist/cjs/components/dropdown/CDropdownItem.js +1 -1
  55. package/dist/cjs/components/dropdown/CDropdownItem.js.map +1 -1
  56. package/dist/cjs/components/dropdown/CDropdownItemPlain.js +1 -1
  57. package/dist/cjs/components/dropdown/CDropdownItemPlain.js.map +1 -1
  58. package/dist/cjs/components/dropdown/CDropdownMenu.js +4 -4
  59. package/dist/cjs/components/dropdown/CDropdownMenu.js.map +1 -1
  60. package/dist/cjs/components/dropdown/CDropdownToggle.js +3 -3
  61. package/dist/cjs/components/dropdown/CDropdownToggle.js.map +1 -1
  62. package/dist/cjs/components/form/CFormCheck.js +1 -1
  63. package/dist/cjs/components/form/CFormCheck.js.map +1 -1
  64. package/dist/cjs/components/form/CFormFeedback.js +1 -1
  65. package/dist/cjs/components/form/CFormFeedback.js.map +1 -1
  66. package/dist/cjs/components/form/CFormInput.js +1 -1
  67. package/dist/cjs/components/form/CFormInput.js.map +1 -1
  68. package/dist/cjs/components/form/CFormLabel.js +1 -1
  69. package/dist/cjs/components/form/CFormLabel.js.map +1 -1
  70. package/dist/cjs/components/form/CFormSwitch.js +1 -1
  71. package/dist/cjs/components/form/CFormSwitch.js.map +1 -1
  72. package/dist/cjs/components/form/CFormText.js +1 -1
  73. package/dist/cjs/components/form/CFormText.js.map +1 -1
  74. package/dist/cjs/components/form/CInputGroupText.js +1 -1
  75. package/dist/cjs/components/form/CInputGroupText.js.map +1 -1
  76. package/dist/cjs/components/header/CHeaderBrand.js +1 -1
  77. package/dist/cjs/components/header/CHeaderBrand.js.map +1 -1
  78. package/dist/cjs/components/header/CHeaderNav.js +1 -1
  79. package/dist/cjs/components/header/CHeaderNav.js.map +1 -1
  80. package/dist/cjs/components/header/CHeaderToggler.js +1 -1
  81. package/dist/cjs/components/header/CHeaderToggler.js.map +1 -1
  82. package/dist/cjs/components/link/CLink.js +1 -1
  83. package/dist/cjs/components/link/CLink.js.map +1 -1
  84. package/dist/cjs/components/list-group/CListGroup.js +1 -1
  85. package/dist/cjs/components/list-group/CListGroup.js.map +1 -1
  86. package/dist/cjs/components/list-group/CListGroupItem.js +1 -1
  87. package/dist/cjs/components/list-group/CListGroupItem.js.map +1 -1
  88. package/dist/cjs/components/modal/CModal.d.ts +0 -6
  89. package/dist/cjs/components/modal/CModal.js +5 -6
  90. package/dist/cjs/components/modal/CModal.js.map +1 -1
  91. package/dist/cjs/components/modal/CModalContext.d.ts +5 -0
  92. package/dist/cjs/components/modal/CModalContext.js +8 -0
  93. package/dist/cjs/components/modal/CModalContext.js.map +1 -0
  94. package/dist/cjs/components/modal/CModalHeader.js +3 -3
  95. package/dist/cjs/components/modal/CModalHeader.js.map +1 -1
  96. package/dist/cjs/components/modal/CModalTitle.js +1 -1
  97. package/dist/cjs/components/modal/CModalTitle.js.map +1 -1
  98. package/dist/cjs/components/nav/CNav.d.ts +1 -1
  99. package/dist/cjs/components/nav/CNav.js +10 -3
  100. package/dist/cjs/components/nav/CNav.js.map +1 -1
  101. package/dist/cjs/components/nav/CNavGroup.js +5 -5
  102. package/dist/cjs/components/nav/CNavGroup.js.map +1 -1
  103. package/dist/cjs/components/nav/CNavGroupItems.js +1 -1
  104. package/dist/cjs/components/nav/CNavGroupItems.js.map +1 -1
  105. package/dist/cjs/components/nav/CNavItem.js +1 -1
  106. package/dist/cjs/components/nav/CNavItem.js.map +1 -1
  107. package/dist/cjs/components/nav/CNavLink.js +3 -3
  108. package/dist/cjs/components/nav/CNavLink.js.map +1 -1
  109. package/dist/cjs/components/nav/CNavTitle.js +1 -1
  110. package/dist/cjs/components/nav/CNavTitle.js.map +1 -1
  111. package/dist/cjs/components/navbar/CNavbar.js +1 -1
  112. package/dist/cjs/components/navbar/CNavbar.js.map +1 -1
  113. package/dist/cjs/components/navbar/CNavbarBrand.js +1 -1
  114. package/dist/cjs/components/navbar/CNavbarBrand.js.map +1 -1
  115. package/dist/cjs/components/navbar/CNavbarNav.js +1 -1
  116. package/dist/cjs/components/navbar/CNavbarNav.js.map +1 -1
  117. package/dist/cjs/components/navbar/CNavbarToggler.js +1 -1
  118. package/dist/cjs/components/navbar/CNavbarToggler.js.map +1 -1
  119. package/dist/cjs/components/offcanvas/COffcanvas.js +2 -2
  120. package/dist/cjs/components/offcanvas/COffcanvas.js.map +1 -1
  121. package/dist/cjs/components/offcanvas/COffcanvasTitle.js +1 -1
  122. package/dist/cjs/components/offcanvas/COffcanvasTitle.js.map +1 -1
  123. package/dist/cjs/components/pagination/CPaginationItem.js +1 -1
  124. package/dist/cjs/components/pagination/CPaginationItem.js.map +1 -1
  125. package/dist/cjs/components/placeholder/CPlaceholder.js +1 -1
  126. package/dist/cjs/components/placeholder/CPlaceholder.js.map +1 -1
  127. package/dist/cjs/components/popover/CPopover.js +1 -1
  128. package/dist/cjs/components/popover/CPopover.js.map +1 -1
  129. package/dist/cjs/components/progress/CProgress.js +2 -2
  130. package/dist/cjs/components/progress/CProgress.js.map +1 -1
  131. package/dist/cjs/components/progress/CProgressBar.js +3 -3
  132. package/dist/cjs/components/progress/CProgressBar.js.map +1 -1
  133. package/dist/cjs/components/progress/CProgressStacked.d.ts +0 -4
  134. package/dist/cjs/components/progress/CProgressStacked.js +2 -3
  135. package/dist/cjs/components/progress/CProgressStacked.js.map +1 -1
  136. package/dist/cjs/components/progress/CProgressStackedContext.d.ts +4 -0
  137. package/dist/cjs/components/progress/CProgressStackedContext.js +8 -0
  138. package/dist/cjs/components/progress/CProgressStackedContext.js.map +1 -0
  139. package/dist/cjs/components/sidebar/CSidebar.js +5 -5
  140. package/dist/cjs/components/sidebar/CSidebar.js.map +1 -1
  141. package/dist/cjs/components/sidebar/CSidebarBrand.js +1 -1
  142. package/dist/cjs/components/sidebar/CSidebarBrand.js.map +1 -1
  143. package/dist/cjs/components/sidebar/CSidebarNav.d.ts +1 -7
  144. package/dist/cjs/components/sidebar/CSidebarNav.js +16 -15
  145. package/dist/cjs/components/sidebar/CSidebarNav.js.map +1 -1
  146. package/dist/cjs/components/sidebar/CSidebarNavContext.d.ts +5 -0
  147. package/dist/cjs/components/sidebar/CSidebarNavContext.js +8 -0
  148. package/dist/cjs/components/sidebar/CSidebarNavContext.js.map +1 -0
  149. package/dist/cjs/components/spinner/CSpinner.js +1 -1
  150. package/dist/cjs/components/spinner/CSpinner.js.map +1 -1
  151. package/dist/cjs/components/table/utils.js +1 -1
  152. package/dist/cjs/components/table/utils.js.map +1 -1
  153. package/dist/cjs/components/tabs/CTab.js +2 -2
  154. package/dist/cjs/components/tabs/CTab.js.map +1 -1
  155. package/dist/cjs/components/tabs/CTabList.d.ts +1 -1
  156. package/dist/cjs/components/tabs/CTabList.js +10 -3
  157. package/dist/cjs/components/tabs/CTabList.js.map +1 -1
  158. package/dist/cjs/components/tabs/CTabPane.js +2 -2
  159. package/dist/cjs/components/tabs/CTabPane.js.map +1 -1
  160. package/dist/cjs/components/tabs/CTabPanel.js +4 -4
  161. package/dist/cjs/components/tabs/CTabPanel.js.map +1 -1
  162. package/dist/cjs/components/tabs/CTabs.d.ts +29 -9
  163. package/dist/cjs/components/tabs/CTabs.js +14 -9
  164. package/dist/cjs/components/tabs/CTabs.js.map +1 -1
  165. package/dist/cjs/components/tabs/CTabsContext.d.ts +6 -0
  166. package/dist/cjs/components/tabs/CTabsContext.js +8 -0
  167. package/dist/cjs/components/tabs/CTabsContext.js.map +1 -0
  168. package/dist/cjs/components/toast/CToast.d.ts +0 -6
  169. package/dist/cjs/components/toast/CToast.js +7 -11
  170. package/dist/cjs/components/toast/CToast.js.map +1 -1
  171. package/dist/cjs/components/toast/CToastClose.js +2 -2
  172. package/dist/cjs/components/toast/CToastClose.js.map +1 -1
  173. package/dist/cjs/components/toast/CToastContext.d.ts +5 -0
  174. package/dist/cjs/components/toast/CToastContext.js +8 -0
  175. package/dist/cjs/components/toast/CToastContext.js.map +1 -0
  176. package/dist/cjs/components/toast/CToaster.d.ts +2 -1
  177. package/dist/cjs/components/toast/CToaster.js +4 -2
  178. package/dist/cjs/components/toast/CToaster.js.map +1 -1
  179. package/dist/cjs/components/tooltip/CTooltip.js +1 -1
  180. package/dist/cjs/components/tooltip/CTooltip.js.map +1 -1
  181. package/dist/cjs/components/widgets/CWidgetStatsF.js +1 -1
  182. package/dist/cjs/components/widgets/CWidgetStatsF.js.map +1 -1
  183. package/dist/cjs/hooks/useClipboard.js +2 -2
  184. package/dist/cjs/hooks/useClipboard.js.map +1 -1
  185. package/dist/cjs/hooks/useColorModes.js +1 -1
  186. package/dist/cjs/hooks/useColorModes.js.map +1 -1
  187. package/dist/cjs/hooks/usePopper.js +2 -2
  188. package/dist/cjs/hooks/usePopper.js.map +1 -1
  189. package/dist/cjs/node_modules/react-transition-group/esm/Transition.js +2 -2
  190. package/dist/cjs/node_modules/react-transition-group/esm/Transition.js.map +1 -1
  191. package/dist/cjs/node_modules/tslib/tslib.es6.js +1 -1
  192. package/dist/cjs/node_modules/tslib/tslib.es6.js.map +1 -1
  193. package/dist/cjs/utils/executeAfterTransition.js +1 -1
  194. package/dist/cjs/utils/executeAfterTransition.js.map +1 -1
  195. package/dist/esm/components/accordion/CAccordion.d.ts +0 -6
  196. package/dist/esm/components/accordion/CAccordion.js +5 -5
  197. package/dist/esm/components/accordion/CAccordion.js.map +1 -1
  198. package/dist/esm/components/accordion/CAccordionBody.js +1 -1
  199. package/dist/esm/components/accordion/CAccordionBody.js.map +1 -1
  200. package/dist/esm/components/accordion/CAccordionButton.js +1 -1
  201. package/dist/esm/components/accordion/CAccordionContext.d.ts +6 -0
  202. package/dist/esm/components/accordion/CAccordionContext.js +6 -0
  203. package/dist/esm/components/accordion/CAccordionContext.js.map +1 -0
  204. package/dist/esm/components/accordion/CAccordionItem.d.ts +0 -6
  205. package/dist/esm/components/accordion/CAccordionItem.js +7 -6
  206. package/dist/esm/components/accordion/CAccordionItem.js.map +1 -1
  207. package/dist/esm/components/accordion/CAccordionItemContext.d.ts +6 -0
  208. package/dist/esm/components/accordion/CAccordionItemContext.js +6 -0
  209. package/dist/esm/components/accordion/CAccordionItemContext.js.map +1 -0
  210. package/dist/esm/components/alert/CAlert.js +1 -1
  211. package/dist/esm/components/alert/CAlert.js.map +1 -1
  212. package/dist/esm/components/alert/CAlertHeading.js +1 -1
  213. package/dist/esm/components/alert/CAlertHeading.js.map +1 -1
  214. package/dist/esm/components/backdrop/CBackdrop.js +1 -1
  215. package/dist/esm/components/backdrop/CBackdrop.js.map +1 -1
  216. package/dist/esm/components/badge/CBadge.js +5 -5
  217. package/dist/esm/components/badge/CBadge.js.map +1 -1
  218. package/dist/esm/components/button/CButton.js +2 -3
  219. package/dist/esm/components/button/CButton.js.map +1 -1
  220. package/dist/esm/components/card/CCardHeader.js +1 -1
  221. package/dist/esm/components/card/CCardHeader.js.map +1 -1
  222. package/dist/esm/components/card/CCardImage.js +1 -1
  223. package/dist/esm/components/card/CCardImage.js.map +1 -1
  224. package/dist/esm/components/card/CCardSubtitle.js +1 -1
  225. package/dist/esm/components/card/CCardSubtitle.js.map +1 -1
  226. package/dist/esm/components/card/CCardText.js +1 -1
  227. package/dist/esm/components/card/CCardText.js.map +1 -1
  228. package/dist/esm/components/card/CCardTitle.js +1 -1
  229. package/dist/esm/components/card/CCardTitle.js.map +1 -1
  230. package/dist/esm/components/carousel/CCarousel.d.ts +0 -5
  231. package/dist/esm/components/carousel/CCarousel.js +4 -4
  232. package/dist/esm/components/carousel/CCarousel.js.map +1 -1
  233. package/dist/esm/components/carousel/CCarouselContext.d.ts +5 -0
  234. package/dist/esm/components/carousel/CCarouselContext.js +6 -0
  235. package/dist/esm/components/carousel/CCarouselContext.js.map +1 -0
  236. package/dist/esm/components/carousel/CCarouselItem.js +8 -8
  237. package/dist/esm/components/carousel/CCarouselItem.js.map +1 -1
  238. package/dist/esm/components/dropdown/CDropdown.d.ts +1 -9
  239. package/dist/esm/components/dropdown/CDropdown.js +28 -19
  240. package/dist/esm/components/dropdown/CDropdown.js.map +1 -1
  241. package/dist/esm/components/dropdown/CDropdownContext.d.ts +15 -0
  242. package/dist/esm/components/dropdown/CDropdownContext.js +6 -0
  243. package/dist/esm/components/dropdown/CDropdownContext.js.map +1 -0
  244. package/dist/esm/components/dropdown/CDropdownHeader.js +1 -1
  245. package/dist/esm/components/dropdown/CDropdownHeader.js.map +1 -1
  246. package/dist/esm/components/dropdown/CDropdownItem.js +1 -1
  247. package/dist/esm/components/dropdown/CDropdownItem.js.map +1 -1
  248. package/dist/esm/components/dropdown/CDropdownItemPlain.js +1 -1
  249. package/dist/esm/components/dropdown/CDropdownItemPlain.js.map +1 -1
  250. package/dist/esm/components/dropdown/CDropdownMenu.js +3 -3
  251. package/dist/esm/components/dropdown/CDropdownMenu.js.map +1 -1
  252. package/dist/esm/components/dropdown/CDropdownToggle.js +2 -2
  253. package/dist/esm/components/dropdown/CDropdownToggle.js.map +1 -1
  254. package/dist/esm/components/form/CFormCheck.js +1 -1
  255. package/dist/esm/components/form/CFormCheck.js.map +1 -1
  256. package/dist/esm/components/form/CFormFeedback.js +1 -1
  257. package/dist/esm/components/form/CFormFeedback.js.map +1 -1
  258. package/dist/esm/components/form/CFormInput.js +1 -1
  259. package/dist/esm/components/form/CFormInput.js.map +1 -1
  260. package/dist/esm/components/form/CFormLabel.js +1 -1
  261. package/dist/esm/components/form/CFormLabel.js.map +1 -1
  262. package/dist/esm/components/form/CFormSwitch.js +1 -1
  263. package/dist/esm/components/form/CFormSwitch.js.map +1 -1
  264. package/dist/esm/components/form/CFormText.js +1 -1
  265. package/dist/esm/components/form/CFormText.js.map +1 -1
  266. package/dist/esm/components/form/CInputGroupText.js +1 -1
  267. package/dist/esm/components/form/CInputGroupText.js.map +1 -1
  268. package/dist/esm/components/header/CHeaderBrand.js +1 -1
  269. package/dist/esm/components/header/CHeaderBrand.js.map +1 -1
  270. package/dist/esm/components/header/CHeaderNav.js +1 -1
  271. package/dist/esm/components/header/CHeaderNav.js.map +1 -1
  272. package/dist/esm/components/header/CHeaderToggler.js +1 -1
  273. package/dist/esm/components/header/CHeaderToggler.js.map +1 -1
  274. package/dist/esm/components/link/CLink.js +1 -1
  275. package/dist/esm/components/link/CLink.js.map +1 -1
  276. package/dist/esm/components/list-group/CListGroup.js +1 -1
  277. package/dist/esm/components/list-group/CListGroup.js.map +1 -1
  278. package/dist/esm/components/list-group/CListGroupItem.js +1 -1
  279. package/dist/esm/components/list-group/CListGroupItem.js.map +1 -1
  280. package/dist/esm/components/modal/CModal.d.ts +0 -6
  281. package/dist/esm/components/modal/CModal.js +6 -6
  282. package/dist/esm/components/modal/CModal.js.map +1 -1
  283. package/dist/esm/components/modal/CModalContext.d.ts +5 -0
  284. package/dist/esm/components/modal/CModalContext.js +6 -0
  285. package/dist/esm/components/modal/CModalContext.js.map +1 -0
  286. package/dist/esm/components/modal/CModalHeader.js +2 -2
  287. package/dist/esm/components/modal/CModalHeader.js.map +1 -1
  288. package/dist/esm/components/modal/CModalTitle.js +1 -1
  289. package/dist/esm/components/modal/CModalTitle.js.map +1 -1
  290. package/dist/esm/components/nav/CNav.d.ts +1 -1
  291. package/dist/esm/components/nav/CNav.js +10 -3
  292. package/dist/esm/components/nav/CNav.js.map +1 -1
  293. package/dist/esm/components/nav/CNavGroup.js +5 -5
  294. package/dist/esm/components/nav/CNavGroup.js.map +1 -1
  295. package/dist/esm/components/nav/CNavGroupItems.js +1 -1
  296. package/dist/esm/components/nav/CNavGroupItems.js.map +1 -1
  297. package/dist/esm/components/nav/CNavItem.js +1 -1
  298. package/dist/esm/components/nav/CNavItem.js.map +1 -1
  299. package/dist/esm/components/nav/CNavLink.js +3 -3
  300. package/dist/esm/components/nav/CNavLink.js.map +1 -1
  301. package/dist/esm/components/nav/CNavTitle.js +1 -1
  302. package/dist/esm/components/nav/CNavTitle.js.map +1 -1
  303. package/dist/esm/components/navbar/CNavbar.js +1 -1
  304. package/dist/esm/components/navbar/CNavbar.js.map +1 -1
  305. package/dist/esm/components/navbar/CNavbarBrand.js +1 -1
  306. package/dist/esm/components/navbar/CNavbarBrand.js.map +1 -1
  307. package/dist/esm/components/navbar/CNavbarNav.js +1 -1
  308. package/dist/esm/components/navbar/CNavbarNav.js.map +1 -1
  309. package/dist/esm/components/navbar/CNavbarToggler.js +1 -1
  310. package/dist/esm/components/navbar/CNavbarToggler.js.map +1 -1
  311. package/dist/esm/components/offcanvas/COffcanvas.js +2 -2
  312. package/dist/esm/components/offcanvas/COffcanvas.js.map +1 -1
  313. package/dist/esm/components/offcanvas/COffcanvasTitle.js +1 -1
  314. package/dist/esm/components/offcanvas/COffcanvasTitle.js.map +1 -1
  315. package/dist/esm/components/pagination/CPaginationItem.js +1 -1
  316. package/dist/esm/components/pagination/CPaginationItem.js.map +1 -1
  317. package/dist/esm/components/placeholder/CPlaceholder.js +1 -1
  318. package/dist/esm/components/placeholder/CPlaceholder.js.map +1 -1
  319. package/dist/esm/components/popover/CPopover.js +1 -1
  320. package/dist/esm/components/popover/CPopover.js.map +1 -1
  321. package/dist/esm/components/progress/CProgress.js +1 -1
  322. package/dist/esm/components/progress/CProgressBar.js +2 -2
  323. package/dist/esm/components/progress/CProgressBar.js.map +1 -1
  324. package/dist/esm/components/progress/CProgressStacked.d.ts +0 -4
  325. package/dist/esm/components/progress/CProgressStacked.js +3 -3
  326. package/dist/esm/components/progress/CProgressStacked.js.map +1 -1
  327. package/dist/esm/components/progress/CProgressStackedContext.d.ts +4 -0
  328. package/dist/esm/components/progress/CProgressStackedContext.js +6 -0
  329. package/dist/esm/components/progress/CProgressStackedContext.js.map +1 -0
  330. package/dist/esm/components/sidebar/CSidebar.js +5 -5
  331. package/dist/esm/components/sidebar/CSidebar.js.map +1 -1
  332. package/dist/esm/components/sidebar/CSidebarBrand.js +1 -1
  333. package/dist/esm/components/sidebar/CSidebarBrand.js.map +1 -1
  334. package/dist/esm/components/sidebar/CSidebarNav.d.ts +1 -7
  335. package/dist/esm/components/sidebar/CSidebarNav.js +18 -16
  336. package/dist/esm/components/sidebar/CSidebarNav.js.map +1 -1
  337. package/dist/esm/components/sidebar/CSidebarNavContext.d.ts +5 -0
  338. package/dist/esm/components/sidebar/CSidebarNavContext.js +6 -0
  339. package/dist/esm/components/sidebar/CSidebarNavContext.js.map +1 -0
  340. package/dist/esm/components/spinner/CSpinner.js +1 -1
  341. package/dist/esm/components/spinner/CSpinner.js.map +1 -1
  342. package/dist/esm/components/table/utils.js +1 -1
  343. package/dist/esm/components/table/utils.js.map +1 -1
  344. package/dist/esm/components/tabs/CTab.js +2 -2
  345. package/dist/esm/components/tabs/CTab.js.map +1 -1
  346. package/dist/esm/components/tabs/CTabList.d.ts +1 -1
  347. package/dist/esm/components/tabs/CTabList.js +10 -3
  348. package/dist/esm/components/tabs/CTabList.js.map +1 -1
  349. package/dist/esm/components/tabs/CTabPane.js +2 -2
  350. package/dist/esm/components/tabs/CTabPane.js.map +1 -1
  351. package/dist/esm/components/tabs/CTabPanel.js +4 -4
  352. package/dist/esm/components/tabs/CTabPanel.js.map +1 -1
  353. package/dist/esm/components/tabs/CTabs.d.ts +29 -9
  354. package/dist/esm/components/tabs/CTabs.js +16 -10
  355. package/dist/esm/components/tabs/CTabs.js.map +1 -1
  356. package/dist/esm/components/tabs/CTabsContext.d.ts +6 -0
  357. package/dist/esm/components/tabs/CTabsContext.js +6 -0
  358. package/dist/esm/components/tabs/CTabsContext.js.map +1 -0
  359. package/dist/esm/components/toast/CToast.d.ts +0 -6
  360. package/dist/esm/components/toast/CToast.js +8 -11
  361. package/dist/esm/components/toast/CToast.js.map +1 -1
  362. package/dist/esm/components/toast/CToastClose.js +1 -1
  363. package/dist/esm/components/toast/CToastClose.js.map +1 -1
  364. package/dist/esm/components/toast/CToastContext.d.ts +5 -0
  365. package/dist/esm/components/toast/CToastContext.js +6 -0
  366. package/dist/esm/components/toast/CToastContext.js.map +1 -0
  367. package/dist/esm/components/toast/CToaster.d.ts +2 -1
  368. package/dist/esm/components/toast/CToaster.js +4 -2
  369. package/dist/esm/components/toast/CToaster.js.map +1 -1
  370. package/dist/esm/components/tooltip/CTooltip.js +1 -1
  371. package/dist/esm/components/tooltip/CTooltip.js.map +1 -1
  372. package/dist/esm/components/widgets/CWidgetStatsF.js +1 -1
  373. package/dist/esm/components/widgets/CWidgetStatsF.js.map +1 -1
  374. package/dist/esm/hooks/useClipboard.js +2 -2
  375. package/dist/esm/hooks/useClipboard.js.map +1 -1
  376. package/dist/esm/hooks/useColorModes.js +1 -1
  377. package/dist/esm/hooks/useColorModes.js.map +1 -1
  378. package/dist/esm/hooks/usePopper.js +2 -2
  379. package/dist/esm/hooks/usePopper.js.map +1 -1
  380. package/dist/esm/node_modules/react-transition-group/esm/Transition.js +2 -2
  381. package/dist/esm/node_modules/react-transition-group/esm/Transition.js.map +1 -1
  382. package/dist/esm/node_modules/tslib/tslib.es6.js +1 -1
  383. package/dist/esm/node_modules/tslib/tslib.es6.js.map +1 -1
  384. package/dist/esm/utils/executeAfterTransition.js +1 -1
  385. package/dist/esm/utils/executeAfterTransition.js.map +1 -1
  386. package/package.json +11 -11
  387. package/src/components/accordion/CAccordion.tsx +4 -10
  388. package/src/components/accordion/CAccordionBody.tsx +1 -2
  389. package/src/components/accordion/CAccordionButton.tsx +2 -2
  390. package/src/components/accordion/CAccordionContext.ts +9 -0
  391. package/src/components/accordion/CAccordionItem.tsx +4 -11
  392. package/src/components/accordion/CAccordionItemContext.ts +9 -0
  393. package/src/components/accordion/__tests__/CAccordion.spec.tsx +1 -1
  394. package/src/components/accordion/__tests__/CAccordionBody.spec.tsx +1 -1
  395. package/src/components/accordion/__tests__/CAccordionButton.spec.tsx +1 -1
  396. package/src/components/accordion/__tests__/CAccordionHeader.spec.tsx +1 -1
  397. package/src/components/accordion/__tests__/CAccordionItem.spec.tsx +1 -1
  398. package/src/components/alert/__tests__/CAlert.spec.tsx +39 -18
  399. package/src/components/alert/__tests__/CAlertHeading.spec.tsx +1 -1
  400. package/src/components/alert/__tests__/CAlertLink.spec.tsx +1 -1
  401. package/src/components/avatar/__tests__/CAvatar.spec.tsx +1 -1
  402. package/src/components/backdrop/__tests__/CBackdrop.spec.tsx +1 -1
  403. package/src/components/badge/__tests__/CBadge.spec.tsx +1 -1
  404. package/src/components/breadcrumb/__tests__/CBreadcrumb.spec.tsx +1 -1
  405. package/src/components/breadcrumb/__tests__/CBreadcrumbItem.spec.tsx +1 -1
  406. package/src/components/button/CButton.tsx +4 -4
  407. package/src/components/button/__tests__/CButton.spec.tsx +1 -1
  408. package/src/components/button-group/__tests__/CButtonGroup.spec.tsx +2 -1
  409. package/src/components/button-group/__tests__/CButtonToolbar.spec.tsx +2 -1
  410. package/src/components/callout/__tests__/CCallout.spec.tsx +1 -1
  411. package/src/components/card/__tests__/CCard.spec.tsx +1 -1
  412. package/src/components/card/__tests__/CCardBody.spec.tsx +1 -1
  413. package/src/components/card/__tests__/CCardFooter.spec.tsx +1 -1
  414. package/src/components/card/__tests__/CCardGroup.spec.tsx +1 -1
  415. package/src/components/card/__tests__/CCardHeader.spec.tsx +1 -1
  416. package/src/components/card/__tests__/CCardImage.spec.tsx +1 -1
  417. package/src/components/card/__tests__/CCardImageOverlay.spec.tsx +1 -1
  418. package/src/components/card/__tests__/CCardLink.spec.tsx +1 -1
  419. package/src/components/card/__tests__/CCardSubtitle.spec.tsx +1 -1
  420. package/src/components/card/__tests__/CCardText.spec.tsx +1 -1
  421. package/src/components/card/__tests__/CCardTitle.spec.tsx +1 -1
  422. package/src/components/carousel/CCarousel.tsx +6 -12
  423. package/src/components/carousel/CCarouselCaption.tsx +1 -1
  424. package/src/components/carousel/CCarouselContext.ts +8 -0
  425. package/src/components/carousel/CCarouselItem.tsx +6 -4
  426. package/src/components/carousel/__tests__/CCarousel.spec.tsx +1 -1
  427. package/src/components/close-button/__tests__/CCloseButton.spec.tsx +1 -1
  428. package/src/components/collapse/__tests__/CCollapse.spec.tsx +26 -7
  429. package/src/components/dropdown/CDropdown.tsx +35 -36
  430. package/src/components/dropdown/CDropdownContext.ts +18 -0
  431. package/src/components/dropdown/CDropdownDivider.tsx +1 -1
  432. package/src/components/dropdown/CDropdownHeader.tsx +1 -1
  433. package/src/components/dropdown/CDropdownItemPlain.tsx +1 -1
  434. package/src/components/dropdown/CDropdownMenu.tsx +3 -3
  435. package/src/components/dropdown/CDropdownToggle.tsx +2 -3
  436. package/src/components/dropdown/__tests__/CDropdown.spec.tsx +1 -1
  437. package/src/components/dropdown/__tests__/CDropdownDivider.spec.tsx +1 -1
  438. package/src/components/dropdown/__tests__/CDropdownHeader.spec.tsx +1 -1
  439. package/src/components/dropdown/__tests__/CDropdownItem.spec.tsx +1 -1
  440. package/src/components/dropdown/__tests__/CDropdownItemPlain.spec.tsx +1 -1
  441. package/src/components/dropdown/__tests__/CDropdownMenu.spec.tsx +1 -1
  442. package/src/components/dropdown/__tests__/CDropdownToggle.spec.tsx +1 -1
  443. package/src/components/dropdown/__tests__/__snapshots__/CDropdown.spec.tsx.snap +0 -1
  444. package/src/components/dropdown/__tests__/__snapshots__/CDropdownMenu.spec.tsx.snap +0 -2
  445. package/src/components/footer/__tests__/CFooter.spec.tsx +1 -1
  446. package/src/components/form/__tests__/CForm.spec.tsx +2 -1
  447. package/src/components/form/__tests__/CFormCheck.spec.tsx +1 -1
  448. package/src/components/form/__tests__/CFormControl.spec.tsx +1 -1
  449. package/src/components/form/__tests__/CFormFeedback.spec.tsx +1 -1
  450. package/src/components/form/__tests__/CFormFloating.spec.tsx +1 -1
  451. package/src/components/form/__tests__/CFormInput.spec.tsx +1 -1
  452. package/src/components/form/__tests__/CFormLabel.spec.tsx +1 -1
  453. package/src/components/form/__tests__/CFormRange.spec.tsx +1 -1
  454. package/src/components/form/__tests__/CFormSelect.spec.tsx +1 -1
  455. package/src/components/form/__tests__/CFormSwitch.spec.tsx +1 -1
  456. package/src/components/form/__tests__/CFormText.spec.tsx +1 -1
  457. package/src/components/form/__tests__/CFormTextarea.spec.tsx +1 -1
  458. package/src/components/form/__tests__/CInputGroup.spec.tsx +1 -1
  459. package/src/components/form/__tests__/CInputGroupText.spec.tsx +1 -1
  460. package/src/components/grid/__tests__/CCol.spec.tsx +1 -1
  461. package/src/components/grid/__tests__/CContainer.spec.tsx +1 -1
  462. package/src/components/grid/__tests__/CRow.spec.tsx +1 -1
  463. package/src/components/header/__tests__/CHeader.spec.tsx +1 -1
  464. package/src/components/header/__tests__/CHeaderBrand.spec.tsx +1 -1
  465. package/src/components/header/__tests__/CHeaderDivider.spec.tsx +1 -1
  466. package/src/components/header/__tests__/CHeaderNav.spec.tsx +1 -1
  467. package/src/components/header/__tests__/CHeaderText.spec.tsx +1 -1
  468. package/src/components/header/__tests__/CHeaderToggler.spec.tsx +1 -1
  469. package/src/components/image/__tests__/CImage.spec.tsx +1 -1
  470. package/src/components/link/__tests__/CLink.spec.tsx +1 -1
  471. package/src/components/list-group/__tests__/CListGroup.spec.tsx +1 -1
  472. package/src/components/list-group/__tests__/CListGroupItem.spec.tsx +1 -1
  473. package/src/components/modal/CModal.tsx +5 -12
  474. package/src/components/modal/CModalContext.ts +8 -0
  475. package/src/components/modal/CModalHeader.tsx +1 -1
  476. package/src/components/modal/__tests__/CModal.spec.tsx +1 -1
  477. package/src/components/modal/__tests__/CModalBody.spec.tsx +1 -1
  478. package/src/components/modal/__tests__/CModalContent.spec.tsx +1 -1
  479. package/src/components/modal/__tests__/CModalDialog.spec.tsx +1 -1
  480. package/src/components/modal/__tests__/CModalFooter.spec.tsx +1 -1
  481. package/src/components/modal/__tests__/CModalHeader.spec.tsx +1 -1
  482. package/src/components/modal/__tests__/CModalTitle.spec.tsx +1 -1
  483. package/src/components/nav/CNav.tsx +11 -3
  484. package/src/components/nav/CNavGroup.tsx +2 -2
  485. package/src/components/nav/CNavLink.tsx +2 -2
  486. package/src/components/nav/__tests__/CNav.spec.tsx +4 -11
  487. package/src/components/nav/__tests__/CNavGroup.spec.tsx +1 -1
  488. package/src/components/nav/__tests__/CNavGroupItems.spec.tsx +1 -1
  489. package/src/components/nav/__tests__/CNavItem.spec.tsx +1 -1
  490. package/src/components/nav/__tests__/CNavLink.spec.tsx +1 -1
  491. package/src/components/nav/__tests__/CNavTitle.spec.tsx +1 -1
  492. package/src/components/nav/__tests__/__snapshots__/CNav.spec.tsx.snap +0 -1
  493. package/src/components/navbar/__tests__/CNavbar.spec.tsx +1 -1
  494. package/src/components/navbar/__tests__/CNavbarBrand.spec.tsx +1 -1
  495. package/src/components/navbar/__tests__/CNavbarNav.spec.tsx +1 -1
  496. package/src/components/navbar/__tests__/CNavbarText.spec.tsx +1 -1
  497. package/src/components/navbar/__tests__/CNavbarToggler.spec.tsx +1 -1
  498. package/src/components/offcanvas/__tests__/COffcanvas.spec.tsx +45 -17
  499. package/src/components/offcanvas/__tests__/COffcanvasBody.spec.tsx +1 -1
  500. package/src/components/offcanvas/__tests__/COffcanvasHeader.spec.tsx +1 -1
  501. package/src/components/offcanvas/__tests__/COffcanvasTitle.spec.tsx +1 -1
  502. package/src/components/pagination/__tests__/CPagination.spec.tsx +1 -1
  503. package/src/components/pagination/__tests__/CPaginationItem.spec.tsx +1 -1
  504. package/src/components/placeholder/__tests__/CPlaceholder.spec.tsx +1 -1
  505. package/src/components/popover/__tests__/CPopover.spec.tsx +70 -62
  506. package/src/components/popover/__tests__/__snapshots__/CPopover.spec.tsx.snap +0 -32
  507. package/src/components/progress/CProgress.tsx +1 -1
  508. package/src/components/progress/CProgressBar.tsx +2 -1
  509. package/src/components/progress/CProgressStacked.tsx +4 -8
  510. package/src/components/progress/CProgressStackedContext.ts +7 -0
  511. package/src/components/progress/__tests__/CProgress.spec.tsx +1 -1
  512. package/src/components/progress/__tests__/CProgressBar.spec.tsx +1 -1
  513. package/src/components/sidebar/CSidebarNav.tsx +27 -27
  514. package/src/components/sidebar/CSidebarNavContext.ts +8 -0
  515. package/src/components/sidebar/__tests__/CSidebar.spec.tsx +1 -1
  516. package/src/components/sidebar/__tests__/CSidebarBrand.spec.tsx +1 -1
  517. package/src/components/sidebar/__tests__/CSidebarFooter.spec.tsx +1 -1
  518. package/src/components/sidebar/__tests__/CSidebarHeader.spec.tsx +1 -1
  519. package/src/components/sidebar/__tests__/CSidebarNav.spec.tsx +1 -1
  520. package/src/components/sidebar/__tests__/CSidebarToggler.spec.tsx +1 -1
  521. package/src/components/spinner/__tests__/CSpinner.spec.tsx +1 -1
  522. package/src/components/table/__tests__/CTable.spec.tsx +1 -1
  523. package/src/components/table/__tests__/CTableBody.spec.tsx +1 -1
  524. package/src/components/table/__tests__/CTableCaption.spec.tsx +1 -1
  525. package/src/components/table/__tests__/CTableDataCell.spec.tsx +1 -1
  526. package/src/components/table/__tests__/CTableFoot.spec.tsx +1 -1
  527. package/src/components/table/__tests__/CTableHead.spec.tsx +1 -1
  528. package/src/components/table/__tests__/CTableHeaderCell.spec.tsx +1 -1
  529. package/src/components/table/__tests__/CTableRow.spec.tsx +1 -1
  530. package/src/components/tabs/CTab.tsx +2 -2
  531. package/src/components/tabs/CTabList.tsx +14 -6
  532. package/src/components/tabs/CTabPane.tsx +1 -1
  533. package/src/components/tabs/CTabPanel.tsx +3 -3
  534. package/src/components/tabs/CTabs.tsx +54 -21
  535. package/src/components/tabs/CTabsContext.ts +9 -0
  536. package/src/components/tabs/__tests__/CTabContent.spec.tsx +17 -8
  537. package/src/components/tabs/__tests__/CTabPane.spec.tsx +49 -29
  538. package/src/components/toast/CToast.tsx +9 -24
  539. package/src/components/toast/CToastClose.tsx +1 -2
  540. package/src/components/toast/CToastContext.ts +8 -0
  541. package/src/components/toast/CToaster.tsx +11 -7
  542. package/src/components/toast/__tests__/CToast.spec.tsx +32 -27
  543. package/src/components/toast/__tests__/CToastBody.spec.tsx +1 -1
  544. package/src/components/toast/__tests__/CToastHeader.spec.tsx +1 -1
  545. package/src/components/toast/__tests__/CToaster.spec.tsx +2 -1
  546. package/src/components/tooltip/__tests__/CTooltip.spec.tsx +54 -33
  547. package/src/components/tooltip/__tests__/__snapshots__/CTooltip.spec.tsx.snap +0 -10
  548. package/src/components/widgets/__tests__/CWidgetStatsA.spec.tsx +1 -1
  549. package/src/components/widgets/__tests__/CWidgetStatsB.spec.tsx +1 -1
  550. package/src/components/widgets/__tests__/CWidgetStatsC.spec.tsx +1 -1
  551. package/src/components/widgets/__tests__/CWidgetStatsD.spec.tsx +1 -1
  552. package/src/components/widgets/__tests__/CWidgetStatsE.spec.tsx +1 -1
  553. package/src/components/widgets/__tests__/CWidgetStatsF.spec.tsx +1 -1
  554. package/src/hooks/usePopper.ts +2 -2
  555. package/src/components/button/__tests__/CButtonClose.spec.tsx +0 -23
  556. package/src/components/button/__tests__/__snapshots__/CButtonClose.spec.tsx.snap +0 -26
@@ -1,41 +1,62 @@
1
1
  import * as React from 'react'
2
- import { render, fireEvent } from '@testing-library/react'
2
+ import { act, render, fireEvent } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CAlert } from '../../../index'
4
+ import { CAlert } from '../index'
5
5
 
6
6
  test('loads and displays CAlert component', async () => {
7
- const { container } = render(<CAlert color="primary">Test</CAlert>)
8
- expect(container).toMatchSnapshot()
7
+ let container: HTMLElement
8
+ await act(async () => {
9
+ const renderResult = render(<CAlert color="primary">Test</CAlert>)
10
+ container = renderResult.container
11
+ })
12
+ expect(container!).toMatchSnapshot()
9
13
  })
10
14
 
11
15
  test('CAlert customize', async () => {
12
- const { container } = render(
13
- <CAlert color="secondary" className="bazinga" dismissible={true} variant="solid" visible={true}>
14
- Test
15
- </CAlert>,
16
- )
17
- expect(container).toMatchSnapshot()
18
- expect(container.firstChild).toHaveClass('bazinga')
19
- expect(container.firstChild).toHaveClass('bg-secondary')
20
- expect(container.firstChild).toHaveClass('text-white')
21
- expect(container.firstChild).toHaveClass('alert-dismissible')
16
+ let container: HTMLElement
17
+ await act(async () => {
18
+ const renderResult = render(
19
+ <CAlert
20
+ color="secondary"
21
+ className="bazinga"
22
+ dismissible={true}
23
+ variant="solid"
24
+ visible={true}
25
+ >
26
+ Test
27
+ </CAlert>
28
+ )
29
+ container = renderResult.container
30
+ })
31
+ expect(container!).toMatchSnapshot()
32
+ expect(container!.firstChild).toHaveClass('bazinga')
33
+ expect(container!.firstChild).toHaveClass('bg-secondary')
34
+ expect(container!.firstChild).toHaveClass('text-white')
35
+ expect(container!.firstChild).toHaveClass('alert-dismissible')
22
36
  })
23
37
 
24
38
  test('CAlert click close button', async () => {
25
39
  jest.useFakeTimers()
40
+
26
41
  const onClose = jest.fn()
27
42
  render(
28
43
  <CAlert color="primary" dismissible onClose={onClose}>
29
44
  Test
30
- </CAlert>,
45
+ </CAlert>
31
46
  )
47
+
32
48
  expect(onClose).toHaveBeenCalledTimes(0)
49
+
33
50
  const btn = document.querySelector('.btn-close')
51
+
34
52
  if (btn !== null) {
35
- fireEvent.click(btn)
53
+ act(() => {
54
+ fireEvent.click(btn)
55
+ jest.runAllTimers()
56
+ })
36
57
  }
58
+
37
59
  expect(onClose).toHaveBeenCalledTimes(1)
38
- jest.runAllTimers()
39
- expect(onClose).toHaveBeenCalledTimes(1)
60
+
40
61
  jest.useRealTimers()
41
62
  })
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CAlertHeading } from '../../../index'
4
+ import { CAlertHeading } from '../index'
5
5
 
6
6
  test('loads and displays CAlertHeading component', async () => {
7
7
  const { container } = render(<CAlertHeading>Test</CAlertHeading>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CAlertLink } from '../../../index'
4
+ import { CAlertLink } from '../index'
5
5
 
6
6
  test('loads and displays CAlertLink component', async () => {
7
7
  const { container } = render(<CAlertLink>Test</CAlertLink>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CAvatar } from '../../../index'
4
+ import { CAvatar } from '../index'
5
5
 
6
6
  test('loads and displays CAvatar component', async () => {
7
7
  const { container } = render(<CAvatar color="primary">Test</CAvatar>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CBackdrop } from '../../../index'
4
+ import { CBackdrop } from '../index'
5
5
 
6
6
  test('loads and displays CBackdrop component', async () => {
7
7
  const { container } = render(<CBackdrop>Test</CBackdrop>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CBadge } from '../../../index'
4
+ import { CBadge } from '../index'
5
5
 
6
6
  test('loads and displays CBadge component', async () => {
7
7
  const { container } = render(<CBadge color="primary">Test</CBadge>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CBreadcrumb, CBreadcrumbItem } from '../../../index'
4
+ import { CBreadcrumb, CBreadcrumbItem } from '../index'
5
5
 
6
6
  test('loads and displays CBreadcrumb component', async () => {
7
7
  const { container } = render(<CBreadcrumb></CBreadcrumb>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CBreadcrumbItem } from '../../../index'
4
+ import { CBreadcrumbItem } from '../index'
5
5
 
6
6
  test('loads and displays CBreadcrumbItem component', async () => {
7
7
  const { container } = render(<CBreadcrumbItem>Test</CBreadcrumbItem>)
@@ -66,7 +66,7 @@ export const CButton: PolymorphicRefForwardingComponent<'button', CButtonProps>
66
66
  >(
67
67
  (
68
68
  { children, as = 'button', className, color, shape, size, type = 'button', variant, ...rest },
69
- ref,
69
+ ref
70
70
  ) => {
71
71
  return (
72
72
  <CLink
@@ -74,13 +74,13 @@ export const CButton: PolymorphicRefForwardingComponent<'button', CButtonProps>
74
74
  {...(!rest.href && { type: type })}
75
75
  className={classNames(
76
76
  'btn',
77
+ variant && color ? `btn-${variant}-${color}` : `btn-${variant}`,
77
78
  {
78
79
  [`btn-${color}`]: color && !variant,
79
- [`btn-${variant}-${color}`]: color && variant,
80
80
  [`btn-${size}`]: size,
81
81
  },
82
82
  shape,
83
- className,
83
+ className
84
84
  )}
85
85
  {...rest}
86
86
  ref={ref}
@@ -88,7 +88,7 @@ export const CButton: PolymorphicRefForwardingComponent<'button', CButtonProps>
88
88
  {children}
89
89
  </CLink>
90
90
  )
91
- },
91
+ }
92
92
  )
93
93
 
94
94
  CButton.propTypes = {
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CButton } from '../../../index'
4
+ import { CButton } from '../index'
5
5
 
6
6
  test('loads and displays CButton component', async () => {
7
7
  const { container } = render(<CButton color="primary">Test</CButton>)
@@ -1,7 +1,8 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CButtonGroup, CButton } from '../../../index'
4
+ import { CButton } from '../../button/CButton'
5
+ import { CButtonGroup } from '../index'
5
6
 
6
7
  test('loads and displays CButtonGroup component', async () => {
7
8
  const { container } = render(<CButtonGroup></CButtonGroup>)
@@ -1,7 +1,8 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CButtonToolbar, CButtonGroup, CButton } from '../../../index'
4
+ import { CButton } from '../../button/CButton'
5
+ import { CButtonToolbar, CButtonGroup } from '../index'
5
6
 
6
7
  test('loads and displays CButtonToolbar component', async () => {
7
8
  const { container } = render(<CButtonToolbar></CButtonToolbar>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCallout } from '../../../index'
4
+ import { CCallout } from '../index'
5
5
 
6
6
  test('loads and displays CCallout component', async () => {
7
7
  const { container } = render(<CCallout>Test</CCallout>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCard } from '../../../index'
4
+ import { CCard } from '../index'
5
5
 
6
6
  test('loads and displays CCard component', async () => {
7
7
  const { container } = render(<CCard>Test</CCard>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCardBody } from '../../../index'
4
+ import { CCardBody } from '../index'
5
5
 
6
6
  test('loads and displays CCardBody component', async () => {
7
7
  const { container } = render(<CCardBody>Test</CCardBody>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCardFooter } from '../../../index'
4
+ import { CCardFooter } from '../index'
5
5
 
6
6
  test('loads and displays CCardFooter component', async () => {
7
7
  const { container } = render(<CCardFooter>Test</CCardFooter>)
@@ -12,7 +12,7 @@ import {
12
12
  CCardTitle,
13
13
  CCardText,
14
14
  CCardGroup,
15
- } from '../../../index'
15
+ } from '../index'
16
16
 
17
17
  test('loads and displays CCardGroup component', async () => {
18
18
  const { container } = render(<CCardGroup>Test</CCardGroup>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCardHeader } from '../../../index'
4
+ import { CCardHeader } from '../index'
5
5
 
6
6
  test('loads and displays CCardHeader component', async () => {
7
7
  const { container } = render(<CCardHeader>Test</CCardHeader>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCardImage } from '../../../index'
4
+ import { CCardImage } from '../index'
5
5
 
6
6
  test('loads and displays CCardImage component', async () => {
7
7
  const { container } = render(<CCardImage />)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCardImageOverlay } from '../../../index'
4
+ import { CCardImageOverlay } from '../index'
5
5
 
6
6
  test('loads and displays CCardImageOverlay component', async () => {
7
7
  const { container } = render(<CCardImageOverlay />)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCardLink } from '../../../index'
4
+ import { CCardLink } from '../index'
5
5
 
6
6
  test('loads and displays CCardLink component', async () => {
7
7
  const { container } = render(<CCardLink>Test</CCardLink>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCardSubtitle } from '../../../index'
4
+ import { CCardSubtitle } from '../index'
5
5
 
6
6
  test('loads and displays CCardSubtitle component', async () => {
7
7
  const { container } = render(<CCardSubtitle>Test</CCardSubtitle>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCardText } from '../../../index'
4
+ import { CCardText } from '../index'
5
5
 
6
6
  test('loads and displays CCardText component', async () => {
7
7
  const { container } = render(<CCardText>Test</CCardText>)
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCardTitle } from '../../../index'
4
+ import { CCardTitle } from '../index'
5
5
 
6
6
  test('loads and displays CCardTitle component', async () => {
7
7
  const { container } = render(<CCardTitle>Test</CCardTitle>)
@@ -1,6 +1,5 @@
1
1
  import React, {
2
2
  Children,
3
- createContext,
4
3
  forwardRef,
5
4
  HTMLAttributes,
6
5
  TouchEvent,
@@ -14,6 +13,8 @@ import classNames from 'classnames'
14
13
  import { isInViewport } from '../../utils'
15
14
  import { useForkedRef } from '../../hooks'
16
15
 
16
+ import { CCarouselContext } from './CCarouselContext'
17
+
17
18
  export interface CCarouselProps extends HTMLAttributes<HTMLDivElement> {
18
19
  /**
19
20
  * index of the active item.
@@ -71,13 +72,6 @@ interface DataType {
71
72
  timeout?: null | ReturnType<typeof setTimeout>
72
73
  }
73
74
 
74
- export interface ContextProps {
75
- setAnimating: (a: boolean) => void
76
- setCustomInterval: (a: boolean | number) => void
77
- }
78
-
79
- export const CCarouselContext = createContext({} as ContextProps)
80
-
81
75
  export const CCarousel = forwardRef<HTMLDivElement, CCarouselProps>(
82
76
  (
83
77
  {
@@ -96,7 +90,7 @@ export const CCarousel = forwardRef<HTMLDivElement, CCarouselProps>(
96
90
  wrap = true,
97
91
  ...rest
98
92
  },
99
- ref,
93
+ ref
100
94
  ) => {
101
95
  const carouselRef = useRef<HTMLDivElement>(null)
102
96
  const forkedRef = useForkedRef(ref, carouselRef)
@@ -141,7 +135,7 @@ export const CCarousel = forwardRef<HTMLDivElement, CCarouselProps>(
141
135
  if (typeof interval === 'number') {
142
136
  data.timeout = setTimeout(
143
137
  () => nextItemWhenVisible(),
144
- typeof customInterval === 'number' ? customInterval : interval,
138
+ typeof customInterval === 'number' ? customInterval : interval
145
139
  )
146
140
  }
147
141
  }
@@ -228,7 +222,7 @@ export const CCarousel = forwardRef<HTMLDivElement, CCarouselProps>(
228
222
  {
229
223
  'carousel-fade': transition === 'crossfade',
230
224
  },
231
- className,
225
+ className
232
226
  )}
233
227
  {...(dark && { 'data-coreui-theme': 'dark' })}
234
228
  onMouseEnter={_pause}
@@ -288,7 +282,7 @@ export const CCarousel = forwardRef<HTMLDivElement, CCarouselProps>(
288
282
  </CCarouselContext.Provider>
289
283
  </div>
290
284
  )
291
- },
285
+ }
292
286
  )
293
287
 
294
288
  CCarousel.propTypes = {
@@ -12,7 +12,7 @@ export interface CCarouselCaptionProps extends HTMLAttributes<HTMLDivElement> {
12
12
  export const CCarouselCaption = forwardRef<HTMLDivElement, CCarouselCaptionProps>(
13
13
  ({ className, ...rest }, ref) => {
14
14
  return <div className={classNames('carousel-caption', className)} {...rest} ref={ref} />
15
- },
15
+ }
16
16
  )
17
17
 
18
18
  CCarouselCaption.propTypes = {
@@ -0,0 +1,8 @@
1
+ import { createContext } from 'react'
2
+
3
+ export interface CCarouselContextProps {
4
+ setAnimating: (a: boolean) => void
5
+ setCustomInterval: (a: boolean | number) => void
6
+ }
7
+
8
+ export const CCarouselContext = createContext({} as CCarouselContextProps)
@@ -3,7 +3,9 @@ import PropTypes from 'prop-types'
3
3
  import classNames from 'classnames'
4
4
 
5
5
  import { useForkedRef } from '../../hooks'
6
- import { CCarouselContext } from './CCarousel'
6
+
7
+ import { CCarouselContext } from './CCarouselContext'
8
+
7
9
  export interface CCarouselItemProps extends HTMLAttributes<HTMLDivElement> {
8
10
  /**
9
11
  * @ignore
@@ -29,7 +31,7 @@ export const CCarouselItem = forwardRef<HTMLDivElement, CCarouselItemProps>(
29
31
  const carouselItemRef = useRef<HTMLDivElement>(null)
30
32
  const forkedRef = useForkedRef(ref, carouselItemRef)
31
33
 
32
- const prevActive = useRef<boolean>()
34
+ const prevActive = useRef<boolean>(undefined)
33
35
  const [directionClassName, setDirectionClassName] = useState<string>()
34
36
  const [orderClassName, setOrderClassName] = useState<string>()
35
37
  const [activeClassName, setActiveClassName] = useState(active && 'active')
@@ -101,7 +103,7 @@ export const CCarouselItem = forwardRef<HTMLDivElement, CCarouselItemProps>(
101
103
  activeClassName,
102
104
  directionClassName,
103
105
  orderClassName,
104
- className,
106
+ className
105
107
  )}
106
108
  ref={forkedRef}
107
109
  {...rest}
@@ -109,7 +111,7 @@ export const CCarouselItem = forwardRef<HTMLDivElement, CCarouselItemProps>(
109
111
  {children}
110
112
  </div>
111
113
  )
112
- },
114
+ }
113
115
  )
114
116
 
115
117
  CCarouselItem.propTypes = {
@@ -1,7 +1,7 @@
1
1
  import React from 'react'
2
2
  import { render, fireEvent, getByText } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCarousel, CCarouselCaption, CCarouselItem } from '../../../index'
4
+ import { CCarousel, CCarouselCaption, CCarouselItem } from '../index'
5
5
 
6
6
  test('loads and displays CCarousel component', async () => {
7
7
  const { container } = render(
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
2
  import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCloseButton } from '../../../index'
4
+ import { CCloseButton } from '../index'
5
5
 
6
6
  test('loads and displays CCloseButton component', async () => {
7
7
  const { container } = render(<CCloseButton />)
@@ -1,7 +1,7 @@
1
1
  import React from 'react'
2
- import { render, screen } from '@testing-library/react'
2
+ import { render, screen, act } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CCollapse } from '../../../index'
4
+ import { CCollapse } from '../index'
5
5
 
6
6
  test('loads and displays CCollapse component', async () => {
7
7
  const { container } = render(<CCollapse>Test</CCollapse>)
@@ -15,26 +15,45 @@ test('CCollapse customize', async () => {
15
15
  })
16
16
 
17
17
  test('CCollapse use case test', async () => {
18
+ jest.useFakeTimers()
19
+
18
20
  const { rerender } = render(<CCollapse visible={false}>Test</CCollapse>)
21
+
19
22
  expect(screen.getByText('Test')).toHaveClass('collapse')
20
23
  expect(screen.getByText('Test')).not.toHaveClass('show')
21
24
  expect(screen.getByText('Test')).not.toHaveClass('collapsing')
22
- rerender(<CCollapse visible={true}>Test</CCollapse>)
25
+
26
+ act(() => {
27
+ rerender(<CCollapse visible={true}>Test</CCollapse>)
28
+ })
29
+
23
30
  expect(screen.getByText('Test')).not.toHaveClass('collapse')
24
31
  expect(screen.getByText('Test')).not.toHaveClass('show')
25
32
  expect(screen.getByText('Test')).toHaveClass('collapsing')
26
- await new Promise((r) => setTimeout(r, 1000))
33
+
34
+ act(() => {
35
+ jest.runAllTimers()
36
+ })
37
+
27
38
  expect(screen.getByText('Test')).toHaveClass('collapse')
28
39
  expect(screen.getByText('Test')).toHaveClass('show')
29
40
  expect(screen.getByText('Test')).not.toHaveClass('collapsing')
30
- rerender(<CCollapse visible={false}>Test</CCollapse>)
41
+
42
+ act(() => {
43
+ rerender(<CCollapse visible={false}>Test</CCollapse>)
44
+ })
45
+
31
46
  expect(screen.getByText('Test')).not.toHaveClass('collapse')
32
47
  expect(screen.getByText('Test')).not.toHaveClass('show')
33
48
  expect(screen.getByText('Test')).toHaveClass('collapsing')
34
- await new Promise((r) => setTimeout(r, 1000))
49
+
50
+ act(() => {
51
+ jest.runAllTimers()
52
+ })
53
+
35
54
  expect(screen.getByText('Test')).toHaveClass('collapse')
36
55
  expect(screen.getByText('Test')).not.toHaveClass('show')
37
56
  expect(screen.getByText('Test')).not.toHaveClass('collapsing')
38
- jest.runAllTimers()
57
+
39
58
  jest.useRealTimers()
40
59
  })
@@ -1,17 +1,10 @@
1
- import React, {
2
- createContext,
3
- ElementType,
4
- forwardRef,
5
- HTMLAttributes,
6
- RefObject,
7
- useEffect,
8
- useRef,
9
- useState,
10
- } from 'react'
1
+ import React, { ElementType, forwardRef, HTMLAttributes, useEffect, useRef, useState } from 'react'
11
2
  import PropTypes from 'prop-types'
12
3
  import classNames from 'classnames'
13
4
  import type { Options } from '@popperjs/core'
14
5
 
6
+ import { CDropdownContext } from './CDropdownContext'
7
+
15
8
  import { PolymorphicRefForwardingComponent } from '../../helpers'
16
9
  import { useForkedRef, usePopper } from '../../hooks'
17
10
  import { placementPropType } from '../../props'
@@ -169,16 +162,6 @@ export interface CDropdownProps extends HTMLAttributes<HTMLDivElement | HTMLLIEl
169
162
  visible?: boolean
170
163
  }
171
164
 
172
- interface ContextProps extends CDropdownProps {
173
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
174
- dropdownToggleRef: RefObject<any | undefined>
175
- dropdownMenuRef: RefObject<HTMLDivElement | HTMLUListElement | undefined>
176
- setVisible: React.Dispatch<React.SetStateAction<boolean | undefined>>
177
- portal: boolean
178
- }
179
-
180
- export const CDropdownContext = createContext({} as ContextProps)
181
-
182
165
  export const CDropdown: PolymorphicRefForwardingComponent<'div', CDropdownProps> = forwardRef<
183
166
  HTMLDivElement | HTMLLIElement,
184
167
  CDropdownProps
@@ -207,8 +190,7 @@ export const CDropdown: PolymorphicRefForwardingComponent<'div', CDropdownProps>
207
190
  ref
208
191
  ) => {
209
192
  const dropdownRef = useRef<HTMLDivElement>(null)
210
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
211
- const dropdownToggleRef = useRef<any>(null)
193
+ const dropdownToggleRef = useRef<HTMLElement>(null)
212
194
  const dropdownMenuRef = useRef<HTMLDivElement | HTMLUListElement>(null)
213
195
  const forkedRef = useForkedRef(ref, dropdownRef)
214
196
  const [_visible, setVisible] = useState(visible)
@@ -256,28 +238,45 @@ export const CDropdown: PolymorphicRefForwardingComponent<'div', CDropdownProps>
256
238
  }, [visible])
257
239
 
258
240
  useEffect(() => {
259
- if (_visible && dropdownToggleRef.current && dropdownMenuRef.current) {
260
- dropdownToggleRef.current.focus()
261
- popper &&
262
- initPopper(dropdownToggleRef.current, dropdownMenuRef.current, computedPopperConfig)
241
+ const toggleElement = dropdownToggleRef.current
242
+ const menuElement = dropdownMenuRef.current
243
+
244
+ if (_visible && toggleElement && menuElement) {
245
+ if (popper) {
246
+ initPopper(toggleElement, menuElement, computedPopperConfig)
247
+ }
248
+
249
+ toggleElement.focus()
250
+ toggleElement.addEventListener('keydown', handleKeydown)
251
+ menuElement.addEventListener('keydown', handleKeydown)
252
+
263
253
  window.addEventListener('mouseup', handleMouseUp)
264
254
  window.addEventListener('keyup', handleKeyup)
265
- dropdownToggleRef.current.addEventListener('keydown', handleKeydown)
266
- dropdownMenuRef.current.addEventListener('keydown', handleKeydown)
267
- onShow && onShow()
255
+
256
+ onShow?.()
268
257
  }
269
258
 
270
259
  return () => {
271
- popper && destroyPopper()
260
+ if (popper) {
261
+ destroyPopper()
262
+ }
263
+
264
+ toggleElement?.removeEventListener('keydown', handleKeydown)
265
+ menuElement?.removeEventListener('keydown', handleKeydown)
266
+
272
267
  window.removeEventListener('mouseup', handleMouseUp)
273
268
  window.removeEventListener('keyup', handleKeyup)
274
- dropdownToggleRef.current &&
275
- dropdownToggleRef.current.removeEventListener('keydown', handleKeydown)
276
- dropdownMenuRef.current &&
277
- dropdownMenuRef.current.removeEventListener('keydown', handleKeydown)
278
- onHide && onHide()
269
+
270
+ onHide?.()
279
271
  }
280
- }, [_visible])
272
+ }, [
273
+ computedPopperConfig,
274
+ destroyPopper,
275
+ dropdownMenuRef,
276
+ dropdownToggleRef,
277
+ initPopper,
278
+ _visible,
279
+ ])
281
280
 
282
281
  const handleKeydown = (event: KeyboardEvent) => {
283
282
  if (