mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
e95ad3e71b
GitOrigin-RevId: b8029b65c95ccdac89587d484e2599e25fe44302
34 lines
909 B
TypeScript
34 lines
909 B
TypeScript
import { Children, cloneElement, type FC, isValidElement } from 'react'
|
|
import { Dropdown, DropdownProps } from 'react-bootstrap'
|
|
import useDropdown from '../hooks/use-dropdown'
|
|
|
|
const ControlledDropdown: FC<
|
|
DropdownProps & { defaultOpen?: boolean }
|
|
> = props => {
|
|
const dropdownProps = useDropdown(Boolean(props.defaultOpen))
|
|
|
|
return (
|
|
<Dropdown {...props} {...dropdownProps}>
|
|
{Children.map(props.children, child => {
|
|
if (!isValidElement(child)) {
|
|
return child
|
|
}
|
|
|
|
// Dropdown.Menu
|
|
if ('open' in child.props) {
|
|
return cloneElement(child, { open: dropdownProps.open })
|
|
}
|
|
|
|
// Overlay
|
|
if ('show' in child.props) {
|
|
return cloneElement(child, { show: dropdownProps.open })
|
|
}
|
|
|
|
// anything else
|
|
return cloneElement(child)
|
|
})}
|
|
</Dropdown>
|
|
)
|
|
}
|
|
|
|
export default ControlledDropdown
|