@coreui/react 5.5.0 → 5.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/cjs/components/accordion/CAccordion.d.ts +0 -6
- package/dist/cjs/components/accordion/CAccordion.js +4 -5
- package/dist/cjs/components/accordion/CAccordion.js.map +1 -1
- package/dist/cjs/components/accordion/CAccordionBody.js +2 -2
- package/dist/cjs/components/accordion/CAccordionBody.js.map +1 -1
- package/dist/cjs/components/accordion/CAccordionButton.js +2 -2
- package/dist/cjs/components/accordion/CAccordionButton.js.map +1 -1
- package/dist/cjs/components/accordion/CAccordionContext.d.ts +6 -0
- package/dist/cjs/components/accordion/CAccordionContext.js +8 -0
- package/dist/cjs/components/accordion/CAccordionContext.js.map +1 -0
- package/dist/cjs/components/accordion/CAccordionItem.d.ts +0 -6
- package/dist/cjs/components/accordion/CAccordionItem.js +7 -7
- package/dist/cjs/components/accordion/CAccordionItem.js.map +1 -1
- package/dist/cjs/components/accordion/CAccordionItemContext.d.ts +6 -0
- package/dist/cjs/components/accordion/CAccordionItemContext.js +8 -0
- package/dist/cjs/components/accordion/CAccordionItemContext.js.map +1 -0
- package/dist/cjs/components/alert/CAlert.js +1 -1
- package/dist/cjs/components/alert/CAlert.js.map +1 -1
- package/dist/cjs/components/alert/CAlertHeading.js +1 -1
- package/dist/cjs/components/alert/CAlertHeading.js.map +1 -1
- package/dist/cjs/components/backdrop/CBackdrop.js +1 -1
- package/dist/cjs/components/backdrop/CBackdrop.js.map +1 -1
- package/dist/cjs/components/badge/CBadge.js +5 -5
- package/dist/cjs/components/badge/CBadge.js.map +1 -1
- package/dist/cjs/components/button/CButton.js +1 -1
- package/dist/cjs/components/button/CButton.js.map +1 -1
- package/dist/cjs/components/card/CCardHeader.js +1 -1
- package/dist/cjs/components/card/CCardHeader.js.map +1 -1
- package/dist/cjs/components/card/CCardImage.js +1 -1
- package/dist/cjs/components/card/CCardImage.js.map +1 -1
- package/dist/cjs/components/card/CCardSubtitle.js +1 -1
- package/dist/cjs/components/card/CCardSubtitle.js.map +1 -1
- package/dist/cjs/components/card/CCardText.js +1 -1
- package/dist/cjs/components/card/CCardText.js.map +1 -1
- package/dist/cjs/components/card/CCardTitle.js +1 -1
- package/dist/cjs/components/card/CCardTitle.js.map +1 -1
- package/dist/cjs/components/carousel/CCarousel.d.ts +0 -5
- package/dist/cjs/components/carousel/CCarousel.js +3 -4
- package/dist/cjs/components/carousel/CCarousel.js.map +1 -1
- package/dist/cjs/components/carousel/CCarouselContext.d.ts +5 -0
- package/dist/cjs/components/carousel/CCarouselContext.js +8 -0
- package/dist/cjs/components/carousel/CCarouselContext.js.map +1 -0
- package/dist/cjs/components/carousel/CCarouselItem.js +9 -9
- package/dist/cjs/components/carousel/CCarouselItem.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdown.d.ts +1 -9
- package/dist/cjs/components/dropdown/CDropdown.js +27 -19
- package/dist/cjs/components/dropdown/CDropdown.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdownContext.d.ts +15 -0
- package/dist/cjs/components/dropdown/CDropdownContext.js +8 -0
- package/dist/cjs/components/dropdown/CDropdownContext.js.map +1 -0
- package/dist/cjs/components/dropdown/CDropdownHeader.js +1 -1
- package/dist/cjs/components/dropdown/CDropdownHeader.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdownItem.js +1 -1
- package/dist/cjs/components/dropdown/CDropdownItem.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdownItemPlain.js +1 -1
- package/dist/cjs/components/dropdown/CDropdownItemPlain.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdownMenu.js +4 -4
- package/dist/cjs/components/dropdown/CDropdownMenu.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdownToggle.js +3 -3
- package/dist/cjs/components/dropdown/CDropdownToggle.js.map +1 -1
- package/dist/cjs/components/form/CFormCheck.js +1 -1
- package/dist/cjs/components/form/CFormCheck.js.map +1 -1
- package/dist/cjs/components/form/CFormFeedback.js +1 -1
- package/dist/cjs/components/form/CFormFeedback.js.map +1 -1
- package/dist/cjs/components/form/CFormInput.js +1 -1
- package/dist/cjs/components/form/CFormInput.js.map +1 -1
- package/dist/cjs/components/form/CFormLabel.js +1 -1
- package/dist/cjs/components/form/CFormLabel.js.map +1 -1
- package/dist/cjs/components/form/CFormSwitch.js +1 -1
- package/dist/cjs/components/form/CFormSwitch.js.map +1 -1
- package/dist/cjs/components/form/CFormText.js +1 -1
- package/dist/cjs/components/form/CFormText.js.map +1 -1
- package/dist/cjs/components/form/CInputGroupText.js +1 -1
- package/dist/cjs/components/form/CInputGroupText.js.map +1 -1
- package/dist/cjs/components/header/CHeaderBrand.js +1 -1
- package/dist/cjs/components/header/CHeaderBrand.js.map +1 -1
- package/dist/cjs/components/header/CHeaderNav.js +1 -1
- package/dist/cjs/components/header/CHeaderNav.js.map +1 -1
- package/dist/cjs/components/header/CHeaderToggler.js +1 -1
- package/dist/cjs/components/header/CHeaderToggler.js.map +1 -1
- package/dist/cjs/components/link/CLink.js +1 -1
- package/dist/cjs/components/link/CLink.js.map +1 -1
- package/dist/cjs/components/list-group/CListGroup.js +1 -1
- package/dist/cjs/components/list-group/CListGroup.js.map +1 -1
- package/dist/cjs/components/list-group/CListGroupItem.js +1 -1
- package/dist/cjs/components/list-group/CListGroupItem.js.map +1 -1
- package/dist/cjs/components/modal/CModal.d.ts +0 -6
- package/dist/cjs/components/modal/CModal.js +5 -6
- package/dist/cjs/components/modal/CModal.js.map +1 -1
- package/dist/cjs/components/modal/CModalContext.d.ts +5 -0
- package/dist/cjs/components/modal/CModalContext.js +8 -0
- package/dist/cjs/components/modal/CModalContext.js.map +1 -0
- package/dist/cjs/components/modal/CModalHeader.js +3 -3
- package/dist/cjs/components/modal/CModalHeader.js.map +1 -1
- package/dist/cjs/components/modal/CModalTitle.js +1 -1
- package/dist/cjs/components/modal/CModalTitle.js.map +1 -1
- package/dist/cjs/components/nav/CNav.js +1 -1
- package/dist/cjs/components/nav/CNav.js.map +1 -1
- package/dist/cjs/components/nav/CNavGroup.js +5 -5
- package/dist/cjs/components/nav/CNavGroup.js.map +1 -1
- package/dist/cjs/components/nav/CNavGroupItems.js +1 -1
- package/dist/cjs/components/nav/CNavGroupItems.js.map +1 -1
- package/dist/cjs/components/nav/CNavItem.js +1 -1
- package/dist/cjs/components/nav/CNavItem.js.map +1 -1
- package/dist/cjs/components/nav/CNavLink.js +3 -3
- package/dist/cjs/components/nav/CNavLink.js.map +1 -1
- package/dist/cjs/components/nav/CNavTitle.js +1 -1
- package/dist/cjs/components/nav/CNavTitle.js.map +1 -1
- package/dist/cjs/components/navbar/CNavbar.js +1 -1
- package/dist/cjs/components/navbar/CNavbar.js.map +1 -1
- package/dist/cjs/components/navbar/CNavbarBrand.js +1 -1
- package/dist/cjs/components/navbar/CNavbarBrand.js.map +1 -1
- package/dist/cjs/components/navbar/CNavbarNav.js +1 -1
- package/dist/cjs/components/navbar/CNavbarNav.js.map +1 -1
- package/dist/cjs/components/navbar/CNavbarToggler.js +1 -1
- package/dist/cjs/components/navbar/CNavbarToggler.js.map +1 -1
- package/dist/cjs/components/offcanvas/COffcanvas.js +2 -2
- package/dist/cjs/components/offcanvas/COffcanvas.js.map +1 -1
- package/dist/cjs/components/offcanvas/COffcanvasTitle.js +1 -1
- package/dist/cjs/components/offcanvas/COffcanvasTitle.js.map +1 -1
- package/dist/cjs/components/pagination/CPaginationItem.js +1 -1
- package/dist/cjs/components/pagination/CPaginationItem.js.map +1 -1
- package/dist/cjs/components/placeholder/CPlaceholder.js +1 -1
- package/dist/cjs/components/placeholder/CPlaceholder.js.map +1 -1
- package/dist/cjs/components/popover/CPopover.js +1 -1
- package/dist/cjs/components/popover/CPopover.js.map +1 -1
- package/dist/cjs/components/progress/CProgress.js +2 -2
- package/dist/cjs/components/progress/CProgress.js.map +1 -1
- package/dist/cjs/components/progress/CProgressBar.js +3 -3
- package/dist/cjs/components/progress/CProgressBar.js.map +1 -1
- package/dist/cjs/components/progress/CProgressStacked.d.ts +0 -4
- package/dist/cjs/components/progress/CProgressStacked.js +2 -3
- package/dist/cjs/components/progress/CProgressStacked.js.map +1 -1
- package/dist/cjs/components/progress/CProgressStackedContext.d.ts +4 -0
- package/dist/cjs/components/progress/CProgressStackedContext.js +8 -0
- package/dist/cjs/components/progress/CProgressStackedContext.js.map +1 -0
- package/dist/cjs/components/sidebar/CSidebar.js +5 -5
- package/dist/cjs/components/sidebar/CSidebar.js.map +1 -1
- package/dist/cjs/components/sidebar/CSidebarBrand.js +1 -1
- package/dist/cjs/components/sidebar/CSidebarBrand.js.map +1 -1
- package/dist/cjs/components/sidebar/CSidebarNav.d.ts +1 -7
- package/dist/cjs/components/sidebar/CSidebarNav.js +16 -15
- package/dist/cjs/components/sidebar/CSidebarNav.js.map +1 -1
- package/dist/cjs/components/sidebar/CSidebarNavContext.d.ts +5 -0
- package/dist/cjs/components/sidebar/CSidebarNavContext.js +8 -0
- package/dist/cjs/components/sidebar/CSidebarNavContext.js.map +1 -0
- package/dist/cjs/components/spinner/CSpinner.js +1 -1
- package/dist/cjs/components/spinner/CSpinner.js.map +1 -1
- package/dist/cjs/components/table/utils.js +1 -1
- package/dist/cjs/components/table/utils.js.map +1 -1
- package/dist/cjs/components/tabs/CTab.js +2 -2
- package/dist/cjs/components/tabs/CTab.js.map +1 -1
- package/dist/cjs/components/tabs/CTabList.js +1 -1
- package/dist/cjs/components/tabs/CTabList.js.map +1 -1
- package/dist/cjs/components/tabs/CTabPane.js +2 -2
- package/dist/cjs/components/tabs/CTabPane.js.map +1 -1
- package/dist/cjs/components/tabs/CTabPanel.js +4 -4
- package/dist/cjs/components/tabs/CTabPanel.js.map +1 -1
- package/dist/cjs/components/tabs/CTabs.d.ts +29 -9
- package/dist/cjs/components/tabs/CTabs.js +14 -9
- package/dist/cjs/components/tabs/CTabs.js.map +1 -1
- package/dist/cjs/components/tabs/CTabsContext.d.ts +6 -0
- package/dist/cjs/components/tabs/CTabsContext.js +8 -0
- package/dist/cjs/components/tabs/CTabsContext.js.map +1 -0
- package/dist/cjs/components/toast/CToast.d.ts +0 -6
- package/dist/cjs/components/toast/CToast.js +7 -11
- package/dist/cjs/components/toast/CToast.js.map +1 -1
- package/dist/cjs/components/toast/CToastClose.js +2 -2
- package/dist/cjs/components/toast/CToastClose.js.map +1 -1
- package/dist/cjs/components/toast/CToastContext.d.ts +5 -0
- package/dist/cjs/components/toast/CToastContext.js +8 -0
- package/dist/cjs/components/toast/CToastContext.js.map +1 -0
- package/dist/cjs/components/toast/CToaster.d.ts +2 -1
- package/dist/cjs/components/toast/CToaster.js +4 -2
- package/dist/cjs/components/toast/CToaster.js.map +1 -1
- package/dist/cjs/components/tooltip/CTooltip.js +1 -1
- package/dist/cjs/components/tooltip/CTooltip.js.map +1 -1
- package/dist/cjs/components/widgets/CWidgetStatsF.js +1 -1
- package/dist/cjs/components/widgets/CWidgetStatsF.js.map +1 -1
- package/dist/cjs/hooks/useClipboard.js +2 -2
- package/dist/cjs/hooks/useClipboard.js.map +1 -1
- package/dist/cjs/hooks/useColorModes.js +1 -1
- package/dist/cjs/hooks/useColorModes.js.map +1 -1
- package/dist/cjs/hooks/usePopper.js +2 -2
- package/dist/cjs/hooks/usePopper.js.map +1 -1
- package/dist/cjs/node_modules/react-transition-group/esm/Transition.js +2 -2
- package/dist/cjs/node_modules/react-transition-group/esm/Transition.js.map +1 -1
- package/dist/cjs/node_modules/tslib/tslib.es6.js +1 -1
- package/dist/cjs/node_modules/tslib/tslib.es6.js.map +1 -1
- package/dist/cjs/utils/executeAfterTransition.js +1 -1
- package/dist/cjs/utils/executeAfterTransition.js.map +1 -1
- package/dist/esm/components/accordion/CAccordion.d.ts +0 -6
- package/dist/esm/components/accordion/CAccordion.js +5 -5
- package/dist/esm/components/accordion/CAccordion.js.map +1 -1
- package/dist/esm/components/accordion/CAccordionBody.js +1 -1
- package/dist/esm/components/accordion/CAccordionBody.js.map +1 -1
- package/dist/esm/components/accordion/CAccordionButton.js +1 -1
- package/dist/esm/components/accordion/CAccordionContext.d.ts +6 -0
- package/dist/esm/components/accordion/CAccordionContext.js +6 -0
- package/dist/esm/components/accordion/CAccordionContext.js.map +1 -0
- package/dist/esm/components/accordion/CAccordionItem.d.ts +0 -6
- package/dist/esm/components/accordion/CAccordionItem.js +7 -6
- package/dist/esm/components/accordion/CAccordionItem.js.map +1 -1
- package/dist/esm/components/accordion/CAccordionItemContext.d.ts +6 -0
- package/dist/esm/components/accordion/CAccordionItemContext.js +6 -0
- package/dist/esm/components/accordion/CAccordionItemContext.js.map +1 -0
- package/dist/esm/components/alert/CAlert.js +1 -1
- package/dist/esm/components/alert/CAlert.js.map +1 -1
- package/dist/esm/components/alert/CAlertHeading.js +1 -1
- package/dist/esm/components/alert/CAlertHeading.js.map +1 -1
- package/dist/esm/components/backdrop/CBackdrop.js +1 -1
- package/dist/esm/components/backdrop/CBackdrop.js.map +1 -1
- package/dist/esm/components/badge/CBadge.js +5 -5
- package/dist/esm/components/badge/CBadge.js.map +1 -1
- package/dist/esm/components/button/CButton.js +1 -1
- package/dist/esm/components/button/CButton.js.map +1 -1
- package/dist/esm/components/card/CCardHeader.js +1 -1
- package/dist/esm/components/card/CCardHeader.js.map +1 -1
- package/dist/esm/components/card/CCardImage.js +1 -1
- package/dist/esm/components/card/CCardImage.js.map +1 -1
- package/dist/esm/components/card/CCardSubtitle.js +1 -1
- package/dist/esm/components/card/CCardSubtitle.js.map +1 -1
- package/dist/esm/components/card/CCardText.js +1 -1
- package/dist/esm/components/card/CCardText.js.map +1 -1
- package/dist/esm/components/card/CCardTitle.js +1 -1
- package/dist/esm/components/card/CCardTitle.js.map +1 -1
- package/dist/esm/components/carousel/CCarousel.d.ts +0 -5
- package/dist/esm/components/carousel/CCarousel.js +4 -4
- package/dist/esm/components/carousel/CCarousel.js.map +1 -1
- package/dist/esm/components/carousel/CCarouselContext.d.ts +5 -0
- package/dist/esm/components/carousel/CCarouselContext.js +6 -0
- package/dist/esm/components/carousel/CCarouselContext.js.map +1 -0
- package/dist/esm/components/carousel/CCarouselItem.js +8 -8
- package/dist/esm/components/carousel/CCarouselItem.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdown.d.ts +1 -9
- package/dist/esm/components/dropdown/CDropdown.js +28 -19
- package/dist/esm/components/dropdown/CDropdown.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdownContext.d.ts +15 -0
- package/dist/esm/components/dropdown/CDropdownContext.js +6 -0
- package/dist/esm/components/dropdown/CDropdownContext.js.map +1 -0
- package/dist/esm/components/dropdown/CDropdownHeader.js +1 -1
- package/dist/esm/components/dropdown/CDropdownHeader.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdownItem.js +1 -1
- package/dist/esm/components/dropdown/CDropdownItem.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdownItemPlain.js +1 -1
- package/dist/esm/components/dropdown/CDropdownItemPlain.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdownMenu.js +3 -3
- package/dist/esm/components/dropdown/CDropdownMenu.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdownToggle.js +2 -2
- package/dist/esm/components/dropdown/CDropdownToggle.js.map +1 -1
- package/dist/esm/components/form/CFormCheck.js +1 -1
- package/dist/esm/components/form/CFormCheck.js.map +1 -1
- package/dist/esm/components/form/CFormFeedback.js +1 -1
- package/dist/esm/components/form/CFormFeedback.js.map +1 -1
- package/dist/esm/components/form/CFormInput.js +1 -1
- package/dist/esm/components/form/CFormInput.js.map +1 -1
- package/dist/esm/components/form/CFormLabel.js +1 -1
- package/dist/esm/components/form/CFormLabel.js.map +1 -1
- package/dist/esm/components/form/CFormSwitch.js +1 -1
- package/dist/esm/components/form/CFormSwitch.js.map +1 -1
- package/dist/esm/components/form/CFormText.js +1 -1
- package/dist/esm/components/form/CFormText.js.map +1 -1
- package/dist/esm/components/form/CInputGroupText.js +1 -1
- package/dist/esm/components/form/CInputGroupText.js.map +1 -1
- package/dist/esm/components/header/CHeaderBrand.js +1 -1
- package/dist/esm/components/header/CHeaderBrand.js.map +1 -1
- package/dist/esm/components/header/CHeaderNav.js +1 -1
- package/dist/esm/components/header/CHeaderNav.js.map +1 -1
- package/dist/esm/components/header/CHeaderToggler.js +1 -1
- package/dist/esm/components/header/CHeaderToggler.js.map +1 -1
- package/dist/esm/components/link/CLink.js +1 -1
- package/dist/esm/components/link/CLink.js.map +1 -1
- package/dist/esm/components/list-group/CListGroup.js +1 -1
- package/dist/esm/components/list-group/CListGroup.js.map +1 -1
- package/dist/esm/components/list-group/CListGroupItem.js +1 -1
- package/dist/esm/components/list-group/CListGroupItem.js.map +1 -1
- package/dist/esm/components/modal/CModal.d.ts +0 -6
- package/dist/esm/components/modal/CModal.js +6 -6
- package/dist/esm/components/modal/CModal.js.map +1 -1
- package/dist/esm/components/modal/CModalContext.d.ts +5 -0
- package/dist/esm/components/modal/CModalContext.js +6 -0
- package/dist/esm/components/modal/CModalContext.js.map +1 -0
- package/dist/esm/components/modal/CModalHeader.js +2 -2
- package/dist/esm/components/modal/CModalHeader.js.map +1 -1
- package/dist/esm/components/modal/CModalTitle.js +1 -1
- package/dist/esm/components/modal/CModalTitle.js.map +1 -1
- package/dist/esm/components/nav/CNav.js +1 -1
- package/dist/esm/components/nav/CNav.js.map +1 -1
- package/dist/esm/components/nav/CNavGroup.js +5 -5
- package/dist/esm/components/nav/CNavGroup.js.map +1 -1
- package/dist/esm/components/nav/CNavGroupItems.js +1 -1
- package/dist/esm/components/nav/CNavGroupItems.js.map +1 -1
- package/dist/esm/components/nav/CNavItem.js +1 -1
- package/dist/esm/components/nav/CNavItem.js.map +1 -1
- package/dist/esm/components/nav/CNavLink.js +3 -3
- package/dist/esm/components/nav/CNavLink.js.map +1 -1
- package/dist/esm/components/nav/CNavTitle.js +1 -1
- package/dist/esm/components/nav/CNavTitle.js.map +1 -1
- package/dist/esm/components/navbar/CNavbar.js +1 -1
- package/dist/esm/components/navbar/CNavbar.js.map +1 -1
- package/dist/esm/components/navbar/CNavbarBrand.js +1 -1
- package/dist/esm/components/navbar/CNavbarBrand.js.map +1 -1
- package/dist/esm/components/navbar/CNavbarNav.js +1 -1
- package/dist/esm/components/navbar/CNavbarNav.js.map +1 -1
- package/dist/esm/components/navbar/CNavbarToggler.js +1 -1
- package/dist/esm/components/navbar/CNavbarToggler.js.map +1 -1
- package/dist/esm/components/offcanvas/COffcanvas.js +2 -2
- package/dist/esm/components/offcanvas/COffcanvas.js.map +1 -1
- package/dist/esm/components/offcanvas/COffcanvasTitle.js +1 -1
- package/dist/esm/components/offcanvas/COffcanvasTitle.js.map +1 -1
- package/dist/esm/components/pagination/CPaginationItem.js +1 -1
- package/dist/esm/components/pagination/CPaginationItem.js.map +1 -1
- package/dist/esm/components/placeholder/CPlaceholder.js +1 -1
- package/dist/esm/components/placeholder/CPlaceholder.js.map +1 -1
- package/dist/esm/components/popover/CPopover.js +1 -1
- package/dist/esm/components/popover/CPopover.js.map +1 -1
- package/dist/esm/components/progress/CProgress.js +1 -1
- package/dist/esm/components/progress/CProgressBar.js +2 -2
- package/dist/esm/components/progress/CProgressBar.js.map +1 -1
- package/dist/esm/components/progress/CProgressStacked.d.ts +0 -4
- package/dist/esm/components/progress/CProgressStacked.js +3 -3
- package/dist/esm/components/progress/CProgressStacked.js.map +1 -1
- package/dist/esm/components/progress/CProgressStackedContext.d.ts +4 -0
- package/dist/esm/components/progress/CProgressStackedContext.js +6 -0
- package/dist/esm/components/progress/CProgressStackedContext.js.map +1 -0
- package/dist/esm/components/sidebar/CSidebar.js +5 -5
- package/dist/esm/components/sidebar/CSidebar.js.map +1 -1
- package/dist/esm/components/sidebar/CSidebarBrand.js +1 -1
- package/dist/esm/components/sidebar/CSidebarBrand.js.map +1 -1
- package/dist/esm/components/sidebar/CSidebarNav.d.ts +1 -7
- package/dist/esm/components/sidebar/CSidebarNav.js +18 -16
- package/dist/esm/components/sidebar/CSidebarNav.js.map +1 -1
- package/dist/esm/components/sidebar/CSidebarNavContext.d.ts +5 -0
- package/dist/esm/components/sidebar/CSidebarNavContext.js +6 -0
- package/dist/esm/components/sidebar/CSidebarNavContext.js.map +1 -0
- package/dist/esm/components/spinner/CSpinner.js +1 -1
- package/dist/esm/components/spinner/CSpinner.js.map +1 -1
- package/dist/esm/components/table/utils.js +1 -1
- package/dist/esm/components/table/utils.js.map +1 -1
- package/dist/esm/components/tabs/CTab.js +2 -2
- package/dist/esm/components/tabs/CTab.js.map +1 -1
- package/dist/esm/components/tabs/CTabList.js +1 -1
- package/dist/esm/components/tabs/CTabList.js.map +1 -1
- package/dist/esm/components/tabs/CTabPane.js +2 -2
- package/dist/esm/components/tabs/CTabPane.js.map +1 -1
- package/dist/esm/components/tabs/CTabPanel.js +4 -4
- package/dist/esm/components/tabs/CTabPanel.js.map +1 -1
- package/dist/esm/components/tabs/CTabs.d.ts +29 -9
- package/dist/esm/components/tabs/CTabs.js +16 -10
- package/dist/esm/components/tabs/CTabs.js.map +1 -1
- package/dist/esm/components/tabs/CTabsContext.d.ts +6 -0
- package/dist/esm/components/tabs/CTabsContext.js +6 -0
- package/dist/esm/components/tabs/CTabsContext.js.map +1 -0
- package/dist/esm/components/toast/CToast.d.ts +0 -6
- package/dist/esm/components/toast/CToast.js +8 -11
- package/dist/esm/components/toast/CToast.js.map +1 -1
- package/dist/esm/components/toast/CToastClose.js +1 -1
- package/dist/esm/components/toast/CToastClose.js.map +1 -1
- package/dist/esm/components/toast/CToastContext.d.ts +5 -0
- package/dist/esm/components/toast/CToastContext.js +6 -0
- package/dist/esm/components/toast/CToastContext.js.map +1 -0
- package/dist/esm/components/toast/CToaster.d.ts +2 -1
- package/dist/esm/components/toast/CToaster.js +4 -2
- package/dist/esm/components/toast/CToaster.js.map +1 -1
- package/dist/esm/components/tooltip/CTooltip.js +1 -1
- package/dist/esm/components/tooltip/CTooltip.js.map +1 -1
- package/dist/esm/components/widgets/CWidgetStatsF.js +1 -1
- package/dist/esm/components/widgets/CWidgetStatsF.js.map +1 -1
- package/dist/esm/hooks/useClipboard.js +2 -2
- package/dist/esm/hooks/useClipboard.js.map +1 -1
- package/dist/esm/hooks/useColorModes.js +1 -1
- package/dist/esm/hooks/useColorModes.js.map +1 -1
- package/dist/esm/hooks/usePopper.js +2 -2
- package/dist/esm/hooks/usePopper.js.map +1 -1
- package/dist/esm/node_modules/react-transition-group/esm/Transition.js +2 -2
- package/dist/esm/node_modules/react-transition-group/esm/Transition.js.map +1 -1
- package/dist/esm/node_modules/tslib/tslib.es6.js +1 -1
- package/dist/esm/node_modules/tslib/tslib.es6.js.map +1 -1
- package/dist/esm/utils/executeAfterTransition.js +1 -1
- package/dist/esm/utils/executeAfterTransition.js.map +1 -1
- package/package.json +11 -11
- package/src/components/accordion/CAccordion.tsx +4 -10
- package/src/components/accordion/CAccordionBody.tsx +1 -2
- package/src/components/accordion/CAccordionButton.tsx +2 -2
- package/src/components/accordion/CAccordionContext.ts +9 -0
- package/src/components/accordion/CAccordionItem.tsx +4 -11
- package/src/components/accordion/CAccordionItemContext.ts +9 -0
- package/src/components/accordion/__tests__/CAccordion.spec.tsx +1 -1
- package/src/components/accordion/__tests__/CAccordionBody.spec.tsx +1 -1
- package/src/components/accordion/__tests__/CAccordionButton.spec.tsx +1 -1
- package/src/components/accordion/__tests__/CAccordionHeader.spec.tsx +1 -1
- package/src/components/accordion/__tests__/CAccordionItem.spec.tsx +1 -1
- package/src/components/alert/__tests__/CAlert.spec.tsx +39 -18
- package/src/components/alert/__tests__/CAlertHeading.spec.tsx +1 -1
- package/src/components/alert/__tests__/CAlertLink.spec.tsx +1 -1
- package/src/components/avatar/__tests__/CAvatar.spec.tsx +1 -1
- package/src/components/backdrop/__tests__/CBackdrop.spec.tsx +1 -1
- package/src/components/badge/__tests__/CBadge.spec.tsx +1 -1
- package/src/components/breadcrumb/__tests__/CBreadcrumb.spec.tsx +1 -1
- package/src/components/breadcrumb/__tests__/CBreadcrumbItem.spec.tsx +1 -1
- package/src/components/button/__tests__/CButton.spec.tsx +1 -1
- package/src/components/button-group/__tests__/CButtonGroup.spec.tsx +2 -1
- package/src/components/button-group/__tests__/CButtonToolbar.spec.tsx +2 -1
- package/src/components/callout/__tests__/CCallout.spec.tsx +1 -1
- package/src/components/card/__tests__/CCard.spec.tsx +1 -1
- package/src/components/card/__tests__/CCardBody.spec.tsx +1 -1
- package/src/components/card/__tests__/CCardFooter.spec.tsx +1 -1
- package/src/components/card/__tests__/CCardGroup.spec.tsx +1 -1
- package/src/components/card/__tests__/CCardHeader.spec.tsx +1 -1
- package/src/components/card/__tests__/CCardImage.spec.tsx +1 -1
- package/src/components/card/__tests__/CCardImageOverlay.spec.tsx +1 -1
- package/src/components/card/__tests__/CCardLink.spec.tsx +1 -1
- package/src/components/card/__tests__/CCardSubtitle.spec.tsx +1 -1
- package/src/components/card/__tests__/CCardText.spec.tsx +1 -1
- package/src/components/card/__tests__/CCardTitle.spec.tsx +1 -1
- package/src/components/carousel/CCarousel.tsx +6 -12
- package/src/components/carousel/CCarouselCaption.tsx +1 -1
- package/src/components/carousel/CCarouselContext.ts +8 -0
- package/src/components/carousel/CCarouselItem.tsx +6 -4
- package/src/components/carousel/__tests__/CCarousel.spec.tsx +1 -1
- package/src/components/close-button/__tests__/CCloseButton.spec.tsx +1 -1
- package/src/components/collapse/__tests__/CCollapse.spec.tsx +26 -7
- package/src/components/dropdown/CDropdown.tsx +35 -36
- package/src/components/dropdown/CDropdownContext.ts +18 -0
- package/src/components/dropdown/CDropdownDivider.tsx +1 -1
- package/src/components/dropdown/CDropdownHeader.tsx +1 -1
- package/src/components/dropdown/CDropdownItemPlain.tsx +1 -1
- package/src/components/dropdown/CDropdownMenu.tsx +3 -3
- package/src/components/dropdown/CDropdownToggle.tsx +2 -3
- package/src/components/dropdown/__tests__/CDropdown.spec.tsx +1 -1
- package/src/components/dropdown/__tests__/CDropdownDivider.spec.tsx +1 -1
- package/src/components/dropdown/__tests__/CDropdownHeader.spec.tsx +1 -1
- package/src/components/dropdown/__tests__/CDropdownItem.spec.tsx +1 -1
- package/src/components/dropdown/__tests__/CDropdownItemPlain.spec.tsx +1 -1
- package/src/components/dropdown/__tests__/CDropdownMenu.spec.tsx +1 -1
- package/src/components/dropdown/__tests__/CDropdownToggle.spec.tsx +1 -1
- package/src/components/dropdown/__tests__/__snapshots__/CDropdown.spec.tsx.snap +0 -1
- package/src/components/dropdown/__tests__/__snapshots__/CDropdownMenu.spec.tsx.snap +0 -2
- package/src/components/footer/__tests__/CFooter.spec.tsx +1 -1
- package/src/components/form/__tests__/CForm.spec.tsx +2 -1
- package/src/components/form/__tests__/CFormCheck.spec.tsx +1 -1
- package/src/components/form/__tests__/CFormControl.spec.tsx +1 -1
- package/src/components/form/__tests__/CFormFeedback.spec.tsx +1 -1
- package/src/components/form/__tests__/CFormFloating.spec.tsx +1 -1
- package/src/components/form/__tests__/CFormInput.spec.tsx +1 -1
- package/src/components/form/__tests__/CFormLabel.spec.tsx +1 -1
- package/src/components/form/__tests__/CFormRange.spec.tsx +1 -1
- package/src/components/form/__tests__/CFormSelect.spec.tsx +1 -1
- package/src/components/form/__tests__/CFormSwitch.spec.tsx +1 -1
- package/src/components/form/__tests__/CFormText.spec.tsx +1 -1
- package/src/components/form/__tests__/CFormTextarea.spec.tsx +1 -1
- package/src/components/form/__tests__/CInputGroup.spec.tsx +1 -1
- package/src/components/form/__tests__/CInputGroupText.spec.tsx +1 -1
- package/src/components/grid/__tests__/CCol.spec.tsx +1 -1
- package/src/components/grid/__tests__/CContainer.spec.tsx +1 -1
- package/src/components/grid/__tests__/CRow.spec.tsx +1 -1
- package/src/components/header/__tests__/CHeader.spec.tsx +1 -1
- package/src/components/header/__tests__/CHeaderBrand.spec.tsx +1 -1
- package/src/components/header/__tests__/CHeaderDivider.spec.tsx +1 -1
- package/src/components/header/__tests__/CHeaderNav.spec.tsx +1 -1
- package/src/components/header/__tests__/CHeaderText.spec.tsx +1 -1
- package/src/components/header/__tests__/CHeaderToggler.spec.tsx +1 -1
- package/src/components/image/__tests__/CImage.spec.tsx +1 -1
- package/src/components/link/__tests__/CLink.spec.tsx +1 -1
- package/src/components/list-group/__tests__/CListGroup.spec.tsx +1 -1
- package/src/components/list-group/__tests__/CListGroupItem.spec.tsx +1 -1
- package/src/components/modal/CModal.tsx +5 -12
- package/src/components/modal/CModalContext.ts +8 -0
- package/src/components/modal/CModalHeader.tsx +1 -1
- package/src/components/modal/__tests__/CModal.spec.tsx +1 -1
- package/src/components/modal/__tests__/CModalBody.spec.tsx +1 -1
- package/src/components/modal/__tests__/CModalContent.spec.tsx +1 -1
- package/src/components/modal/__tests__/CModalDialog.spec.tsx +1 -1
- package/src/components/modal/__tests__/CModalFooter.spec.tsx +1 -1
- package/src/components/modal/__tests__/CModalHeader.spec.tsx +1 -1
- package/src/components/modal/__tests__/CModalTitle.spec.tsx +1 -1
- package/src/components/nav/CNavGroup.tsx +2 -2
- package/src/components/nav/CNavLink.tsx +2 -2
- package/src/components/nav/__tests__/CNav.spec.tsx +4 -11
- package/src/components/nav/__tests__/CNavGroup.spec.tsx +1 -1
- package/src/components/nav/__tests__/CNavGroupItems.spec.tsx +1 -1
- package/src/components/nav/__tests__/CNavItem.spec.tsx +1 -1
- package/src/components/nav/__tests__/CNavLink.spec.tsx +1 -1
- package/src/components/nav/__tests__/CNavTitle.spec.tsx +1 -1
- package/src/components/nav/__tests__/__snapshots__/CNav.spec.tsx.snap +0 -1
- package/src/components/navbar/__tests__/CNavbar.spec.tsx +1 -1
- package/src/components/navbar/__tests__/CNavbarBrand.spec.tsx +1 -1
- package/src/components/navbar/__tests__/CNavbarNav.spec.tsx +1 -1
- package/src/components/navbar/__tests__/CNavbarText.spec.tsx +1 -1
- package/src/components/navbar/__tests__/CNavbarToggler.spec.tsx +1 -1
- package/src/components/offcanvas/__tests__/COffcanvas.spec.tsx +45 -17
- package/src/components/offcanvas/__tests__/COffcanvasBody.spec.tsx +1 -1
- package/src/components/offcanvas/__tests__/COffcanvasHeader.spec.tsx +1 -1
- package/src/components/offcanvas/__tests__/COffcanvasTitle.spec.tsx +1 -1
- package/src/components/pagination/__tests__/CPagination.spec.tsx +1 -1
- package/src/components/pagination/__tests__/CPaginationItem.spec.tsx +1 -1
- package/src/components/placeholder/__tests__/CPlaceholder.spec.tsx +1 -1
- package/src/components/popover/__tests__/CPopover.spec.tsx +70 -62
- package/src/components/popover/__tests__/__snapshots__/CPopover.spec.tsx.snap +0 -32
- package/src/components/progress/CProgress.tsx +1 -1
- package/src/components/progress/CProgressBar.tsx +2 -1
- package/src/components/progress/CProgressStacked.tsx +4 -8
- package/src/components/progress/CProgressStackedContext.ts +7 -0
- package/src/components/progress/__tests__/CProgress.spec.tsx +1 -1
- package/src/components/progress/__tests__/CProgressBar.spec.tsx +1 -1
- package/src/components/sidebar/CSidebarNav.tsx +27 -27
- package/src/components/sidebar/CSidebarNavContext.ts +8 -0
- package/src/components/sidebar/__tests__/CSidebar.spec.tsx +1 -1
- package/src/components/sidebar/__tests__/CSidebarBrand.spec.tsx +1 -1
- package/src/components/sidebar/__tests__/CSidebarFooter.spec.tsx +1 -1
- package/src/components/sidebar/__tests__/CSidebarHeader.spec.tsx +1 -1
- package/src/components/sidebar/__tests__/CSidebarNav.spec.tsx +1 -1
- package/src/components/sidebar/__tests__/CSidebarToggler.spec.tsx +1 -1
- package/src/components/spinner/__tests__/CSpinner.spec.tsx +1 -1
- package/src/components/table/__tests__/CTable.spec.tsx +1 -1
- package/src/components/table/__tests__/CTableBody.spec.tsx +1 -1
- package/src/components/table/__tests__/CTableCaption.spec.tsx +1 -1
- package/src/components/table/__tests__/CTableDataCell.spec.tsx +1 -1
- package/src/components/table/__tests__/CTableFoot.spec.tsx +1 -1
- package/src/components/table/__tests__/CTableHead.spec.tsx +1 -1
- package/src/components/table/__tests__/CTableHeaderCell.spec.tsx +1 -1
- package/src/components/table/__tests__/CTableRow.spec.tsx +1 -1
- package/src/components/tabs/CTab.tsx +2 -2
- package/src/components/tabs/CTabPane.tsx +1 -1
- package/src/components/tabs/CTabPanel.tsx +3 -3
- package/src/components/tabs/CTabs.tsx +54 -21
- package/src/components/tabs/CTabsContext.ts +9 -0
- package/src/components/tabs/__tests__/CTabContent.spec.tsx +17 -8
- package/src/components/tabs/__tests__/CTabPane.spec.tsx +49 -29
- package/src/components/toast/CToast.tsx +9 -24
- package/src/components/toast/CToastClose.tsx +1 -2
- package/src/components/toast/CToastContext.ts +8 -0
- package/src/components/toast/CToaster.tsx +11 -7
- package/src/components/toast/__tests__/CToast.spec.tsx +32 -27
- package/src/components/toast/__tests__/CToastBody.spec.tsx +1 -1
- package/src/components/toast/__tests__/CToastHeader.spec.tsx +1 -1
- package/src/components/toast/__tests__/CToaster.spec.tsx +2 -1
- package/src/components/tooltip/__tests__/CTooltip.spec.tsx +54 -33
- package/src/components/tooltip/__tests__/__snapshots__/CTooltip.spec.tsx.snap +0 -10
- package/src/components/widgets/__tests__/CWidgetStatsA.spec.tsx +1 -1
- package/src/components/widgets/__tests__/CWidgetStatsB.spec.tsx +1 -1
- package/src/components/widgets/__tests__/CWidgetStatsC.spec.tsx +1 -1
- package/src/components/widgets/__tests__/CWidgetStatsD.spec.tsx +1 -1
- package/src/components/widgets/__tests__/CWidgetStatsE.spec.tsx +1 -1
- package/src/components/widgets/__tests__/CWidgetStatsF.spec.tsx +1 -1
- package/src/hooks/usePopper.ts +2 -2
- package/src/components/button/__tests__/CButtonClose.spec.tsx +0 -23
- package/src/components/button/__tests__/__snapshots__/CButtonClose.spec.tsx.snap +0 -26
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as React from 'react'
|
|
2
2
|
import { render } from '@testing-library/react'
|
|
3
3
|
import '@testing-library/jest-dom'
|
|
4
|
-
import { CTableBody, CTableDataCell, CTableRow } from '
|
|
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 '
|
|
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 '
|
|
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 '
|
|
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 '
|
|
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 '
|
|
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 '
|
|
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 {
|
|
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(
|
|
24
|
+
const { _activeItemKey, setActiveItemKey, id } = useContext(CTabsContext)
|
|
25
25
|
|
|
26
26
|
const isActive = () => itemKey === _activeItemKey
|
|
27
27
|
|
|
@@ -32,7 +32,7 @@ export interface CTabPaneProps extends HTMLAttributes<HTMLDivElement> {
|
|
|
32
32
|
|
|
33
33
|
export const CTabPane = forwardRef<HTMLDivElement, CTabPaneProps>(
|
|
34
34
|
({ children, className, onHide, onShow, transition = true, visible, ...rest }, ref) => {
|
|
35
|
-
const tabPaneRef = useRef()
|
|
35
|
+
const tabPaneRef = useRef(null)
|
|
36
36
|
const forkedRef = useForkedRef(ref, tabPaneRef)
|
|
37
37
|
|
|
38
38
|
return (
|
|
@@ -3,7 +3,7 @@ import PropTypes from 'prop-types'
|
|
|
3
3
|
import classNames from 'classnames'
|
|
4
4
|
import { Transition } from 'react-transition-group'
|
|
5
5
|
|
|
6
|
-
import {
|
|
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(
|
|
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, {
|
|
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
|
-
*
|
|
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
|
|
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
|
-
*
|
|
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
|
-
|
|
18
|
-
}
|
|
35
|
+
defaultActiveItemKey?: number | string
|
|
19
36
|
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
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
|
|
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
|
-
|
|
34
|
-
|
|
35
|
-
}, [_activeItemKey])
|
|
66
|
+
onChange?.(value)
|
|
67
|
+
}
|
|
36
68
|
|
|
37
69
|
return (
|
|
38
|
-
<
|
|
70
|
+
<CTabsContext.Provider value={{ _activeItemKey: currentActiveItemKey, setActiveItemKey, id }}>
|
|
39
71
|
<div className={classNames('tabs', className)} ref={ref}>
|
|
40
72
|
{children}
|
|
41
73
|
</div>
|
|
42
|
-
</
|
|
74
|
+
</CTabsContext.Provider>
|
|
43
75
|
)
|
|
44
|
-
}
|
|
76
|
+
}
|
|
45
77
|
)
|
|
46
78
|
|
|
47
79
|
CTabs.propTypes = {
|
|
48
|
-
activeItemKey: PropTypes.oneOfType([PropTypes.number, PropTypes.string])
|
|
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
|
-
|
|
4
|
+
|
|
5
|
+
import { CTabContent } from '../index'
|
|
5
6
|
|
|
6
7
|
test('loads and displays CTabContent component', async () => {
|
|
7
|
-
|
|
8
|
-
|
|
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
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
17
|
+
let container: HTMLElement
|
|
18
|
+
await act(async () => {
|
|
19
|
+
const renderResult = render(<CTabContent className="bazinga">Test</CTabContent>)
|
|
20
|
+
container = renderResult.container
|
|
21
|
+
})
|
|
22
|
+
expect(container!).toMatchSnapshot()
|
|
23
|
+
expect(container!.firstChild).toHaveClass('bazinga')
|
|
24
|
+
expect(container!.firstChild).toHaveClass('tab-content')
|
|
16
25
|
})
|
|
@@ -1,48 +1,68 @@
|
|
|
1
1
|
import * as React from 'react'
|
|
2
|
-
import { render, screen } from '@testing-library/react'
|
|
2
|
+
import { act, render, screen, waitFor } from '@testing-library/react'
|
|
3
3
|
import '@testing-library/jest-dom'
|
|
4
|
-
|
|
4
|
+
|
|
5
|
+
import { CTabPane, CTabContent } from '../index'
|
|
5
6
|
|
|
6
7
|
test('loads and displays CTabPane component', async () => {
|
|
7
|
-
|
|
8
|
-
|
|
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
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
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
|
-
|
|
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
|
|
|
@@ -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
|
-
|
|
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 '
|
|
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
|
-
|
|
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
|
-
|
|
68
|
+
act(() => {
|
|
69
|
+
fireEvent.click(btn)
|
|
70
|
+
jest.runAllTimers()
|
|
71
|
+
})
|
|
72
72
|
}
|
|
73
|
-
|
|
74
|
-
await
|
|
75
|
-
|
|
76
|
-
|
|
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
|
-
|
|
92
|
-
()
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
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 '
|
|
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 '
|
|
4
|
+
import { CToastHeader } from '../index'
|
|
5
5
|
|
|
6
6
|
test('loads and displays CToastHeader component', async () => {
|
|
7
7
|
const { container } = render(<CToastHeader>Test</CToastHeader>)
|