@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,7 +1,9 @@
1
- import React, { createContext, forwardRef, HTMLAttributes } from 'react'
1
+ import React, { forwardRef, HTMLAttributes } from 'react'
2
2
  import PropTypes from 'prop-types'
3
3
  import classNames from 'classnames'
4
4
 
5
+ import { CProgressStackedContext } from './CProgressStackedContext'
6
+
5
7
  export interface CProgressStackedProps extends HTMLAttributes<HTMLDivElement> {
6
8
  /**
7
9
  * A string of all className you want applied to the component.
@@ -9,12 +11,6 @@ export interface CProgressStackedProps extends HTMLAttributes<HTMLDivElement> {
9
11
  className?: string
10
12
  }
11
13
 
12
- export interface CProgressStackedContextProps {
13
- stacked?: boolean
14
- }
15
-
16
- export const CProgressStackedContext = createContext({} as CProgressStackedContextProps)
17
-
18
14
  export const CProgressStacked = forwardRef<HTMLDivElement, CProgressStackedProps>(
19
15
  ({ children, className, ...rest }, ref) => {
20
16
  return (
@@ -28,7 +24,7 @@ export const CProgressStacked = forwardRef<HTMLDivElement, CProgressStackedProps
28
24
  </CProgressStackedContext.Provider>
29
25
  </div>
30
26
  )
31
- },
27
+ }
32
28
  )
33
29
 
34
30
  CProgressStacked.propTypes = {
@@ -0,0 +1,7 @@
1
+ import { createContext } from 'react'
2
+
3
+ export interface CProgressStackedContextProps {
4
+ stacked?: boolean
5
+ }
6
+
7
+ export const CProgressStackedContext = createContext({} as CProgressStackedContextProps)
@@ -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 { CProgress } from '../../../index'
4
+ import { CProgress } from '../index'
5
5
 
6
6
  test('loads and displays CProgress component', async () => {
7
7
  const { container } = render(<CProgress color="warning">Test</CProgress>)
@@ -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 { CProgressBar } from '../../../index'
4
+ import { CProgressBar } from '../index'
5
5
 
6
6
  test('loads and displays CProgressBar component', async () => {
7
7
  const { container } = render(<CProgressBar color="warning">Test</CProgressBar>)
@@ -1,5 +1,4 @@
1
1
  import React, {
2
- createContext,
3
2
  ElementType,
4
3
  forwardRef,
5
4
  HTMLAttributes,
@@ -10,6 +9,12 @@ import React, {
10
9
  import PropTypes from 'prop-types'
11
10
  import classNames from 'classnames'
12
11
 
12
+ import type { CNavGroupProps } from '../nav/CNavGroup'
13
+ import type { CNavLinkProps } from '../nav/CNavLink'
14
+ import type { CNavItemProps } from '../nav/CNavItem'
15
+
16
+ import { CSidebarNavContext } from './CSidebarNavContext'
17
+
13
18
  import { PolymorphicRefForwardingComponent } from '../../helpers'
14
19
 
15
20
  export interface CSidebarNavProps extends HTMLAttributes<HTMLUListElement> {
@@ -25,42 +30,37 @@ export interface CSidebarNavProps extends HTMLAttributes<HTMLUListElement> {
25
30
  className?: string
26
31
  }
27
32
 
28
- interface ContextProps {
29
- visibleGroup: string
30
- setVisibleGroup: React.Dispatch<React.SetStateAction<string | undefined>>
33
+ const isNavElement = (
34
+ child: ReactNode
35
+ ): child is ReactElement<CNavGroupProps | CNavLinkProps | CNavItemProps> => {
36
+ if (!React.isValidElement(child)) return false
37
+ const type = child.type as { displayName?: string }
38
+ return (
39
+ type.displayName === 'CNavGroup' ||
40
+ type.displayName === 'CNavLink' ||
41
+ type.displayName === 'CNavItem'
42
+ )
31
43
  }
32
44
 
33
- export const CNavContext = createContext({} as ContextProps)
34
-
35
45
  const recursiveClone = (children: ReactNode, id?: string, updateId?: boolean): ReactNode => {
36
- return React.Children.map(children, (child: ReactNode, index: number) => {
37
- if (
38
- !React.isValidElement(child) ||
39
- // @ts-expect-error the `children` exist in each component. TODO: resolve
40
- (child.type.displayName !== 'CNavGroup' &&
41
- // @ts-expect-error the `children` exist in each component. TODO: resolve
42
- child.type.displayName !== 'CNavLink' &&
43
- // @ts-expect-error the `children` exist in each component. TODO: resolve
44
- child.type.displayName !== 'CNavItem')
45
- ) {
46
+ return React.Children.map(children, (child, index) => {
47
+ if (!isNavElement(child)) {
46
48
  return child
47
49
  }
48
50
 
49
51
  const _id = id ? (updateId ? `${id}.${index}` : `${id}`) : `${index}`
50
52
 
51
- if (child.props && child.props.children) {
52
- return React.cloneElement(child as ReactElement<any>, {
53
+ if (child.props.children) {
54
+ const type = child.type as { displayName?: string }
55
+ const shouldUpdateId = type.displayName !== 'CNavItem'
56
+
57
+ return React.cloneElement(child, {
53
58
  idx: _id,
54
- children: recursiveClone(
55
- child.props.children,
56
- _id,
57
- // @ts-expect-error the `displayName` exist in each component. TODO: resolve
58
- child.type.displayName === 'CNavItem' ? false : true,
59
- ),
59
+ children: recursiveClone(child.props.children, _id, shouldUpdateId),
60
60
  })
61
61
  }
62
62
 
63
- return React.cloneElement(child as ReactElement<any>, {
63
+ return React.cloneElement(child, {
64
64
  idx: _id,
65
65
  })
66
66
  })
@@ -77,11 +77,11 @@ export const CSidebarNav: PolymorphicRefForwardingComponent<'ul', CSidebarNavPro
77
77
  }
78
78
 
79
79
  return (
80
- <CNavContext.Provider value={CNavContextValues}>
80
+ <CSidebarNavContext.Provider value={CNavContextValues}>
81
81
  <Component className={classNames('sidebar-nav', className)} ref={ref} {...rest}>
82
82
  {recursiveClone(children)}
83
83
  </Component>
84
- </CNavContext.Provider>
84
+ </CSidebarNavContext.Provider>
85
85
  )
86
86
  })
87
87
 
@@ -0,0 +1,8 @@
1
+ import { createContext } from 'react'
2
+
3
+ export interface CSidebarNavContextProps {
4
+ visibleGroup: string
5
+ setVisibleGroup: React.Dispatch<React.SetStateAction<string | undefined>>
6
+ }
7
+
8
+ export const CSidebarNavContext = createContext({} as CSidebarNavContextProps)
@@ -3,7 +3,7 @@ import { render } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
4
  import {
5
5
  CSidebar /* , CSidebarNav, CNavLink, CNavGroup, CNavGroupItems, CNavItem */,
6
- } from '../../../index'
6
+ } from '../index'
7
7
 
