@coreui/react 5.5.0 → 5.6.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 (549) 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 +1 -1
  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.js +1 -1
  99. package/dist/cjs/components/nav/CNav.js.map +1 -1
  100. package/dist/cjs/components/nav/CNavGroup.js +5 -5
  101. package/dist/cjs/components/nav/CNavGroup.js.map +1 -1
  102. package/dist/cjs/components/nav/CNavGroupItems.js +1 -1
  103. package/dist/cjs/components/nav/CNavGroupItems.js.map +1 -1
  104. package/dist/cjs/components/nav/CNavItem.js +1 -1
  105. package/dist/cjs/components/nav/CNavItem.js.map +1 -1
  106. package/dist/cjs/components/nav/CNavLink.js +3 -3
  107. package/dist/cjs/components/nav/CNavLink.js.map +1 -1
  108. package/dist/cjs/components/nav/CNavTitle.js +1 -1
  109. package/dist/cjs/components/nav/CNavTitle.js.map +1 -1
  110. package/dist/cjs/components/navbar/CNavbar.js +1 -1
  111. package/dist/cjs/components/navbar/CNavbar.js.map +1 -1
  112. package/dist/cjs/components/navbar/CNavbarBrand.js +1 -1
  113. package/dist/cjs/components/navbar/CNavbarBrand.js.map +1 -1
  114. package/dist/cjs/components/navbar/CNavbarNav.js +1 -1
  115. package/dist/cjs/components/navbar/CNavbarNav.js.map +1 -1
  116. package/dist/cjs/components/navbar/CNavbarToggler.js +1 -1
  117. package/dist/cjs/components/navbar/CNavbarToggler.js.map +1 -1
  118. package/dist/cjs/components/offcanvas/COffcanvas.js +2 -2
  119. package/dist/cjs/components/offcanvas/COffcanvas.js.map +1 -1
  120. package/dist/cjs/components/offcanvas/COffcanvasTitle.js +1 -1
  121. package/dist/cjs/components/offcanvas/COffcanvasTitle.js.map +1 -1
  122. package/dist/cjs/components/pagination/CPaginationItem.js +1 -1
  123. package/dist/cjs/components/pagination/CPaginationItem.js.map +1 -1
  124. package/dist/cjs/components/placeholder/CPlaceholder.js +1 -1
  125. package/dist/cjs/components/placeholder/CPlaceholder.js.map +1 -1
  126. package/dist/cjs/components/popover/CPopover.js +1 -1
  127. package/dist/cjs/components/popover/CPopover.js.map +1 -1
  128. package/dist/cjs/components/progress/CProgress.js +2 -2
  129. package/dist/cjs/components/progress/CProgress.js.map +1 -1
  130. package/dist/cjs/components/progress/CProgressBar.js +3 -3
  131. package/dist/cjs/components/progress/CProgressBar.js.map +1 -1
  132. package/dist/cjs/components/progress/CProgressStacked.d.ts +0 -4
  133. package/dist/cjs/components/progress/CProgressStacked.js +2 -3
  134. package/dist/cjs/components/progress/CProgressStacked.js.map +1 -1
  135. package/dist/cjs/components/progress/CProgressStackedContext.d.ts +4 -0
  136. package/dist/cjs/components/progress/CProgressStackedContext.js +8 -0
  137. package/dist/cjs/components/progress/CProgressStackedContext.js.map +1 -0
  138. package/dist/cjs/components/sidebar/CSidebar.js +5 -5
  139. package/dist/cjs/components/sidebar/CSidebar.js.map +1 -1
  140. package/dist/cjs/components/sidebar/CSidebarBrand.js +1 -1
  141. package/dist/cjs/components/sidebar/CSidebarBrand.js.map +1 -1
  142. package/dist/cjs/components/sidebar/CSidebarNav.d.ts +1 -7
  143. package/dist/cjs/components/sidebar/CSidebarNav.js +16 -15
  144. package/dist/cjs/components/sidebar/CSidebarNav.js.map +1 -1
  145. package/dist/cjs/components/sidebar/CSidebarNavContext.d.ts +5 -0
  146. package/dist/cjs/components/sidebar/CSidebarNavContext.js +8 -0
  147. package/dist/cjs/components/sidebar/CSidebarNavContext.js.map +1 -0
  148. package/dist/cjs/components/spinner/CSpinner.js +1 -1
  149. package/dist/cjs/components/spinner/CSpinner.js.map +1 -1
  150. package/dist/cjs/components/table/utils.js +1 -1
  151. package/dist/cjs/components/table/utils.js.map +1 -1
  152. package/dist/cjs/components/tabs/CTab.js +2 -2
  153. package/dist/cjs/components/tabs/CTab.js.map +1 -1
  154. package/dist/cjs/components/tabs/CTabList.js +1 -1
  155. package/dist/cjs/components/tabs/CTabList.js.map +1 -1
  156. package/dist/cjs/components/tabs/CTabPane.js +2 -2
  157. package/dist/cjs/components/tabs/CTabPane.js.map +1 -1
  158. package/dist/cjs/components/tabs/CTabPanel.js +4 -4
  159. package/dist/cjs/components/tabs/CTabPanel.js.map +1 -1
  160. package/dist/cjs/components/tabs/CTabs.d.ts +29 -9
  161. package/dist/cjs/components/tabs/CTabs.js +14 -9
  162. package/dist/cjs/components/tabs/CTabs.js.map +1 -1
  163. package/dist/cjs/components/tabs/CTabsContext.d.ts +6 -0
  164. package/dist/cjs/components/tabs/CTabsContext.js +8 -0
  165. package/dist/cjs/components/tabs/CTabsContext.js.map +1 -0
  166. package/dist/cjs/components/toast/CToast.d.ts +0 -6
  167. package/dist/cjs/components/toast/CToast.js +7 -11
  168. package/dist/cjs/components/toast/CToast.js.map +1 -1
  169. package/dist/cjs/components/toast/CToastClose.js +2 -2
  170. package/dist/cjs/components/toast/CToastClose.js.map +1 -1
  171. package/dist/cjs/components/toast/CToastContext.d.ts +5 -0
  172. package/dist/cjs/components/toast/CToastContext.js +8 -0
  173. package/dist/cjs/components/toast/CToastContext.js.map +1 -0
  174. package/dist/cjs/components/toast/CToaster.d.ts +2 -1
  175. package/dist/cjs/components/toast/CToaster.js +4 -2
  176. package/dist/cjs/components/toast/CToaster.js.map +1 -1
  177. package/dist/cjs/components/tooltip/CTooltip.js +1 -1
  178. package/dist/cjs/components/tooltip/CTooltip.js.map +1 -1
  179. package/dist/cjs/components/widgets/CWidgetStatsF.js +1 -1
  180. package/dist/cjs/components/widgets/CWidgetStatsF.js.map +1 -1
  181. package/dist/cjs/hooks/useClipboard.js +2 -2
  182. package/dist/cjs/hooks/useClipboard.js.map +1 -1
  183. package/dist/cjs/hooks/useColorModes.js +1 -1
  184. package/dist/cjs/hooks/useColorModes.js.map +1 -1
  185. package/dist/cjs/hooks/usePopper.js +2 -2
  186. package/dist/cjs/hooks/usePopper.js.map +1 -1
  187. package/dist/cjs/node_modules/react-transition-group/esm/Transition.js +2 -2
  188. package/dist/cjs/node_modules/react-transition-group/esm/Transition.js.map +1 -1
  189. package/dist/cjs/node_modules/tslib/tslib.es6.js +1 -1
  190. package/dist/cjs/node_modules/tslib/tslib.es6.js.map +1 -1
  191. package/dist/cjs/utils/executeAfterTransition.js +1 -1
  192. package/dist/cjs/utils/executeAfterTransition.js.map +1 -1
  193. package/dist/esm/components/accordion/CAccordion.d.ts +0 -6
  194. package/dist/esm/components/accordion/CAccordion.js +5 -5
  195. package/dist/esm/components/accordion/CAccordion.js.map +1 -1
  196. package/dist/esm/components/accordion/CAccordionBody.js +1 -1
  197. package/dist/esm/components/accordion/CAccordionBody.js.map +1 -1
  198. package/dist/esm/components/accordion/CAccordionButton.js +1 -1
  199. package/dist/esm/components/accordion/CAccordionContext.d.ts +6 -0
  200. package/dist/esm/components/accordion/CAccordionContext.js +6 -0
  201. package/dist/esm/components/accordion/CAccordionContext.js.map +1 -0
  202. package/dist/esm/components/accordion/CAccordionItem.d.ts +0 -6
  203. package/dist/esm/components/accordion/CAccordionItem.js +7 -6
  204. package/dist/esm/components/accordion/CAccordionItem.js.map +1 -1
  205. package/dist/esm/components/accordion/CAccordionItemContext.d.ts +6 -0
  206. package/dist/esm/components/accordion/CAccordionItemContext.js +6 -0
  207. package/dist/esm/components/accordion/CAccordionItemContext.js.map +1 -0
  208. package/dist/esm/components/alert/CAlert.js +1 -1
  209. package/dist/esm/components/alert/CAlert.js.map +1 -1
  210. package/dist/esm/components/alert/CAlertHeading.js +1 -1
  211. package/dist/esm/components/alert/CAlertHeading.js.map +1 -1
  212. package/dist/esm/components/backdrop/CBackdrop.js +1 -1
  213. package/dist/esm/components/backdrop/CBackdrop.js.map +1 -1
  214. package/dist/esm/components/badge/CBadge.js +5 -5
  215. package/dist/esm/components/badge/CBadge.js.map +1 -1
  216. package/dist/esm/components/button/CButton.js +1 -1
  217. package/dist/esm/components/button/CButton.js.map +1 -1
  218. package/dist/esm/components/card/CCardHeader.js +1 -1
  219. package/dist/esm/components/card/CCardHeader.js.map +1 -1
  220. package/dist/esm/components/card/CCardImage.js +1 -1
  221. package/dist/esm/components/card/CCardImage.js.map +1 -1
  222. package/dist/esm/components/card/CCardSubtitle.js +1 -1
  223. package/dist/esm/components/card/CCardSubtitle.js.map +1 -1
  224. package/dist/esm/components/card/CCardText.js +1 -1
  225. package/dist/esm/components/card/CCardText.js.map +1 -1
  226. package/dist/esm/components/card/CCardTitle.js +1 -1
  227. package/dist/esm/components/card/CCardTitle.js.map +1 -1
  228. package/dist/esm/components/carousel/CCarousel.d.ts +0 -5
  229. package/dist/esm/components/carousel/CCarousel.js +4 -4
  230. package/dist/esm/components/carousel/CCarousel.js.map +1 -1
  231. package/dist/esm/components/carousel/CCarouselContext.d.ts +5 -0
  232. package/dist/esm/components/carousel/CCarouselContext.js +6 -0
  233. package/dist/esm/components/carousel/CCarouselContext.js.map +1 -0
  234. package/dist/esm/components/carousel/CCarouselItem.js +8 -8
  235. package/dist/esm/components/carousel/CCarouselItem.js.map +1 -1
  236. package/dist/esm/components/dropdown/CDropdown.d.ts +1 -9
  237. package/dist/esm/components/dropdown/CDropdown.js +28 -19
  238. package/dist/esm/components/dropdown/CDropdown.js.map +1 -1
  239. package/dist/esm/components/dropdown/CDropdownContext.d.ts +15 -0
  240. package/dist/esm/components/dropdown/CDropdownContext.js +6 -0
  241. package/dist/esm/components/dropdown/CDropdownContext.js.map +1 -0
  242. package/dist/esm/components/dropdown/CDropdownHeader.js +1 -1
  243. package/dist/esm/components/dropdown/CDropdownHeader.js.map +1 -1
  244. package/dist/esm/components/dropdown/CDropdownItem.js +1 -1
  245. package/dist/esm/components/dropdown/CDropdownItem.js.map +1 -1
  246. package/dist/esm/components/dropdown/CDropdownItemPlain.js +1 -1
  247. package/dist/esm/components/dropdown/CDropdownItemPlain.js.map +1 -1
  248. package/dist/esm/components/dropdown/CDropdownMenu.js +3 -3
  249. package/dist/esm/components/dropdown/CDropdownMenu.js.map +1 -1
  250. package/dist/esm/components/dropdown/CDropdownToggle.js +2 -2
  251. package/dist/esm/components/dropdown/CDropdownToggle.js.map +1 -1
  252. package/dist/esm/components/form/CFormCheck.js +1 -1
  253. package/dist/esm/components/form/CFormCheck.js.map +1 -1
  254. package/dist/esm/components/form/CFormFeedback.js +1 -1
  255. package/dist/esm/components/form/CFormFeedback.js.map +1 -1
  256. package/dist/esm/components/form/CFormInput.js +1 -1
  257. package/dist/esm/components/form/CFormInput.js.map +1 -1
  258. package/dist/esm/components/form/CFormLabel.js +1 -1
  259. package/dist/esm/components/form/CFormLabel.js.map +1 -1
  260. package/dist/esm/components/form/CFormSwitch.js +1 -1
  261. package/dist/esm/components/form/CFormSwitch.js.map +1 -1
  262. package/dist/esm/components/form/CFormText.js +1 -1
  263. package/dist/esm/components/form/CFormText.js.map +1 -1
  264. package/dist/esm/components/form/CInputGroupText.js +1 -1
  265. package/dist/esm/components/form/CInputGroupText.js.map +1 -1
  266. package/dist/esm/components/header/CHeaderBrand.js +1 -1
  267. package/dist/esm/components/header/CHeaderBrand.js.map +1 -1
  268. package/dist/esm/components/header/CHeaderNav.js +1 -1
  269. package/dist/esm/components/header/CHeaderNav.js.map +1 -1
  270. package/dist/esm/components/header/CHeaderToggler.js +1 -1
  271. package/dist/esm/components/header/CHeaderToggler.js.map +1 -1
  272. package/dist/esm/components/link/CLink.js +1 -1
  273. package/dist/esm/components/link/CLink.js.map +1 -1
  274. package/dist/esm/components/list-group/CListGroup.js +1 -1
  275. package/dist/esm/components/list-group/CListGroup.js.map +1 -1
  276. package/dist/esm/components/list-group/CListGroupItem.js +1 -1
  277. package/dist/esm/components/list-group/CListGroupItem.js.map +1 -1
  278. package/dist/esm/components/modal/CModal.d.ts +0 -6
  279. package/dist/esm/components/modal/CModal.js +6 -6
  280. package/dist/esm/components/modal/CModal.js.map +1 -1
  281. package/dist/esm/components/modal/CModalContext.d.ts +5 -0
  282. package/dist/esm/components/modal/CModalContext.js +6 -0
  283. package/dist/esm/components/modal/CModalContext.js.map +1 -0
  284. package/dist/esm/components/modal/CModalHeader.js +2 -2
  285. package/dist/esm/components/modal/CModalHeader.js.map +1 -1
  286. package/dist/esm/components/modal/CModalTitle.js +1 -1
  287. package/dist/esm/components/modal/CModalTitle.js.map +1 -1
  288. package/dist/esm/components/nav/CNav.js +1 -1
  289. package/dist/esm/components/nav/CNav.js.map +1 -1
  290. package/dist/esm/components/nav/CNavGroup.js +5 -5
  291. package/dist/esm/components/nav/CNavGroup.js.map +1 -1
  292. package/dist/esm/components/nav/CNavGroupItems.js +1 -1
  293. package/dist/esm/components/nav/CNavGroupItems.js.map +1 -1
  294. package/dist/esm/components/nav/CNavItem.js +1 -1
  295. package/dist/esm/components/nav/CNavItem.js.map +1 -1
  296. package/dist/esm/components/nav/CNavLink.js +3 -3
  297. package/dist/esm/components/nav/CNavLink.js.map +1 -1
  298. package/dist/esm/components/nav/CNavTitle.js +1 -1
  299. package/dist/esm/components/nav/CNavTitle.js.map +1 -1
  300. package/dist/esm/components/navbar/CNavbar.js +1 -1
  301. package/dist/esm/components/navbar/CNavbar.js.map +1 -1
  302. package/dist/esm/components/navbar/CNavbarBrand.js +1 -1
  303. package/dist/esm/components/navbar/CNavbarBrand.js.map +1 -1
  304. package/dist/esm/components/navbar/CNavbarNav.js +1 -1
  305. package/dist/esm/components/navbar/CNavbarNav.js.map +1 -1
  306. package/dist/esm/components/navbar/CNavbarToggler.js +1 -1
  307. package/dist/esm/components/navbar/CNavbarToggler.js.map +1 -1
  308. package/dist/esm/components/offcanvas/COffcanvas.js +2 -2
  309. package/dist/esm/components/offcanvas/COffcanvas.js.map +1 -1
  310. package/dist/esm/components/offcanvas/COffcanvasTitle.js +1 -1
  311. package/dist/esm/components/offcanvas/COffcanvasTitle.js.map +1 -1
  312. package/dist/esm/components/pagination/CPaginationItem.js +1 -1
  313. package/dist/esm/components/pagination/CPaginationItem.js.map +1 -1
  314. package/dist/esm/components/placeholder/CPlaceholder.js +1 -1
  315. package/dist/esm/components/placeholder/CPlaceholder.js.map +1 -1
  316. package/dist/esm/components/popover/CPopover.js +1 -1
  317. package/dist/esm/components/popover/CPopover.js.map +1 -1
  318. package/dist/esm/components/progress/CProgress.js +1 -1
  319. package/dist/esm/components/progress/CProgressBar.js +2 -2
  320. package/dist/esm/components/progress/CProgressBar.js.map +1 -1
  321. package/dist/esm/components/progress/CProgressStacked.d.ts +0 -4
  322. package/dist/esm/components/progress/CProgressStacked.js +3 -3
  323. package/dist/esm/components/progress/CProgressStacked.js.map +1 -1
  324. package/dist/esm/components/progress/CProgressStackedContext.d.ts +4 -0
  325. package/dist/esm/components/progress/CProgressStackedContext.js +6 -0
  326. package/dist/esm/components/progress/CProgressStackedContext.js.map +1 -0
  327. package/dist/esm/components/sidebar/CSidebar.js +5 -5
  328. package/dist/esm/components/sidebar/CSidebar.js.map +1 -1
  329. package/dist/esm/components/sidebar/CSidebarBrand.js +1 -1
  330. package/dist/esm/components/sidebar/CSidebarBrand.js.map +1 -1
  331. package/dist/esm/components/sidebar/CSidebarNav.d.ts +1 -7
  332. package/dist/esm/components/sidebar/CSidebarNav.js +18 -16
  333. package/dist/esm/components/sidebar/CSidebarNav.js.map +1 -1
  334. package/dist/esm/components/sidebar/CSidebarNavContext.d.ts +5 -0
  335. package/dist/esm/components/sidebar/CSidebarNavContext.js +6 -0
  336. package/dist/esm/components/sidebar/CSidebarNavContext.js.map +1 -0
  337. package/dist/esm/components/spinner/CSpinner.js +1 -1
  338. package/dist/esm/components/spinner/CSpinner.js.map +1 -1
  339. package/dist/esm/components/table/utils.js +1 -1
  340. package/dist/esm/components/table/utils.js.map +1 -1
  341. package/dist/esm/components/tabs/CTab.js +2 -2
  342. package/dist/esm/components/tabs/CTab.js.map +1 -1
  343. package/dist/esm/components/tabs/CTabList.js +1 -1
  344. package/dist/esm/components/tabs/CTabList.js.map +1 -1
  345. package/dist/esm/components/tabs/CTabPane.js +2 -2
  346. package/dist/esm/components/tabs/CTabPane.js.map +1 -1
  347. package/dist/esm/components/tabs/CTabPanel.js +4 -4
  348. package/dist/esm/components/tabs/CTabPanel.js.map +1 -1
  349. package/dist/esm/components/tabs/CTabs.d.ts +29 -9
  350. package/dist/esm/components/tabs/CTabs.js +16 -10
  351. package/dist/esm/components/tabs/CTabs.js.map +1 -1
  352. package/dist/esm/components/tabs/CTabsContext.d.ts +6 -0
  353. package/dist/esm/components/tabs/CTabsContext.js +6 -0
  354. package/dist/esm/components/tabs/CTabsContext.js.map +1 -0
  355. package/dist/esm/components/toast/CToast.d.ts +0 -6
  356. package/dist/esm/components/toast/CToast.js +8 -11
  357. package/dist/esm/components/toast/CToast.js.map +1 -1
  358. package/dist/esm/components/toast/CToastClose.js +1 -1
  359. package/dist/esm/components/toast/CToastClose.js.map +1 -1
  360. package/dist/esm/components/toast/CToastContext.d.ts +5 -0
  361. package/dist/esm/components/toast/CToastContext.js +6 -0
  362. package/dist/esm/components/toast/CToastContext.js.map +1 -0
  363. package/dist/esm/components/toast/CToaster.d.ts +2 -1
  364. package/dist/esm/components/toast/CToaster.js +4 -2
  365. package/dist/esm/components/toast/CToaster.js.map +1 -1
  366. package/dist/esm/components/tooltip/CTooltip.js +1 -1
  367. package/dist/esm/components/tooltip/CTooltip.js.map +1 -1
  368. package/dist/esm/components/widgets/CWidgetStatsF.js +1 -1
  369. package/dist/esm/components/widgets/CWidgetStatsF.js.map +1 -1
  370. package/dist/esm/hooks/useClipboard.js +2 -2
  371. package/dist/esm/hooks/useClipboard.js.map +1 -1
  372. package/dist/esm/hooks/useColorModes.js +1 -1
  373. package/dist/esm/hooks/useColorModes.js.map +1 -1
  374. package/dist/esm/hooks/usePopper.js +2 -2
  375. package/dist/esm/hooks/usePopper.js.map +1 -1
  376. package/dist/esm/node_modules/react-transition-group/esm/Transition.js +2 -2
  377. package/dist/esm/node_modules/react-transition-group/esm/Transition.js.map +1 -1
  378. package/dist/esm/node_modules/tslib/tslib.es6.js +1 -1
  379. package/dist/esm/node_modules/tslib/tslib.es6.js.map +1 -1
  380. package/dist/esm/utils/executeAfterTransition.js +1 -1
  381. package/dist/esm/utils/executeAfterTransition.js.map +1 -1
  382. package/package.json +11 -11
  383. package/src/components/accordion/CAccordion.tsx +4 -10
  384. package/src/components/accordion/CAccordionBody.tsx +1 -2
  385. package/src/components/accordion/CAccordionButton.tsx +2 -2
  386. package/src/components/accordion/CAccordionContext.ts +9 -0
  387. package/src/components/accordion/CAccordionItem.tsx +4 -11
  388. package/src/components/accordion/CAccordionItemContext.ts +9 -0
  389. package/src/components/accordion/__tests__/CAccordion.spec.tsx +1 -1
  390. package/src/components/accordion/__tests__/CAccordionBody.spec.tsx +1 -1
  391. package/src/components/accordion/__tests__/CAccordionButton.spec.tsx +1 -1
  392. package/src/components/accordion/__tests__/CAccordionHeader.spec.tsx +1 -1
  393. package/src/components/accordion/__tests__/CAccordionItem.spec.tsx +1 -1
  394. package/src/components/alert/__tests__/CAlert.spec.tsx +39 -18
  395. package/src/components/alert/__tests__/CAlertHeading.spec.tsx +1 -1
  396. package/src/components/alert/__tests__/CAlertLink.spec.tsx +1 -1
  397. package/src/components/avatar/__tests__/CAvatar.spec.tsx +1 -1
  398. package/src/components/backdrop/__tests__/CBackdrop.spec.tsx +1 -1
  399. package/src/components/badge/__tests__/CBadge.spec.tsx +1 -1
  400. package/src/components/breadcrumb/__tests__/CBreadcrumb.spec.tsx +1 -1
  401. package/src/components/breadcrumb/__tests__/CBreadcrumbItem.spec.tsx +1 -1
  402. package/src/components/button/__tests__/CButton.spec.tsx +1 -1
  403. package/src/components/button-group/__tests__/CButtonGroup.spec.tsx +2 -1
  404. package/src/components/button-group/__tests__/CButtonToolbar.spec.tsx +2 -1
  405. package/src/components/callout/__tests__/CCallout.spec.tsx +1 -1
  406. package/src/components/card/__tests__/CCard.spec.tsx +1 -1
  407. package/src/components/card/__tests__/CCardBody.spec.tsx +1 -1
  408. package/src/components/card/__tests__/CCardFooter.spec.tsx +1 -1
  409. package/src/components/card/__tests__/CCardGroup.spec.tsx +1 -1
  410. package/src/components/card/__tests__/CCardHeader.spec.tsx +1 -1
  411. package/src/components/card/__tests__/CCardImage.spec.tsx +1 -1
  412. package/src/components/card/__tests__/CCardImageOverlay.spec.tsx +1 -1
  413. package/src/components/card/__tests__/CCardLink.spec.tsx +1 -1
  414. package/src/components/card/__tests__/CCardSubtitle.spec.tsx +1 -1
  415. package/src/components/card/__tests__/CCardText.spec.tsx +1 -1
  416. package/src/components/card/__tests__/CCardTitle.spec.tsx +1 -1
  417. package/src/components/carousel/CCarousel.tsx +6 -12
  418. package/src/components/carousel/CCarouselCaption.tsx +1 -1
  419. package/src/components/carousel/CCarouselContext.ts +8 -0
  420. package/src/components/carousel/CCarouselItem.tsx +6 -4
  421. package/src/components/carousel/__tests__/CCarousel.spec.tsx +1 -1
  422. package/src/components/close-button/__tests__/CCloseButton.spec.tsx +1 -1
  423. package/src/components/collapse/__tests__/CCollapse.spec.tsx +26 -7
  424. package/src/components/dropdown/CDropdown.tsx +35 -36
  425. package/src/components/dropdown/CDropdownContext.ts +18 -0
  426. package/src/components/dropdown/CDropdownDivider.tsx +1 -1
  427. package/src/components/dropdown/CDropdownHeader.tsx +1 -1
  428. package/src/components/dropdown/CDropdownItemPlain.tsx +1 -1
  429. package/src/components/dropdown/CDropdownMenu.tsx +3 -3
  430. package/src/components/dropdown/CDropdownToggle.tsx +2 -3
  431. package/src/components/dropdown/__tests__/CDropdown.spec.tsx +1 -1
  432. package/src/components/dropdown/__tests__/CDropdownDivider.spec.tsx +1 -1
  433. package/src/components/dropdown/__tests__/CDropdownHeader.spec.tsx +1 -1
  434. package/src/components/dropdown/__tests__/CDropdownItem.spec.tsx +1 -1
  435. package/src/components/dropdown/__tests__/CDropdownItemPlain.spec.tsx +1 -1
  436. package/src/components/dropdown/__tests__/CDropdownMenu.spec.tsx +1 -1
  437. package/src/components/dropdown/__tests__/CDropdownToggle.spec.tsx +1 -1
  438. package/src/components/dropdown/__tests__/__snapshots__/CDropdown.spec.tsx.snap +0 -1
  439. package/src/components/dropdown/__tests__/__snapshots__/CDropdownMenu.spec.tsx.snap +0 -2
  440. package/src/components/footer/__tests__/CFooter.spec.tsx +1 -1
  441. package/src/components/form/__tests__/CForm.spec.tsx +2 -1
  442. package/src/components/form/__tests__/CFormCheck.spec.tsx +1 -1
  443. package/src/components/form/__tests__/CFormControl.spec.tsx +1 -1
  444. package/src/components/form/__tests__/CFormFeedback.spec.tsx +1 -1
  445. package/src/components/form/__tests__/CFormFloating.spec.tsx +1 -1
  446. package/src/components/form/__tests__/CFormInput.spec.tsx +1 -1
  447. package/src/components/form/__tests__/CFormLabel.spec.tsx +1 -1
  448. package/src/components/form/__tests__/CFormRange.spec.tsx +1 -1
  449. package/src/components/form/__tests__/CFormSelect.spec.tsx +1 -1
  450. package/src/components/form/__tests__/CFormSwitch.spec.tsx +1 -1
  451. package/src/components/form/__tests__/CFormText.spec.tsx +1 -1
  452. package/src/components/form/__tests__/CFormTextarea.spec.tsx +1 -1
  453. package/src/components/form/__tests__/CInputGroup.spec.tsx +1 -1
  454. package/src/components/form/__tests__/CInputGroupText.spec.tsx +1 -1
  455. package/src/components/grid/__tests__/CCol.spec.tsx +1 -1
  456. package/src/components/grid/__tests__/CContainer.spec.tsx +1 -1
  457. package/src/components/grid/__tests__/CRow.spec.tsx +1 -1
  458. package/src/components/header/__tests__/CHeader.spec.tsx +1 -1
  459. package/src/components/header/__tests__/CHeaderBrand.spec.tsx +1 -1
  460. package/src/components/header/__tests__/CHeaderDivider.spec.tsx +1 -1
  461. package/src/components/header/__tests__/CHeaderNav.spec.tsx +1 -1
  462. package/src/components/header/__tests__/CHeaderText.spec.tsx +1 -1
  463. package/src/components/header/__tests__/CHeaderToggler.spec.tsx +1 -1
  464. package/src/components/image/__tests__/CImage.spec.tsx +1 -1
  465. package/src/components/link/__tests__/CLink.spec.tsx +1 -1
  466. package/src/components/list-group/__tests__/CListGroup.spec.tsx +1 -1
  467. package/src/components/list-group/__tests__/CListGroupItem.spec.tsx +1 -1
  468. package/src/components/modal/CModal.tsx +5 -12
  469. package/src/components/modal/CModalContext.ts +8 -0
  470. package/src/components/modal/CModalHeader.tsx +1 -1
  471. package/src/components/modal/__tests__/CModal.spec.tsx +1 -1
  472. package/src/components/modal/__tests__/CModalBody.spec.tsx +1 -1
  473. package/src/components/modal/__tests__/CModalContent.spec.tsx +1 -1
  474. package/src/components/modal/__tests__/CModalDialog.spec.tsx +1 -1
  475. package/src/components/modal/__tests__/CModalFooter.spec.tsx +1 -1
  476. package/src/components/modal/__tests__/CModalHeader.spec.tsx +1 -1
  477. package/src/components/modal/__tests__/CModalTitle.spec.tsx +1 -1
  478. package/src/components/nav/CNavGroup.tsx +2 -2
  479. package/src/components/nav/CNavLink.tsx +2 -2
  480. package/src/components/nav/__tests__/CNav.spec.tsx +4 -11
  481. package/src/components/nav/__tests__/CNavGroup.spec.tsx +1 -1
  482. package/src/components/nav/__tests__/CNavGroupItems.spec.tsx +1 -1
  483. package/src/components/nav/__tests__/CNavItem.spec.tsx +1 -1
  484. package/src/components/nav/__tests__/CNavLink.spec.tsx +1 -1
  485. package/src/components/nav/__tests__/CNavTitle.spec.tsx +1 -1
  486. package/src/components/nav/__tests__/__snapshots__/CNav.spec.tsx.snap +0 -1
  487. package/src/components/navbar/__tests__/CNavbar.spec.tsx +1 -1
  488. package/src/components/navbar/__tests__/CNavbarBrand.spec.tsx +1 -1
  489. package/src/components/navbar/__tests__/CNavbarNav.spec.tsx +1 -1
  490. package/src/components/navbar/__tests__/CNavbarText.spec.tsx +1 -1
  491. package/src/components/navbar/__tests__/CNavbarToggler.spec.tsx +1 -1
  492. package/src/components/offcanvas/__tests__/COffcanvas.spec.tsx +45 -17
  493. package/src/components/offcanvas/__tests__/COffcanvasBody.spec.tsx +1 -1
  494. package/src/components/offcanvas/__tests__/COffcanvasHeader.spec.tsx +1 -1
  495. package/src/components/offcanvas/__tests__/COffcanvasTitle.spec.tsx +1 -1
  496. package/src/components/pagination/__tests__/CPagination.spec.tsx +1 -1
  497. package/src/components/pagination/__tests__/CPaginationItem.spec.tsx +1 -1
  498. package/src/components/placeholder/__tests__/CPlaceholder.spec.tsx +1 -1
  499. package/src/components/popover/__tests__/CPopover.spec.tsx +70 -62
  500. package/src/components/popover/__tests__/__snapshots__/CPopover.spec.tsx.snap +0 -32
  501. package/src/components/progress/CProgress.tsx +1 -1
  502. package/src/components/progress/CProgressBar.tsx +2 -1
  503. package/src/components/progress/CProgressStacked.tsx +4 -8
  504. package/src/components/progress/CProgressStackedContext.ts +7 -0
  505. package/src/components/progress/__tests__/CProgress.spec.tsx +1 -1
  506. package/src/components/progress/__tests__/CProgressBar.spec.tsx +1 -1
  507. package/src/components/sidebar/CSidebarNav.tsx +27 -27
  508. package/src/components/sidebar/CSidebarNavContext.ts +8 -0
  509. package/src/components/sidebar/__tests__/CSidebar.spec.tsx +1 -1
  510. package/src/components/sidebar/__tests__/CSidebarBrand.spec.tsx +1 -1
  511. package/src/components/sidebar/__tests__/CSidebarFooter.spec.tsx +1 -1
  512. package/src/components/sidebar/__tests__/CSidebarHeader.spec.tsx +1 -1
  513. package/src/components/sidebar/__tests__/CSidebarNav.spec.tsx +1 -1
  514. package/src/components/sidebar/__tests__/CSidebarToggler.spec.tsx +1 -1
  515. package/src/components/spinner/__tests__/CSpinner.spec.tsx +1 -1
  516. package/src/components/table/__tests__/CTable.spec.tsx +1 -1
  517. package/src/components/table/__tests__/CTableBody.spec.tsx +1 -1
  518. package/src/components/table/__tests__/CTableCaption.spec.tsx +1 -1
  519. package/src/components/table/__tests__/CTableDataCell.spec.tsx +1 -1
  520. package/src/components/table/__tests__/CTableFoot.spec.tsx +1 -1
  521. package/src/components/table/__tests__/CTableHead.spec.tsx +1 -1
  522. package/src/components/table/__tests__/CTableHeaderCell.spec.tsx +1 -1
  523. package/src/components/table/__tests__/CTableRow.spec.tsx +1 -1
  524. package/src/components/tabs/CTab.tsx +2 -2
  525. package/src/components/tabs/CTabPane.tsx +1 -1
  526. package/src/components/tabs/CTabPanel.tsx +3 -3
  527. package/src/components/tabs/CTabs.tsx +54 -21
  528. package/src/components/tabs/CTabsContext.ts +9 -0
  529. package/src/components/tabs/__tests__/CTabContent.spec.tsx +17 -8
  530. package/src/components/tabs/__tests__/CTabPane.spec.tsx +49 -29
  531. package/src/components/toast/CToast.tsx +9 -24
  532. package/src/components/toast/CToastClose.tsx +1 -2
  533. package/src/components/toast/CToastContext.ts +8 -0
  534. package/src/components/toast/CToaster.tsx +11 -7
  535. package/src/components/toast/__tests__/CToast.spec.tsx +32 -27
  536. package/src/components/toast/__tests__/CToastBody.spec.tsx +1 -1
  537. package/src/components/toast/__tests__/CToastHeader.spec.tsx +1 -1
  538. package/src/components/toast/__tests__/CToaster.spec.tsx +2 -1
  539. package/src/components/tooltip/__tests__/CTooltip.spec.tsx +54 -33
  540. package/src/components/tooltip/__tests__/__snapshots__/CTooltip.spec.tsx.snap +0 -10
  541. package/src/components/widgets/__tests__/CWidgetStatsA.spec.tsx +1 -1
  542. package/src/components/widgets/__tests__/CWidgetStatsB.spec.tsx +1 -1
  543. package/src/components/widgets/__tests__/CWidgetStatsC.spec.tsx +1 -1
  544. package/src/components/widgets/__tests__/CWidgetStatsD.spec.tsx +1 -1
  545. package/src/components/widgets/__tests__/CWidgetStatsE.spec.tsx +1 -1
  546. package/src/components/widgets/__tests__/CWidgetStatsF.spec.tsx +1 -1
  547. package/src/hooks/usePopper.ts +2 -2
  548. package/src/components/button/__tests__/CButtonClose.spec.tsx +0 -23
  549. package/src/components/button/__tests__/__snapshots__/CButtonClose.spec.tsx.snap +0 -26
