@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,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>)
@@ -1,7 +1,8 @@
1
1
  import React from 'react' // useState,
2
2
  import { render, fireEvent } from '@testing-library/react'
3
3
  import '@testing-library/jest-dom'
4
- import { CToast, CToaster, CToastBody, CToastHeader, CButton } from '../../../index'
4
+ import { CButton } from '../../button'
5
+ import { CToast, CToaster, CToastBody, CToastHeader } from '../index'
5
6
 
6
7
  test('loads and displays CToaster component', async () => {
7
8
  const { container } = render(<CToaster>Test</CToaster>)
@@ -1,8 +1,9 @@
1
1
  import * as React from 'react'
2
- import { act } from 'react-dom/test-utils'
3
- import { fireEvent, render } from '@testing-library/react'
2
+ import { act, fireEvent, render, screen } from '@testing-library/react'
4
3
  import '@testing-library/jest-dom'
5
- import { CTooltip, CLink } from '../../../index'
4
+ import { CLink } from '../../link'
5
+ import { CTooltip } from '../index'
6
+ import { CButton } from '../../button'
6
7
 
7
8
  let container: HTMLDivElement | null
8
9
 
@@ -20,44 +21,64 @@ test('loads and displays CTooltip component', async () => {
20
21
  const { container } = render(
21
22
  <CTooltip content="content">
22
23
  <CLink>Test</CLink>
23
- </CTooltip>,
24
+ </CTooltip>
24
25
  )
25
26
  expect(container).toMatchSnapshot()
26
27
  })
27
28
 
28
29
  test('CTooltip customize', async () => {
29
- const { container } = render(
30
+ jest.useFakeTimers()
31
+
32
+ render(
30
33
  <CTooltip trigger="hover" placement="right" content="content">
31
- <CLink className="link">Test</CLink>
32
- </CTooltip>,
34
+ <CLink href="#">Test</CLink>
35
+ </CTooltip>
33
36
  )
34
- const link = document.querySelector('.link')
37
+
38
+ const link = screen.getByText('Test')
39
+
35
40
  act(() => {
36
- if (link !== null) {
37
- fireEvent.mouseOver(link)
38
- }
41
+ fireEvent.mouseOver(link)
42
+ jest.runAllTimers()
39
43
  })
40
- expect(container).toMatchSnapshot()
44
+
45
+ expect(document.querySelector('.tooltip')).toBeInTheDocument()
46
+
47
+ jest.useRealTimers()
41
48
  })
42
49
 
43
- // test('CTooltip on toggle', async () => {
44
- // jest.useFakeTimers()
45
- // const onToggle = jest.fn()
46
- // render(
47
- // <CTooltip
48
- // trigger="click"
49
- // placement="right-end"
50
- // content="content"
51
- // visible={true}
52
- // onToggle={onToggle}
53
- // >
54
- // <CButton>Test</CButton>
55
- // </CTooltip>,
56
- // )
57
- // expect(onToggle).toHaveBeenCalledTimes(0)
58
- // const btn = document.querySelector('.btn')
59
- // if (btn !== null) {
60
- // fireEvent.click(btn)
61
- // }
62
- // expect(onToggle).toHaveBeenCalledTimes(1)
63
- // })
50
+ test('CTooltip onShow and onHide', async () => {
51
+ jest.useFakeTimers()
52
+
53
+ const onShow = jest.fn()
54
+ const onHide = jest.fn()
55
+
56
+ render(
57
+ <CTooltip trigger="click" placement="right" content="content" onShow={onShow} onHide={onHide}>
58
+ <CButton>Test</CButton>
59
+ </CTooltip>
60
+ )
61
+
62
+ const btn = screen.getByRole('button', { name: /test/i })
63
+
64
+ expect(onShow).toHaveBeenCalledTimes(0)
65
+ expect(onHide).toHaveBeenCalledTimes(0)
66
+
67
+ act(() => {
68
+ fireEvent.click(btn)
69
+ jest.runAllTimers()
70
+ })
71
+
72
+ expect(onShow).toHaveBeenCalledTimes(1)
73
+ expect(onHide).toHaveBeenCalledTimes(0)
74
+
75
+ act(() => {
76
+ fireEvent.click(btn)
77
+ jest.runAllTimers()
78
+ })
79
+
80
+ expect(onShow).toHaveBeenCalledTimes(1)
81
+ expect(onHide).toHaveBeenCalledTimes(1)
82
+
83
+ jest.useRealTimers()
84
+ })
@@ -1,15 +1,5 @@
1
1
  // Jest Snapshot v1, https://goo.gl/fbAQLP
2
2
 
3
- exports[`CTooltip customize 1`] = `
4
- <div>
5
- <a
6
- class="link"
7
- >
8
- Test
9
- </a>
10
- </div>
11
- `;
12
-
13
3
  exports[`loads and displays CTooltip component 1`] = `
14
4
  <div>
15
5
  <a
@@ -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 { CWidgetStatsA } from '../../../index'
4
+ import { CWidgetStatsA } from '../index'
5
5
 
6
6
  test('loads and displays CWidgetStatsA component', async () => {
7
7
  const { container } = render(<CWidgetStatsA />)
@@ -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 { CWidgetStatsB } from '../../../index'
4
+ import { CWidgetStatsB } from '../index'
5
5
 
6
6
  test('loads and displays CWidgetStatsB component', async () => {
7
7
  const { container } = render(<CWidgetStatsB />)
@@ -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 { CWidgetStatsC } from '../../../index'
4
+ import { CWidgetStatsC } from '../index'
5
5
 
6
6
  test('loads and displays CWidgetStatsC component', async () => {
7
7
  const { container } = render(<CWidgetStatsC />)
@@ -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 { CWidgetStatsD } from '../../../index'
4
+ import { CWidgetStatsD } from '../index'
5
5
 
6
6
  test('loads and displays CWidgetStatsD component', async () => {
7
7
  const { container } = render(<CWidgetStatsD />)
@@ -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 { CWidgetStatsE } from '../../../index'
4
+ import { CWidgetStatsE } from '../index'
5
5
 
6
6
  test('loads and displays CWidgetStatsE component', async () => {
7
7
  const { container } = render(<CWidgetStatsE />)
@@ -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 { CWidgetStatsF } from '../../../index'
4
+ import { CWidgetStatsF } from '../index'
5
5
 
6
6
  test('loads and displays CWidgetStatsF component', async () => {
7
7
  const { container } = render(<CWidgetStatsF />)
@@ -10,8 +10,8 @@ interface UsePopperOutput {
10
10
  }
11
11
 
12
12
  export const usePopper = (): UsePopperOutput => {
13
- const _popper = useRef<Instance>()
14
- const el = useRef<HTMLElement>()
13
+ const _popper = useRef<Instance>(undefined)
14
+ const el = useRef<HTMLElement>(null)
15
15
 
16
16
  const initPopper = (reference: HTMLElement, popper: HTMLElement, options: Partial<Options>) => {
17
17
  _popper.current = createPopper(reference, popper, options)
@@ -1,23 +0,0 @@
1
- import * as React from 'react'
2
- import { render } from '@testing-library/react'
3
- import '@testing-library/jest-dom'
4
- import { CCloseButton } from '../../../index'
5
-
6
- test('loads and displays CCloseButton component', async () => {
7
- const { container } = render(<CCloseButton>Test</CCloseButton>)
8
- expect(container).toMatchSnapshot()
9
- })
10
-
11
- test('CCloseButton customize', async () => {
12
- const { container } = render(
13
- <CCloseButton white={true} disabled={true} className="bazinga">
14
- Test
15
- </CCloseButton>,
16
- )
17
- expect(container).toMatchSnapshot()
18
- expect(container.firstChild).toHaveClass('bazinga')
19
- expect(container.firstChild).toHaveClass('btn')
20
- expect(container.firstChild).toHaveClass('btn-close')
21
- expect(container.firstChild).toHaveClass('btn-close-white')
22
- expect(container.firstChild).toHaveAttribute('disabled')
23
- })
@@ -1,26 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`CCloseButton customize 1`] = `
4
- <div>
5
- <button
6
- aria-label="Close"
7
- class="btn btn-close btn-close-white bazinga"
8
- disabled=""
9
- type="button"
10
- >
11
- Test
12
- </button>
13
- </div>
14
- `;
15
-
16
- exports[`loads and displays CCloseButton component 1`] = `
17
- <div>
18
- <button
19
- aria-label="Close"
20
- class="btn btn-close"
21
- type="button"
22
- >
23
- Test
24
- </button>
25
- </div>
26
- `;