8
8
  test('loads and displays CSidebar component', async () => {
9
9
  const { container } = render(<CSidebar>Test</CSidebar>)
@@ -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 { CSidebarBrand } from '../../../index'
4
+ import { CSidebarBrand } from '../index'
5
5
 
6
6
  test('loads and displays CSidebarBrand component', async () => {
7
7
  const { container } = render(<CSidebarBrand color="primary">Test</CSidebarBrand>)
@@ -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 { CSidebarFooter } from '../../../index'
4
+ import { CSidebarFooter } from '../index'
5
5
 
6
6
  test('loads and displays CSidebarFooter component', async () => {
7
7
  const { container } = render(<CSidebarFooter>Test</CSidebarFooter>)
@@ -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 { CSidebarHeader } from '../../../index'
4
+ import { CSidebarHeader } from '../index'
5
5
 
6
6
  test('loads and displays CSidebarHeader component', async () => {
7
7
  const { container } = render(<CSidebarHeader>Test</CSidebarHeader>)
@@ -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 { CSidebarNav } from '../../../index'
4
+ import { CSidebarNav } from '../index'
5
5
 
6
6
  test('loads and displays CSidebarNav component', async () => {
7
7
  const { container } = render(<CSidebarNav>Test</CSidebarNav>)
@@ -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 { CSidebarToggler } from '../../../index'
4
+ import { CSidebarToggler } from '../index'
5
5
 
6
6
  test('loads and displays CSidebarToggler component', async () => {
7
7
  const { container } = render(<CSidebarToggler />)
@@ -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 { CSpinner } from '../../../index'
4
+ import { CSpinner } from '../index'
5
5
 
6
6
  test('loads and displays CSpinner component', async () => {
7
7
  const { container } = render(<CSpinner>Test</CSpinner>)
@@ -10,7 +10,7 @@ import {
10
10
  CTableBody,
11
11
  CTableDataCell,
12
12
  CTableFoot,
13
- } from '../../../index'
13
+ } from '../index'
14
14
 
15
15
  test('loads and displays CTable component', async () => {
16
16
  const { container } = render(<CTable />)
@@ -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
 
@@ -17,7 +17,7 @@ export interface CTabListProps extends HTMLAttributes<HTMLDivElement> {
17
17
  /**
18
18
  * Set the nav variant to tabs or pills.
19
19
  */
20
- variant?: 'pills' | 'tabs' | 'underline' | 'underline-border'
20
+ variant?: 'enclosed' | 'enclosed-pills' | 'pills' | 'tabs' | 'underline' | 'underline-border'
21
21
  }
22
22
 
23
23
  export const CTabList = forwardRef<HTMLDivElement, CTabListProps>(
@@ -39,7 +39,7 @@ export const CTabList = forwardRef<HTMLDivElement, CTabListProps>(
39
39
  const target = event.target as HTMLElement
40
40
  // eslint-disable-next-line unicorn/prefer-spread
41
41
  const items: HTMLElement[] = Array.from(
42
- tabListRef.current.querySelectorAll('.nav-link:not(.disabled):not(:disabled)'),
42
+ tabListRef.current.querySelectorAll('.nav-link:not(.disabled):not(:disabled)')
43
43
  )
44
44
 
45
45
  let nextActiveElement
@@ -51,7 +51,7 @@ export const CTabList = forwardRef<HTMLDivElement, CTabListProps>(
51
51
  items,
52
52
  target,
53
53
  event.key === 'ArrowDown' || event.key === 'ArrowRight',
54
- true,
54
+ true
55
55
  )
56
56
  }
57
57
 
@@ -65,11 +65,12 @@ export const CTabList = forwardRef<HTMLDivElement, CTabListProps>(
65
65
  <div
66
66
  className={classNames(
67
67
  'nav',
68
+ variant === 'enclosed-pills' && 'nav-enclosed', // Enclosed pills variant required for `.nav-enclosed` class
68
69
  {
69
70
  [`nav-${layout}`]: layout,
70
71
  [`nav-${variant}`]: variant,
71
72
  },
72
- className,
73
+ className
73
74
  )}
74
75
  role="tablist"
75
76
  onKeyDown={handleKeydown}
@@ -79,14 +80,21 @@ export const CTabList = forwardRef<HTMLDivElement, CTabListProps>(
79
80
  {children}
80
81
  </div>
81
82
  )
82
- },
83
+ }
83
84
  )
84
85
 
85
86
  CTabList.propTypes = {
86
87
  children: PropTypes.node,
87
88
  className: PropTypes.string,
88
89
  layout: PropTypes.oneOf(['fill', 'justified']),
89
- variant: PropTypes.oneOf(['pills', 'tabs', 'underline', 'underline-border']),
90
+ variant: PropTypes.oneOf([
91
+ 'enclosed',
92
+ 'enclosed-pills',
93
+ 'pills',
94
+ 'tabs',
95
+ 'underline',
96
+ 'underline-border',
97
+ ]),
90
98
  }
91
99
 
92
100
  CTabList.displayName = 'CTabList'
@@ -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
  })