37 lines
1.6 KiB
JavaScript
37 lines
1.6 KiB
JavaScript
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
||
|
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
||
|
import classNames from 'classnames';
|
||
|
import React from 'react';
|
||
|
import { useUncontrolled } from 'uncontrollable';
|
||
|
import { useBootstrapPrefix } from './ThemeProvider';
|
||
|
import AccordionToggle from './AccordionToggle';
|
||
|
import SelectableContext from './SelectableContext';
|
||
|
import AccordionCollapse from './AccordionCollapse';
|
||
|
import AccordionContext from './AccordionContext';
|
||
|
var Accordion = React.forwardRef(function (props, ref) {
|
||
|
var _useUncontrolled = useUncontrolled(props, {
|
||
|
activeKey: 'onSelect'
|
||
|
}),
|
||
|
_useUncontrolled$as = _useUncontrolled.as,
|
||
|
Component = _useUncontrolled$as === void 0 ? 'div' : _useUncontrolled$as,
|
||
|
activeKey = _useUncontrolled.activeKey,
|
||
|
bsPrefix = _useUncontrolled.bsPrefix,
|
||
|
children = _useUncontrolled.children,
|
||
|
className = _useUncontrolled.className,
|
||
|
onSelect = _useUncontrolled.onSelect,
|
||
|
controlledProps = _objectWithoutPropertiesLoose(_useUncontrolled, ["as", "activeKey", "bsPrefix", "children", "className", "onSelect"]);
|
||
|
|
||
|
bsPrefix = useBootstrapPrefix(bsPrefix, 'accordion');
|
||
|
return React.createElement(AccordionContext.Provider, {
|
||
|
value: activeKey
|
||
|
}, React.createElement(SelectableContext.Provider, {
|
||
|
value: onSelect
|
||
|
}, React.createElement(Component, _extends({
|
||
|
ref: ref
|
||
|
}, controlledProps, {
|
||
|
className: classNames(className, bsPrefix)
|
||
|
}), children)));
|
||
|
});
|
||
|
Accordion.Toggle = AccordionToggle;
|
||
|
Accordion.Collapse = AccordionCollapse;
|
||
|
export default Accordion;
|