@coreui/react 4.1.0 → 4.2.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/components/accordion/index.d.ts +7 -0
- package/dist/components/alert/index.d.ts +4 -0
- package/dist/components/avatar/index.d.ts +2 -0
- package/dist/components/backdrop/index.d.ts +2 -0
- package/dist/components/badge/index.d.ts +2 -0
- package/dist/components/breadcrumb/index.d.ts +3 -0
- package/dist/components/button/index.d.ts +2 -0
- package/dist/components/button-group/index.d.ts +3 -0
- package/dist/components/callout/index.d.ts +2 -0
- package/dist/components/card/index.d.ts +12 -0
- package/dist/components/carousel/index.d.ts +4 -0
- package/dist/components/close-button/index.d.ts +2 -0
- package/dist/components/collapse/index.d.ts +2 -0
- package/dist/components/dropdown/CDropdown.d.ts +10 -1
- package/dist/components/dropdown/CDropdownToggle.d.ts +4 -0
- package/dist/components/dropdown/index.d.ts +8 -0
- package/dist/components/footer/index.d.ts +2 -0
- package/dist/components/form/CForm.d.ts +2 -2
- package/dist/components/form/CFormCheck.d.ts +2 -1
- package/dist/components/form/CFormControlValidation.d.ts +46 -0
- package/dist/components/form/CFormControlWrapper.d.ts +31 -0
- package/dist/components/form/CFormInput.d.ts +6 -9
- package/dist/components/form/CFormRange.d.ts +7 -1
- package/dist/components/form/CFormSelect.d.ts +3 -10
- package/dist/components/form/CFormTextarea.d.ts +2 -9
- package/dist/components/form/index.d.ts +14 -0
- package/dist/components/grid/index.d.ts +4 -0
- package/dist/components/header/index.d.ts +7 -0
- package/dist/components/image/index.d.ts +2 -0
- package/dist/components/index.d.ts +35 -0
- package/dist/components/link/index.d.ts +2 -0
- package/dist/components/list-group/index.d.ts +3 -0
- package/dist/components/modal/CModal.d.ts +4 -0
- package/dist/components/modal/index.d.ts +8 -0
- package/dist/components/nav/index.d.ts +7 -0
- package/dist/components/navbar/index.d.ts +6 -0
- package/dist/components/offcanvas/index.d.ts +5 -0
- package/dist/components/pagination/index.d.ts +3 -0
- package/dist/components/placeholder/index.d.ts +2 -0
- package/dist/components/popover/CPopover.d.ts +4 -4
- package/dist/components/popover/index.d.ts +2 -0
- package/dist/components/progress/index.d.ts +3 -0
- package/dist/components/sidebar/index.d.ts +7 -0
- package/dist/components/spinner/index.d.ts +2 -0
- package/dist/components/table/index.d.ts +9 -0
- package/dist/components/tabs/index.d.ts +3 -0
- package/dist/components/toast/index.d.ts +6 -0
- package/dist/components/tooltip/CTooltip.d.ts +7 -3
- package/dist/components/tooltip/index.d.ts +2 -0
- package/dist/index.d.ts +0 -120
- package/dist/index.es.js +676 -559
- package/dist/index.es.js.map +1 -1
- package/dist/index.js +676 -559
- package/dist/index.js.map +1 -1
- package/package.json +13 -12
- package/src/components/accordion/CAccordionButton.tsx +2 -1
- package/src/components/accordion/__tests__/__snapshots__/CAccordionButton.spec.tsx.snap +2 -0
- package/src/components/accordion/__tests__/__snapshots__/CAccordionHeader.spec.tsx.snap +2 -0
- package/src/components/accordion/index.ts +15 -0
- package/src/components/alert/CAlert.tsx +14 -3
- package/src/components/alert/index.ts +5 -0
- package/src/components/avatar/index.ts +3 -0
- package/src/components/backdrop/CBackdrop.tsx +10 -3
- package/src/components/backdrop/index.ts +3 -0
- package/src/components/badge/index.ts +3 -0
- package/src/components/breadcrumb/index.ts +4 -0
- package/src/components/button/index.ts +3 -0
- package/src/components/button-group/index.ts +4 -0
- package/src/components/callout/index.ts +3 -0
- package/src/components/card/index.ts +25 -0
- package/src/components/carousel/index.ts +5 -0
- package/src/components/close-button/index.ts +3 -0
- package/src/components/collapse/CCollapse.tsx +1 -0
- package/src/components/collapse/index.ts +3 -0
- package/src/components/dropdown/CDropdown.tsx +19 -24
- package/src/components/dropdown/CDropdownItem.tsx +1 -1
- package/src/components/dropdown/CDropdownMenu.tsx +55 -3
- package/src/components/dropdown/CDropdownToggle.tsx +28 -5
- package/src/components/dropdown/index.ts +17 -0
- package/src/components/footer/index.ts +3 -0
- package/src/components/form/CForm.tsx +2 -2
- package/src/components/form/CFormCheck.tsx +32 -7
- package/src/components/form/CFormControlValidation.tsx +97 -0
- package/src/components/form/CFormControlWrapper.tsx +85 -0
- package/src/components/form/CFormInput.tsx +75 -19
- package/src/components/form/CFormRange.tsx +18 -4
- package/src/components/form/CFormSelect.tsx +60 -32
- package/src/components/form/CFormTextarea.tsx +45 -17
- package/src/components/form/index.ts +29 -0
- package/src/components/grid/index.ts +5 -0
- package/src/components/header/index.ts +8 -0
- package/src/components/image/index.ts +3 -0
- package/src/components/index.ts +35 -0
- package/src/components/link/index.ts +3 -0
- package/src/components/list-group/index.ts +4 -0
- package/src/components/modal/CModal.tsx +43 -19
- package/src/components/modal/__tests__/CModal.spec.tsx +1 -1
- package/src/components/modal/__tests__/__snapshots__/CModal.spec.tsx.snap +2 -10
- package/src/components/modal/index.ts +9 -0
- package/src/components/nav/CNavGroup.tsx +1 -0
- package/src/components/nav/index.ts +8 -0
- package/src/components/navbar/index.ts +7 -0
- package/src/components/offcanvas/COffcanvas.tsx +1 -0
- package/src/components/offcanvas/index.ts +6 -0
- package/src/components/pagination/index.ts +4 -0
- package/src/components/placeholder/index.ts +3 -0
- package/src/components/popover/CPopover.tsx +63 -61
- package/src/components/popover/index.ts +3 -0
- package/src/components/progress/index.ts +4 -0
- package/src/components/sidebar/index.ts +8 -0
- package/src/components/spinner/index.ts +3 -0
- package/src/components/table/index.ts +19 -0
- package/src/components/tabs/CTabPane.tsx +7 -3
- package/src/components/tabs/index.ts +4 -0
- package/src/components/toast/CToast.tsx +6 -1
- package/src/components/toast/index.ts +7 -0
- package/src/components/tooltip/CTooltip.tsx +65 -47
- package/src/components/tooltip/index.ts +3 -0
- package/src/index.ts +0 -242
- package/src/utils/hooks/useForkedRef.ts +5 -0
|
@@ -1,19 +1,24 @@
|
|
|
1
|
-
import React, { FC,
|
|
1
|
+
import React, { FC, ReactNode, useRef, useState } from 'react'
|
|
2
2
|
import { createPortal } from 'react-dom'
|
|
3
|
-
|
|
3
|
+
|
|
4
4
|
import classNames from 'classnames'
|
|
5
|
-
import
|
|
5
|
+
import PropTypes from 'prop-types'
|
|
6
|
+
import { usePopper } from 'react-popper'
|
|
6
7
|
import { Transition } from 'react-transition-group'
|
|
7
8
|
|
|
8
|
-
// import { CTooltipContent } from './CTooltipContent'
|
|
9
9
|
import { Triggers, triggerPropType } from '../Types'
|
|
10
10
|
|
|
11
11
|
export interface CTooltipProps {
|
|
12
|
-
|
|
12
|
+
// TODO: find solution to not use any
|
|
13
|
+
children: any
|
|
13
14
|
/**
|
|
14
15
|
* Content node for your component.
|
|
15
16
|
*/
|
|
16
|
-
content: ReactNode
|
|
17
|
+
content: ReactNode | string
|
|
18
|
+
/**
|
|
19
|
+
* Offset of the popover relative to its target.
|
|
20
|
+
*/
|
|
21
|
+
offset?: [number, number]
|
|
17
22
|
/**
|
|
18
23
|
* Callback fired when the component requests to be hidden.
|
|
19
24
|
*/
|
|
@@ -41,15 +46,33 @@ export interface CTooltipProps {
|
|
|
41
46
|
export const CTooltip: FC<CTooltipProps> = ({
|
|
42
47
|
children,
|
|
43
48
|
content,
|
|
44
|
-
|
|
49
|
+
offset = [0, 0],
|
|
45
50
|
onHide,
|
|
46
51
|
onShow,
|
|
52
|
+
placement = 'top',
|
|
47
53
|
trigger = 'hover',
|
|
48
54
|
visible,
|
|
49
55
|
...rest
|
|
50
56
|
}) => {
|
|
57
|
+
const tooltipRef = useRef()
|
|
51
58
|
const [_visible, setVisible] = useState(visible)
|
|
52
59
|
|
|
60
|
+
const [referenceElement, setReferenceElement] = useState(null)
|
|
61
|
+
const [popperElement, setPopperElement] = useState<HTMLDivElement | null>(null)
|
|
62
|
+
const [arrowElement, setArrowElement] = useState<HTMLDivElement | null>(null)
|
|
63
|
+
const { styles, attributes } = usePopper(referenceElement, popperElement, {
|
|
64
|
+
modifiers: [
|
|
65
|
+
{ name: 'arrow', options: { element: arrowElement } },
|
|
66
|
+
{
|
|
67
|
+
name: 'offset',
|
|
68
|
+
options: {
|
|
69
|
+
offset: offset,
|
|
70
|
+
},
|
|
71
|
+
},
|
|
72
|
+
],
|
|
73
|
+
placement: placement,
|
|
74
|
+
})
|
|
75
|
+
|
|
53
76
|
const getTransitionClass = (state: string) => {
|
|
54
77
|
return state === 'entering'
|
|
55
78
|
? 'fade'
|
|
@@ -61,30 +84,27 @@ export const CTooltip: FC<CTooltipProps> = ({
|
|
|
61
84
|
}
|
|
62
85
|
|
|
63
86
|
return (
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
}),
|
|
80
|
-
})
|
|
81
|
-
}
|
|
82
|
-
</Reference>
|
|
87
|
+
<>
|
|
88
|
+
{React.cloneElement(children, {
|
|
89
|
+
ref: setReferenceElement,
|
|
90
|
+
...((trigger === 'click' || trigger.includes('click')) && {
|
|
91
|
+
onClick: () => setVisible(!_visible),
|
|
92
|
+
}),
|
|
93
|
+
...((trigger === 'focus' || trigger.includes('focus')) && {
|
|
94
|
+
onFocus: () => setVisible(true),
|
|
95
|
+
onBlur: () => setVisible(false),
|
|
96
|
+
}),
|
|
97
|
+
...((trigger === 'hover' || trigger.includes('hover')) && {
|
|
98
|
+
onMouseEnter: () => setVisible(true),
|
|
99
|
+
onMouseLeave: () => setVisible(false),
|
|
100
|
+
}),
|
|
101
|
+
})}
|
|
83
102
|
{typeof window !== 'undefined' &&
|
|
84
103
|
createPortal(
|
|
85
104
|
<Transition
|
|
86
105
|
in={_visible}
|
|
87
106
|
mountOnEnter
|
|
107
|
+
nodeRef={tooltipRef}
|
|
88
108
|
onEnter={onShow}
|
|
89
109
|
onExit={onHide}
|
|
90
110
|
timeout={{
|
|
@@ -96,40 +116,38 @@ export const CTooltip: FC<CTooltipProps> = ({
|
|
|
96
116
|
{(state) => {
|
|
97
117
|
const transitionClass = getTransitionClass(state)
|
|
98
118
|
return (
|
|
99
|
-
<
|
|
100
|
-
{(
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
}`,
|
|
106
|
-
transitionClass,
|
|
107
|
-
)}
|
|
108
|
-
ref={ref}
|
|
109
|
-
role="tooltip"
|
|
110
|
-
style={style}
|
|
111
|
-
{...rest}
|
|
112
|
-
>
|
|
113
|
-
<div className="tooltip-arrow" {...arrowProps}></div>
|
|
114
|
-
<div className="tooltip-inner">{content}</div>
|
|
115
|
-
</div>
|
|
119
|
+
<div
|
|
120
|
+
className={classNames(
|
|
121
|
+
`tooltip bs-tooltip-${
|
|
122
|
+
placement === 'left' ? 'start' : placement === 'right' ? 'end' : placement
|
|
123
|
+
}`,
|
|
124
|
+
transitionClass,
|
|
116
125
|
)}
|
|
117
|
-
|
|
126
|
+
ref={setPopperElement}
|
|
127
|
+
role="tooltip"
|
|
128
|
+
style={styles.popper}
|
|
129
|
+
{...attributes.popper}
|
|
130
|
+
{...rest}
|
|
131
|
+
>
|
|
132
|
+
<div className="tooltip-arrow" style={styles.arrow} ref={setArrowElement}></div>
|
|
133
|
+
<div className="tooltip-inner">{content}</div>
|
|
134
|
+
</div>
|
|
118
135
|
)
|
|
119
136
|
}}
|
|
120
137
|
</Transition>,
|
|
121
138
|
document.body,
|
|
122
139
|
)}
|
|
123
|
-
|
|
140
|
+
</>
|
|
124
141
|
)
|
|
125
142
|
}
|
|
126
143
|
|
|
127
144
|
CTooltip.propTypes = {
|
|
128
145
|
children: PropTypes.any,
|
|
129
|
-
content: PropTypes.node,
|
|
130
|
-
|
|
146
|
+
content: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),
|
|
147
|
+
offset: PropTypes.any, // TODO: find good proptype
|
|
131
148
|
onHide: PropTypes.func,
|
|
132
149
|
onShow: PropTypes.func,
|
|
150
|
+
placement: PropTypes.oneOf(['auto', 'top', 'right', 'bottom', 'left']),
|
|
133
151
|
trigger: triggerPropType,
|
|
134
152
|
visible: PropTypes.bool,
|
|
135
153
|
}
|
package/src/index.ts
CHANGED
|
@@ -1,243 +1 @@
|
|
|
1
|
-
import { CAccordion } from './components/accordion/CAccordion'
|
|
2
|
-
import { CAccordionBody } from './components/accordion/CAccordionBody'
|
|
3
|
-
import { CAccordionButton } from './components/accordion/CAccordionButton'
|
|
4
|
-
import { CAccordionCollapse } from './components/accordion/CAccordionCollapse'
|
|
5
|
-
import { CAccordionHeader } from './components/accordion/CAccordionHeader'
|
|
6
|
-
import { CAccordionItem } from './components/accordion/CAccordionItem'
|
|
7
|
-
import { CAlert } from './components/alert/CAlert'
|
|
8
|
-
import { CAlertHeading } from './components/alert/CAlertHeading'
|
|
9
|
-
import { CAlertLink } from './components/alert/CAlertLink'
|
|
10
|
-
import { CAvatar } from './components/avatar/CAvatar'
|
|
11
|
-
import { CBadge } from './components/badge/CBadge'
|
|
12
|
-
import { CBackdrop } from './components/backdrop/CBackdrop'
|
|
13
|
-
import { CBreadcrumb } from './components/breadcrumb/CBreadcrumb'
|
|
14
|
-
import { CBreadcrumbItem } from './components/breadcrumb/CBreadcrumbItem'
|
|
15
|
-
import { CButton } from './components/button/CButton'
|
|
16
|
-
import { CButtonGroup } from './components/button-group/CButtonGroup'
|
|
17
|
-
import { CButtonToolbar } from './components/button-group/CButtonToolbar'
|
|
18
|
-
import { CCallout } from './components/callout/CCallout'
|
|
19
|
-
import { CCard } from './components/card/CCard'
|
|
20
|
-
import { CCardBody } from './components/card/CCardBody'
|
|
21
|
-
import { CCardFooter } from './components/card/CCardFooter'
|
|
22
|
-
import { CCardGroup } from './components/card/CCardGroup'
|
|
23
|
-
import { CCardHeader } from './components/card/CCardHeader'
|
|
24
|
-
import { CCardImage } from './components/card/CCardImage'
|
|
25
|
-
import { CCardImageOverlay } from './components/card/CCardImageOverlay'
|
|
26
|
-
import { CCardLink } from './components/card/CCardLink'
|
|
27
|
-
import { CCardSubtitle } from './components/card/CCardSubtitle'
|
|
28
|
-
import { CCardText } from './components/card/CCardText'
|
|
29
|
-
import { CCardTitle } from './components/card/CCardTitle'
|
|
30
|
-
import { CCarousel } from './components/carousel/CCarousel'
|
|
31
|
-
import { CCarouselCaption } from './components/carousel/CCarouselCaption'
|
|
32
|
-
import { CCarouselItem } from './components/carousel/CCarouselItem'
|
|
33
|
-
import { CCollapse } from './components/collapse/CCollapse'
|
|
34
|
-
import { CCloseButton } from './components/close-button/CCloseButton'
|
|
35
|
-
import { CDropdown } from './components/dropdown/CDropdown'
|
|
36
|
-
import { CDropdownDivider } from './components/dropdown/CDropdownDivider'
|
|
37
|
-
import { CDropdownHeader } from './components/dropdown/CDropdownHeader'
|
|
38
|
-
import { CDropdownItem } from './components/dropdown/CDropdownItem'
|
|
39
|
-
import { CDropdownItemPlain } from './components/dropdown/CDropdownItemPlain'
|
|
40
|
-
import { CDropdownMenu } from './components/dropdown/CDropdownMenu'
|
|
41
|
-
import { CDropdownToggle } from './components/dropdown/CDropdownToggle'
|
|
42
|
-
import { CCol } from './components/grid/CCol'
|
|
43
|
-
import { CContainer } from './components/grid/CContainer'
|
|
44
|
-
import { CRow } from './components/grid/CRow'
|
|
45
|
-
import { CFooter } from './components/footer/CFooter'
|
|
46
|
-
import { CForm } from './components/form/CForm'
|
|
47
|
-
import { CFormCheck } from './components/form/CFormCheck'
|
|
48
|
-
import { CFormFeedback } from './components/form/CFormFeedback'
|
|
49
|
-
import { CFormFloating } from './components/form/CFormFloating'
|
|
50
|
-
import { CFormInput } from './components/form/CFormInput'
|
|
51
|
-
import { CFormLabel } from './components/form/CFormLabel'
|
|
52
|
-
import { CFormRange } from './components/form/CFormRange'
|
|
53
|
-
import { CFormSelect } from './components/form/CFormSelect'
|
|
54
|
-
import { CFormSwitch } from './components/form/CFormSwitch'
|
|
55
|
-
import { CFormText } from './components/form/CFormText'
|
|
56
|
-
import { CFormTextarea } from './components/form/CFormTextarea'
|
|
57
|
-
import { CInputGroup } from './components/form/CInputGroup'
|
|
58
|
-
import { CInputGroupText } from './components/form/CInputGroupText'
|
|
59
|
-
import { CHeader } from './components/header/CHeader'
|
|
60
|
-
import { CHeaderBrand } from './components/header/CHeaderBrand'
|
|
61
|
-
import { CHeaderDivider } from './components/header/CHeaderDivider'
|
|
62
|
-
import { CHeaderNav } from './components/header/CHeaderNav'
|
|
63
|
-
import { CHeaderText } from './components/header/CHeaderText'
|
|
64
|
-
import { CHeaderToggler } from './components/header/CHeaderToggler'
|
|
65
|
-
import { CImage } from './components/image/CImage'
|
|
66
|
-
import { CLink } from './components/link/CLink'
|
|
67
|
-
import { CListGroup } from './components/list-group/CListGroup'
|
|
68
|
-
import { CListGroupItem } from './components/list-group/CListGroupItem'
|
|
69
|
-
import { CModal } from './components/modal/CModal'
|
|
70
|
-
import { CModalBody } from './components/modal/CModalBody'
|
|
71
|
-
import { CModalContent } from './components/modal/CModalContent'
|
|
72
|
-
import { CModalDialog } from './components/modal/CModalDialog'
|
|
73
|
-
import { CModalFooter } from './components/modal/CModalFooter'
|
|
74
|
-
import { CModalHeader } from './components/modal/CModalHeader'
|
|
75
|
-
import { CModalTitle } from './components/modal/CModalTitle'
|
|
76
|
-
import { CNav } from './components/nav/CNav'
|
|
77
|
-
import { CNavGroupItems } from './components/nav/CNavGroupItems'
|
|
78
|
-
import { CNavGroup } from './components/nav/CNavGroup'
|
|
79
|
-
import { CNavItem } from './components/nav/CNavItem'
|
|
80
|
-
import { CNavLink } from './components/nav/CNavLink'
|
|
81
|
-
import { CNavTitle } from './components/nav/CNavTitle'
|
|
82
|
-
import { CNavbar } from './components/navbar/CNavbar'
|
|
83
|
-
import { CNavbarBrand } from './components/navbar/CNavbarBrand'
|
|
84
|
-
import { CNavbarNav } from './components/navbar/CNavbarNav'
|
|
85
|
-
import { CNavbarText } from './components/navbar/CNavbarText'
|
|
86
|
-
import { CNavbarToggler } from './components/navbar/CNavbarToggler'
|
|
87
|
-
import { CPagination } from './components/pagination/CPagination'
|
|
88
|
-
import { CPaginationItem } from './components/pagination/CPaginationItem'
|
|
89
|
-
import { CPlaceholder } from './components/placeholder/CPlaceholder'
|
|
90
|
-
import { CPopover } from './components/popover/CPopover'
|
|
91
|
-
import { CProgress } from './components/progress/CProgress'
|
|
92
|
-
import { CProgressBar } from './components/progress/CProgressBar'
|
|
93
|
-
import { CSidebar } from './components/sidebar/CSidebar'
|
|
94
|
-
import { COffcanvas } from './components/offcanvas/COffcanvas'
|
|
95
|
-
import { COffcanvasBody } from './components/offcanvas/COffcanvasBody'
|
|
96
|
-
import { COffcanvasHeader } from './components/offcanvas/COffcanvasHeader'
|
|
97
|
-
import { COffcanvasTitle } from './components/offcanvas/COffcanvasTitle'
|
|
98
|
-
import { CSidebarBrand } from './components/sidebar/CSidebarBrand'
|
|
99
|
-
import { CSidebarFooter } from './components/sidebar/CSidebarFooter'
|
|
100
|
-
import { CSidebarToggler } from './components/sidebar/CSidebarToggler'
|
|
101
|
-
import { CSidebarHeader } from './components/sidebar/CSidebarHeader'
|
|
102
|
-
import { CSidebarNav } from './components/sidebar/CSidebarNav'
|
|
103
|
-
import { CSpinner } from './components/spinner/CSpinner'
|
|
104
|
-
import { CTable } from './components/table/CTable'
|
|
105
|
-
import { CTableBody } from './components/table/CTableBody'
|
|
106
|
-
import { CTableCaption } from './components/table/CTableCaption'
|
|
107
|
-
import { CTableDataCell } from './components/table/CTableDataCell'
|
|
108
|
-
import { CTableFoot } from './components/table/CTableFoot'
|
|
109
|
-
import { CTableHead } from './components/table/CTableHead'
|
|
110
|
-
import { CTableHeaderCell } from './components/table/CTableHeaderCell'
|
|
111
|
-
import { CTableRow } from './components/table/CTableRow'
|
|
112
|
-
import { CTabContent } from './components/tabs/CTabContent'
|
|
113
|
-
import { CTabPane } from './components/tabs/CTabPane'
|
|
114
|
-
import { CToast } from './components/toast/CToast'
|
|
115
|
-
import { CToastBody } from './components/toast/CToastBody'
|
|
116
|
-
import { CToastClose } from './components/toast/CToastClose'
|
|
117
|
-
import { CToastHeader } from './components/toast/CToastHeader'
|
|
118
|
-
import { CToaster } from './components/toast/CToaster'
|
|
119
|
-
import { CTooltip } from './components/tooltip/CTooltip'
|
|
120
|
-
|
|
121
|
-
export {
|
|
122
|
-
CAccordion,
|
|
123
|
-
CAccordionBody,
|
|
124
|
-
CAccordionButton,
|
|
125
|
-
CAccordionCollapse,
|
|
126
|
-
CAccordionHeader,
|
|
127
|
-
CAccordionItem,
|
|
128
|
-
CAlert,
|
|
129
|
-
CAlertHeading,
|
|
130
|
-
CAlertLink,
|
|
131
|
-
CAvatar,
|
|
132
|
-
CBadge,
|
|
133
|
-
CBackdrop,
|
|
134
|
-
CBreadcrumb,
|
|
135
|
-
CBreadcrumbItem,
|
|
136
|
-
CButton,
|
|
137
|
-
CButtonGroup,
|
|
138
|
-
CButtonToolbar,
|
|
139
|
-
CCallout,
|
|
140
|
-
CCard,
|
|
141
|
-
CCardBody,
|
|
142
|
-
CCardFooter,
|
|
143
|
-
CCardHeader,
|
|
144
|
-
CCardImage,
|
|
145
|
-
CCardImageOverlay,
|
|
146
|
-
CCardLink,
|
|
147
|
-
CCardSubtitle,
|
|
148
|
-
CCardText,
|
|
149
|
-
CCardTitle,
|
|
150
|
-
CCarousel,
|
|
151
|
-
CCarouselCaption,
|
|
152
|
-
CCarouselItem,
|
|
153
|
-
CCloseButton,
|
|
154
|
-
CCollapse,
|
|
155
|
-
CDropdown,
|
|
156
|
-
CDropdownDivider,
|
|
157
|
-
CDropdownHeader,
|
|
158
|
-
CDropdownItem,
|
|
159
|
-
CDropdownItemPlain,
|
|
160
|
-
CDropdownMenu,
|
|
161
|
-
CDropdownToggle,
|
|
162
|
-
CCol,
|
|
163
|
-
CContainer,
|
|
164
|
-
CRow,
|
|
165
|
-
CFooter,
|
|
166
|
-
CCardGroup,
|
|
167
|
-
CForm,
|
|
168
|
-
CFormCheck,
|
|
169
|
-
CFormFeedback,
|
|
170
|
-
CFormFloating,
|
|
171
|
-
CFormInput,
|
|
172
|
-
CFormLabel,
|
|
173
|
-
CFormRange,
|
|
174
|
-
CFormSelect,
|
|
175
|
-
CFormSwitch,
|
|
176
|
-
CFormText,
|
|
177
|
-
CFormTextarea,
|
|
178
|
-
CImage,
|
|
179
|
-
CInputGroup,
|
|
180
|
-
CInputGroupText,
|
|
181
|
-
CHeader,
|
|
182
|
-
CHeaderBrand,
|
|
183
|
-
CHeaderDivider,
|
|
184
|
-
CHeaderNav,
|
|
185
|
-
CHeaderText,
|
|
186
|
-
CHeaderToggler,
|
|
187
|
-
CLink,
|
|
188
|
-
CListGroup,
|
|
189
|
-
CListGroupItem,
|
|
190
|
-
CModal,
|
|
191
|
-
CModalBody,
|
|
192
|
-
CModalContent,
|
|
193
|
-
CModalDialog,
|
|
194
|
-
CModalFooter,
|
|
195
|
-
CModalHeader,
|
|
196
|
-
CModalTitle,
|
|
197
|
-
CNav,
|
|
198
|
-
CNavGroup,
|
|
199
|
-
CNavGroupItems,
|
|
200
|
-
CNavItem,
|
|
201
|
-
CNavLink,
|
|
202
|
-
CNavTitle,
|
|
203
|
-
CNavbar,
|
|
204
|
-
CNavbarBrand,
|
|
205
|
-
CNavbarNav,
|
|
206
|
-
CNavbarText,
|
|
207
|
-
CNavbarToggler,
|
|
208
|
-
CPagination,
|
|
209
|
-
CPaginationItem,
|
|
210
|
-
CPlaceholder,
|
|
211
|
-
CPopover,
|
|
212
|
-
CProgress,
|
|
213
|
-
CProgressBar,
|
|
214
|
-
COffcanvas,
|
|
215
|
-
COffcanvasBody,
|
|
216
|
-
COffcanvasHeader,
|
|
217
|
-
COffcanvasTitle,
|
|
218
|
-
CSidebar,
|
|
219
|
-
CSidebarBrand,
|
|
220
|
-
CSidebarFooter,
|
|
221
|
-
CSidebarToggler,
|
|
222
|
-
CSidebarHeader,
|
|
223
|
-
CSidebarNav,
|
|
224
|
-
CSpinner,
|
|
225
|
-
CTable,
|
|
226
|
-
CTableBody,
|
|
227
|
-
CTableCaption,
|
|
228
|
-
CTableDataCell,
|
|
229
|
-
CTableFoot,
|
|
230
|
-
CTableHead,
|
|
231
|
-
CTableHeaderCell,
|
|
232
|
-
CTableRow,
|
|
233
|
-
CTabContent,
|
|
234
|
-
CTabPane,
|
|
235
|
-
CToast,
|
|
236
|
-
CToastBody,
|
|
237
|
-
CToastClose,
|
|
238
|
-
CToastHeader,
|
|
239
|
-
CToaster,
|
|
240
|
-
CTooltip,
|
|
241
|
-
}
|
|
242
|
-
|
|
243
1
|
export * from './components/'
|
|
@@ -9,6 +9,7 @@ export type AssignableRef<ValueType> =
|
|
|
9
9
|
}['bivarianceHack']
|
|
10
10
|
| React.MutableRefObject<ValueType | null>
|
|
11
11
|
|
|
12
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
12
13
|
export function useForkedRef<RefValueType = any>(
|
|
13
14
|
...refs: (AssignableRef<RefValueType> | null | undefined)[]
|
|
14
15
|
) {
|
|
@@ -16,6 +17,7 @@ export function useForkedRef<RefValueType = any>(
|
|
|
16
17
|
if (refs.every((ref) => ref == null)) {
|
|
17
18
|
return null
|
|
18
19
|
}
|
|
20
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
19
21
|
return (node: any) => {
|
|
20
22
|
refs.forEach((ref) => {
|
|
21
23
|
assignRef(ref, node)
|
|
@@ -24,8 +26,10 @@ export function useForkedRef<RefValueType = any>(
|
|
|
24
26
|
}, refs)
|
|
25
27
|
}
|
|
26
28
|
|
|
29
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
27
30
|
export function assignRef<RefValueType = any>(
|
|
28
31
|
ref: AssignableRef<RefValueType> | null | undefined,
|
|
32
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
29
33
|
value: any,
|
|
30
34
|
) {
|
|
31
35
|
if (ref == null) return
|
|
@@ -40,6 +44,7 @@ export function assignRef<RefValueType = any>(
|
|
|
40
44
|
}
|
|
41
45
|
}
|
|
42
46
|
|
|
47
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types
|
|
43
48
|
export function isFunction(value: any): value is Function {
|
|
44
49
|
return !!(value && {}.toString.call(value) == '[object Function]')
|
|
45
50
|
}
|