@@ -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 { CTableBody, CTableDataCell, CTableRow } from '../../../index'
4
+ import { CTableBody, CTableDataCell, CTableRow } from '../index'
5
5
 
6
6
  test('loads and displays CTableBody component', async () => {
7
7
  const table = document.createElement('table')
@@ -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 { CTableCaption } from '../../../index'
4
+ import { CTableCaption } from '../index'
5
5
 
6
6
  test('loads and displays CTableCaption component', async () => {
7
7
  const table = document.createElement('table')
@@ -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 { CTableDataCell } from '../../../index'
4
+ import { CTableDataCell } from '../index'
5
5
  import { CTableBody } from '../CTableBody'
6
6
  import { CTableRow } from '../CTableRow'
7
7
 
@@ -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 { CTableFoot, CTableHeaderCell, CTableRow } from '../../../index'
4
+ import { CTableFoot, CTableHeaderCell, CTableRow } from '../index'
5
5
 
6
6
  test('loads and displays CTableFoot component', async () => {
7
7
  const table = document.createElement('table')
@@ -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 { CTableHead, CTableHeaderCell, CTableRow } from '../../../index'
4
+ import { CTableHead, CTableHeaderCell, CTableRow } from '../index'
5
5
 
6
6
  test('loads and displays CTableHead component', async () => {
7
7
  const table = document.createElement('table')
@@ -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 { CTableHead, CTableHeaderCell, CTableRow } from '../../../index'
4
+ import { CTableHead, CTableHeaderCell, CTableRow } from '../index'
5
5
 
6
6
  test('loads and displays CTableHeaderCell component', async () => {
7
7
  const table = document.createElement('table')
@@ -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 { CTableBody, CTableHeaderCell, CTableRow } from '../../../index'
4
+ import { CTableBody, CTableHeaderCell, CTableRow } from '../index'
5
5
 
6
6
  test('loads and displays CTableRow component', async () => {
7
7
  const table = document.createElement('table')
@@ -2,7 +2,7 @@ import React, { forwardRef, HTMLAttributes, useContext } from 'react'
2
2
  import PropTypes from 'prop-types'
3
3
  import classNames from 'classnames'
4
4
 
5
- import { TabsContext } from './CTabs'
5
+ import { CTabsContext } from './CTabsContext'
6
6
 
7
7
  export interface CTabProps extends HTMLAttributes<HTMLButtonElement> {
8
8
  /**
@@ -21,7 +21,7 @@ export interface CTabProps extends HTMLAttributes<HTMLButtonElement> {
21
21
 
22
22
  export const CTab = forwardRef<HTMLButtonElement, CTabProps>(
23
23
  ({ children, className, itemKey, ...rest }, ref) => {
24
- const { _activeItemKey, setActiveItemKey, id } = useContext(TabsContext)
24
+ const { _activeItemKey, setActiveItemKey, id } = useContext(CTabsContext)
25
25
 
26
26
  const isActive = () => itemKey === _activeItemKey
27
27
 
@@ -32,7 +32,7 @@ export interface CTabPaneProps extends HTMLAttributes<HTMLDivElement> {
32
32
 
33
33
  export const CTabPane = forwardRef<HTMLDivElement, CTabPaneProps>(
34
34
  ({ children, className, onHide, onShow, transition = true, visible, ...rest }, ref) => {
35
- const tabPaneRef = useRef()
35
+ const tabPaneRef = useRef(null)
36
36
  const forkedRef = useForkedRef(ref, tabPaneRef)
37
37
 
38
38
  return (
@@ -3,7 +3,7 @@ import PropTypes from 'prop-types'
3
3
  import classNames from 'classnames'
4
4
  import { Transition } from 'react-transition-group'
5
5
 
6
- import { TabsContext } from './CTabs'
6
+ import { CTabsContext } from './CTabsContext'
7
7
  import { useForkedRef } from '../../hooks'
8
8
  import { getTransitionDurationFromElement } from '../../utils'
9
9
 
@@ -36,9 +36,9 @@ export interface CTabPanelProps extends HTMLAttributes<HTMLDivElement> {
36
36
 
37
37
  export const CTabPanel = forwardRef<HTMLDivElement, CTabPanelProps>(
38
38
  ({ children, className, itemKey, onHide, onShow, transition = true, visible, ...rest }, ref) => {
39
- const { _activeItemKey, id } = useContext(TabsContext)
39
+ const { _activeItemKey, id } = useContext(CTabsContext)
40
40
 
41
- const tabPaneRef = useRef()
41
+ const tabPaneRef = useRef(null)
42
42
  const forkedRef = useForkedRef(ref, tabPaneRef)
43
43
 
44
44
  const [_visible, setVisible] = useState(visible || _activeItemKey === itemKey)
@@ -1,53 +1,86 @@
1
- import React, { createContext, forwardRef, HTMLAttributes, useEffect, useId, useState } from 'react'
1
+ import React, { forwardRef, HTMLAttributes, useId, useState } from 'react'
2
2
  import PropTypes from 'prop-types'
3
3
  import classNames from 'classnames'
4
4
 
5
+ import { CTabsContext } from './CTabsContext'
6
+
5
7
  export interface CTabsProps extends Omit<HTMLAttributes<HTMLDivElement>, 'onChange'> {
6
8
  /**
7
- * The active item key.
9
+ * Controls the currently active tab.
10
+ *
11
+ * When provided, the component operates in a controlled mode.
12
+ * You must handle tab switching manually by updating this prop.
13
+ *
14
+ * @example
15
+ * const [activeTab, setActiveTab] = useState(0);
16
+ * <CTabs activeItemKey={activeTab} onChange={setActiveTab} />
8
17
  */
9
- activeItemKey: number | string
18
+ activeItemKey?: number | string
19
+
10
20
  /**
11
21
  * A string of all className you want applied to the base component.
12
22
  */
13
23
  className?: string
24
+
14
25
  /**
15
- * The callback is fired when the active tab changes.
26
+ * Sets the initially active tab when the component mounts.
27
+ *
28
+ * After initialization, the component manages active tab changes internally.
29
+ *
30
+ * Use `defaultActiveItemKey` for uncontrolled usage.
31
+ *
32
+ * @example
33
+ * <CTabs defaultActiveItemKey={1} />
16
34
  */
17
- onChange?: (value: number | string) => void
18
- }
35
+ defaultActiveItemKey?: number | string
19
36
 
20
- export interface TabsContextProps {
21
- _activeItemKey?: number | string
22
- setActiveItemKey: React.Dispatch<React.SetStateAction<number | string | undefined>>
23
- id?: string
37
+ /**
38
+ * Callback fired when the active tab changes.
39
+ *
40
+ * - In controlled mode (`activeItemKey` provided), you must update `activeItemKey` yourself based on the value received.
41
+ * - In uncontrolled mode, this callback is called after internal state updates.
42
+ *
43
+ * @param value - The newly selected tab key.
44
+ *
45
+ * @example
46
+ * <CTabs onChange={(key) => console.log('Tab changed to', key)} />
47
+ */
48
+ onChange?: (value: number | string) => void
24
49
  }
25
50
 
26
- export const TabsContext = createContext({} as TabsContextProps)
27
-
28
51
  export const CTabs = forwardRef<HTMLDivElement, CTabsProps>(
29
- ({ children, activeItemKey, className, onChange }, ref) => {
52
+ ({ children, activeItemKey, className, defaultActiveItemKey, onChange }, ref) => {
30
53
  const id = useId()
31
- const [_activeItemKey, setActiveItemKey] = useState(activeItemKey)
54
+ const isControlled = activeItemKey !== undefined
55
+ const [internalActiveItemKey, setInternalActiveItemKey] = useState<number | string | undefined>(
56
+ () => (isControlled ? undefined : defaultActiveItemKey)
57
+ )
58
+
59
+ const currentActiveItemKey = isControlled ? activeItemKey : internalActiveItemKey
60
+
61
+ const setActiveItemKey = (value: number | string) => {
62
+ if (!isControlled) {
63
+ setInternalActiveItemKey(value)
64
+ }
32
65
 
33
- useEffect(() => {
34
- _activeItemKey && onChange && onChange(_activeItemKey)
35
- }, [_activeItemKey])
66
+ onChange?.(value)
67
+ }
36
68
 
37
69
  return (
38
- <TabsContext.Provider value={{ _activeItemKey, setActiveItemKey, id }}>
70
+ <CTabsContext.Provider value={{ _activeItemKey: currentActiveItemKey, setActiveItemKey, id }}>
39
71
  <div className={classNames('tabs', className)} ref={ref}>
40
72
  {children}
41
73
  </div>
42
- </TabsContext.Provider>
74
+ </CTabsContext.Provider>
43
75
  )
44
- },
76
+ }
45
77
  )
46
78
 
47
79
  CTabs.propTypes = {
48
- activeItemKey: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired,
80
+ activeItemKey: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
49
81
  children: PropTypes.node,
50
82
  className: PropTypes.string,
83
+ defaultActiveItemKey: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
51
84
  onChange: PropTypes.func,
52
85
  }
53
86
 
@@ -0,0 +1,9 @@
1
+ import { createContext } from 'react'
2
+
3
+ export interface CTabsContextProps {
4
+ _activeItemKey?: number | string
5
+ setActiveItemKey: React.Dispatch<React.SetStateAction<number | string | undefined>>
6
+ id?: string
7
+ }
8
+
9
+ export const CTabsContext = createContext({} as CTabsContextProps)
@@ -1,16 +1,25 @@
1
1
  import * as React from 'react'
2
- import { render } from '@testing-library/react'
2
+ import { act, render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CTabContent } from '../../../index'
4
+
5
+ import { CTabContent } from '../index'
5
6
 
6
7
  test('loads and displays CTabContent component', async () => {
7
- const { container } = render(<CTabContent>Test</CTabContent>)
8
- expect(container).toMatchSnapshot()
8
+ let container: HTMLElement
9
+ await act(async () => {
10
+ const renderResult = render(<CTabContent>Test</CTabContent>)
11
+ container = renderResult.container
12
+ })
13
+ expect(container!).toMatchSnapshot()
9
14
  })
10
15
 
11
16
  test('CTabContent customize', async () => {
12
- const { container } = render(<CTabContent className="bazinga">Test</CTabContent>)
13
- expect(container).toMatchSnapshot()
14
- expect(container.firstChild).toHaveClass('bazinga')
15
- expect(container.firstChild).toHaveClass('tab-content')
17
+ let container: HTMLElement
18
+ await act(async () => {
19
+ const renderResult = render(<CTabContent className="bazinga">Test</CTabContent>)
20
+ container = renderResult.container
21
+ })
22
+ expect(container!).toMatchSnapshot()
23
+ expect(container!.firstChild).toHaveClass('bazinga')
24
+ expect(container!.firstChild).toHaveClass('tab-content')
16
25
  })
@@ -1,48 +1,68 @@
1
1
  import * as React from 'react'
2
- import { render, screen } from '@testing-library/react'
2
+ import { act, render, screen, waitFor } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CTabPane, CTabContent } from '../../../index'
4
+
5
+ import { CTabPane, CTabContent } from '../index'
5
6
 
6
7
  test('loads and displays CTabPane component', async () => {
7
- const { container } = render(<CTabPane>Test</CTabPane>)
8
- expect(container).toMatchSnapshot()
8
+ let container: HTMLElement
9
+ await act(async () => {
10
+ const renderResult = render(<CTabPane>Test</CTabPane>)
11
+ container = renderResult.container
12
+ })
13
+ expect(container!).toMatchSnapshot()
9
14
  })
10
15
 
11
16
  test('CTabPane customize', async () => {
12
- const { container } = render(
13
- <CTabPane className="bazinga" visible={true}>
14
- Test
15
- </CTabPane>,
16
- )
17
- expect(container).toMatchSnapshot()
17
+ let container: HTMLElement
18
+ await act(async () => {
19
+ const renderResult = render(
20
+ <CTabPane className="bazinga" visible={true}>
21
+ Test
22
+ </CTabPane>
23
+ )
24
+ container = renderResult.container
25
+ })
26
+ expect(container!).toMatchSnapshot()
18
27
  })
19
28
 
20
29
  test('CTabContent use case test', async () => {
30
+ jest.useFakeTimers()
31
+
21
32
  const { rerender } = render(
22
33
  <CTabContent>
23
34
  <CTabPane visible={false}>Test</CTabPane>
24
- </CTabContent>,
25
- )
26
- expect(screen.getByText('Test')).not.toHaveClass('show')
27
- expect(screen.getByText('Test')).not.toHaveClass('active')
28
- rerender(
29
- <CTabContent>
30
- <CTabPane visible={true}>Test</CTabPane>
31
- </CTabContent>,
32
- )
33
- expect(screen.getByText('Test')).not.toHaveClass('show')
34
- expect(screen.getByText('Test')).toHaveClass('active')
35
- await new Promise((r) => setTimeout(r, 1000))
36
- expect(screen.getByText('Test')).toHaveClass('show')
37
- expect(screen.getByText('Test')).toHaveClass('active')
38
- rerender(
39
- <CTabContent>
40
- <CTabPane visible={false}>Test</CTabPane>
41
- </CTabContent>,
35
+ </CTabContent>
42
36
  )
37
+
43
38
  expect(screen.getByText('Test')).not.toHaveClass('show')
44
39
  expect(screen.getByText('Test')).not.toHaveClass('active')
45
- await new Promise((r) => setTimeout(r, 1000))
40
+
41
+ act(() => {
42
+ rerender(
43
+ <CTabContent>
44
+ <CTabPane visible={true}>Test</CTabPane>
45
+ </CTabContent>
46
+ )
47
+ jest.runAllTimers()
48
+ })
49
+
50
+ await waitFor(() => {
51
+ expect(screen.getByText('Test')).toHaveClass('active')
52
+ expect(screen.getByText('Test')).toHaveClass('show')
53
+ })
54
+
55
+ act(() => {
56
+ rerender(
57
+ <CTabContent>
58
+ <CTabPane visible={false}>Test</CTabPane>
59
+ </CTabContent>
60
+ )
61
+ jest.runAllTimers()
62
+ })
63
+
46
64
  expect(screen.getByText('Test')).not.toHaveClass('show')
47
65
  expect(screen.getByText('Test')).not.toHaveClass('active')
66
+
67
+ jest.useRealTimers()
48
68
  })
@@ -1,15 +1,10 @@
1
- import React, {
2
- createContext,
3
- forwardRef,
4
- HTMLAttributes,
5
- useEffect,
6
- useRef,
7
- useState,
8
- } from 'react'
1
+ import React, { forwardRef, HTMLAttributes, useEffect, useRef, useState } from 'react'
9
2
  import PropTypes from 'prop-types'
10
3
  import classNames from 'classnames'
11
4
  import { Transition } from 'react-transition-group'
12
5
 
6
+ import { CToastContext } from './CToastContext'
7
+
13
8
  import { useForkedRef } from '../../hooks'
14
9
  import { colorPropType } from '../../props'
15
10
  import type { Colors } from '../../types'
@@ -59,13 +54,6 @@ export interface CToastProps extends Omit<HTMLAttributes<HTMLDivElement>, 'title
59
54
  visible?: boolean
60
55
  }
61
56
 
62
- interface ContextProps extends CToastProps {
63
- visible?: boolean
64
- setVisible: React.Dispatch<React.SetStateAction<boolean | undefined>>
65
- }
66
-
67
- export const CToastContext = createContext({} as ContextProps)
68
-
69
57
  export const CToast = forwardRef<HTMLDivElement, CToastProps>(
70
58
  (
71
59
  {
@@ -82,12 +70,12 @@ export const CToast = forwardRef<HTMLDivElement, CToastProps>(
82
70
  onShow,
83
71
  ...rest
84
72
  },
85
- ref,
73
+ ref
86
74
  ) => {
87
- const toastRef = useRef()
75
+ const toastRef = useRef(null)
88
76
  const forkedRef = useForkedRef(ref, toastRef)
89
77
  const [_visible, setVisible] = useState(false)
90
- const timeout = useRef<number>()
78
+ const timeout = useRef<number>(undefined)
91
79
 
92
80
  useEffect(() => {
93
81
  setVisible(visible)
@@ -135,7 +123,7 @@ export const CToast = forwardRef<HTMLDivElement, CToastProps>(
135
123
  'show showing': state === 'entering' || state === 'exiting',
136
124
  show: state === 'entered',
137
125
  },
138
- className,
126
+ className
139
127
  )}
140
128
  aria-live="assertive"
141
129
  aria-atomic="true"
@@ -152,7 +140,7 @@ export const CToast = forwardRef<HTMLDivElement, CToastProps>(
152
140
  )}
153
141
  </Transition>
154
142
  )
155
- },
143
+ }
156
144
  )
157
145
 
158
146
  CToast.propTypes = {
@@ -163,10 +151,7 @@ CToast.propTypes = {
163
151
  color: colorPropType,
164
152
  delay: PropTypes.number,
165
153
  index: PropTypes.number,
166
- innerKey: PropTypes.oneOfType([
167
- PropTypes.number,
168
- PropTypes.string
169
- ]),
154
+ innerKey: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
170
155
  onClose: PropTypes.func,
171
156
  onShow: PropTypes.func,
172
157
  visible: PropTypes.bool,
@@ -3,8 +3,7 @@ import PropTypes from 'prop-types'
3
3
 
4
4
  import { CButtonProps } from '../button/CButton'
5
5
  import { CCloseButton, CCloseButtonProps } from '../close-button/CCloseButton'
6
-
7
- import { CToastContext } from './CToast'
6
+ import { CToastContext } from './CToastContext'
8
7
 
9
8
  import { PolymorphicRefForwardingComponent } from '../../helpers'
10
9
 
@@ -0,0 +1,8 @@
1
+ import { createContext } from 'react'
2
+
3
+ export interface CToastContextProps {
4
+ visible?: boolean
5
+ setVisible: React.Dispatch<React.SetStateAction<boolean | undefined>>
6
+ }
7
+
8
+ export const CToastContext = createContext({} as CToastContextProps)
@@ -3,6 +3,8 @@ import PropTypes from 'prop-types'
3
3
  import classNames from 'classnames'
4
4
  import { CConditionalPortal } from '../conditional-portal'
5
5
 
6
+ import type { CToastProps } from './CToast'
7
+
6
8
  export interface CToasterProps extends HTMLAttributes<HTMLDivElement> {
7
9
  /**
8
10
  * A string of all className you want applied to the base component.
@@ -27,20 +29,22 @@ export interface CToasterProps extends HTMLAttributes<HTMLDivElement> {
27
29
  /**
28
30
  * Adds new `CToast` to `CToaster`.
29
31
  */
30
- push?: ReactElement
32
+ push?: ReactElement<CToastProps>
31
33
  }
32
34
 
33
35
  export const CToaster = forwardRef<HTMLDivElement, CToasterProps>(
34
36
  ({ children, className, placement, push, ...rest }, ref) => {
35
- const [toasts, setToasts] = useState<ReactElement[]>([])
37
+ const [toasts, setToasts] = useState<ReactElement<CToastProps>[]>([])
36
38
  const index = useRef<number>(0)
37
39
 
38
40
  useEffect(() => {
39
41
  index.current++
40
- push && addToast(push)
42
+ if (push) {
43
+ addToast(push)
44
+ }
41
45
  }, [push])
42
46
 
43
- const addToast = (push: ReactElement) => {
47
+ const addToast = (push: ReactElement<CToastProps>) => {
44
48
  setToasts((state) => [
45
49
  ...state,
46
50
  React.cloneElement(push, {
@@ -67,18 +71,18 @@ export const CToaster = forwardRef<HTMLDivElement, CToasterProps>(
67
71
  'start-50 translate-middle-x': placement && placement.includes('center'),
68
72
  'end-0': placement && placement.includes('end'),
69
73
  },
70
- className,
74
+ className
71
75
  )}
72
76
  {...rest}
73
77
  ref={ref}
74
78
  >
75
79
  {children}
76
- {toasts.map((toast) => React.cloneElement(toast, { visible: true }))}
80
+ {toasts.map((toast, index) => React.cloneElement(toast, { visible: true, key: index }))}
77
81
  </div>
78
82
  ) : null}
79
83
  </CConditionalPortal>
80
84
  )
81
- },
85
+ }
82
86
  )
83
87
 
84
88
  CToaster.propTypes = {
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react'
2
- import { render, fireEvent, waitFor } from '@testing-library/react'
2
+ import { render, fireEvent, waitFor, act } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CToast, CToastBody, CToastHeader } from '../../../index'
4
+ import { CToast, CToastBody, CToastHeader } from '../index'
5
5
 
6
6
  test('loads and displays CToast component', async () => {
7
7
  const { container } = render(<CToast>Test</CToast>)
@@ -10,16 +10,9 @@ test('loads and displays CToast component', async () => {
10
10
 
11
11
  test('CToast customize', async () => {
12
12
  const { container } = render(
13
- <CToast
14
- className="bazinga"
15
- autohide={false}
16
- color="warning"
17
- delay={100}
18
- visible={true}
19
- //onClose
20
- >
13
+ <CToast className="bazinga" autohide={false} color="warning" delay={100} visible={true}>
21
14
  Test
22
- </CToast>,
15
+ </CToast>
23
16
  )
24
17
  await waitFor(() => {
25
18
  expect(container).toMatchSnapshot()
@@ -32,7 +25,8 @@ test('CToast customize', async () => {
32
25
  })
33
26
 
34
27
  test('CToast click on dismiss button', async () => {
35
- // jest.useFakeTimers()
28
+ jest.useFakeTimers()
29
+
36
30
  const onClose = jest.fn()
37
31
  const { container } = render(
38
32
  <CToast
@@ -59,41 +53,52 @@ test('CToast click on dismiss button', async () => {
59
53
  <small>7 min ago</small>
60
54
  </CToastHeader>
61
55
  <CToastBody>Hello, world! This is a toast message.</CToastBody>
62
- </CToast>,
56
+ </CToast>
63
57
  )
58
+
64
59
  await waitFor(() => {
65
60
  expect(container.firstChild).toHaveClass('show')
66
61
  })
67
62
 
68
63
  expect(onClose).toHaveBeenCalledTimes(0)
64
+
69
65
  const btn = document.querySelector('.btn-close')
66
+
70
67
  if (btn !== null) {
71
- fireEvent.click(btn)
68
+ act(() => {
69
+ fireEvent.click(btn)
70
+ jest.runAllTimers()
71
+ })
72
72
  }
73
- jest.runAllTimers()
74
- await new Promise((r) => setTimeout(r, 1000))
75
- expect(onClose).toHaveBeenCalledTimes(1)
76
- expect(container.firstChild).toBeNull()
73
+
74
+ await waitFor(() => {
75
+ expect(onClose).toHaveBeenCalledTimes(1)
76
+ expect(container.firstChild).toBeNull()
77
+ })
78
+
77
79
  jest.useRealTimers()
78
80
  })
79
81
 
80
82
  test('CToast test autohide', async () => {
83
+ jest.useFakeTimers()
84
+
81
85
  const { container } = render(
82
86
  <CToast autohide={true} delay={1000} visible={true}>
83
87
  Test
84
- </CToast>,
88
+ </CToast>
85
89
  )
86
90
 
87
91
  await waitFor(() => {
88
92
  expect(container.firstChild).toHaveClass('show')
89
93
  })
90
94
 
91
- await waitFor(
92
- () => {
93
- expect(container.firstChild).toBeNull()
94
- },
95
- {
96
- timeout: 5000,
97
- },
98
- )
95
+ act(() => {
96
+ jest.advanceTimersByTime(1000)
97
+ })
98
+
99
+ await waitFor(() => {
100
+ expect(container.firstChild).toBeNull()
101
+ })
102
+
103
+ jest.useRealTimers()
99
104
  })
@@ -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 { CToastBody } from '../../../index'
4
+ import { CToastBody } from '../index'
5
5
 
6
6
  test('loads and displays CToastBody component', async () => {
7
7
  const { container } = render(<CToastBody>Test</CToastBody>)
@@ -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 { CToastHeader } from '../../../index'
4
+ import { CToastHeader } from '../index'
5
5
 
6
6
  test('loads and displays CToastHeader component', async () => {
7
7
  const { container } = render(<CToastHeader>Test</CToastHeader>)