1 | import _extends from "@babel/runtime/helpers/esm/extends";
|
2 | import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
3 | import React, { useContext } from 'react';
|
4 | import SelectableContext from './SelectableContext';
|
5 | import AccordionContext from './AccordionContext';
|
6 | export function useAccordionToggle(eventKey, onClick) {
|
7 | var contextEventKey = useContext(AccordionContext);
|
8 | var onSelect = useContext(SelectableContext);
|
9 | return function (e) {
|
10 | |
11 |
|
12 |
|
13 |
|
14 | var eventKeyPassed = eventKey === contextEventKey ? null : eventKey;
|
15 | if (onSelect) onSelect(eventKeyPassed, e);
|
16 | if (onClick) onClick(e);
|
17 | };
|
18 | }
|
19 | var AccordionToggle = React.forwardRef(function (_ref, ref) {
|
20 | var _ref$as = _ref.as,
|
21 | Component = _ref$as === void 0 ? 'button' : _ref$as,
|
22 | children = _ref.children,
|
23 | eventKey = _ref.eventKey,
|
24 | onClick = _ref.onClick,
|
25 | props = _objectWithoutPropertiesLoose(_ref, ["as", "children", "eventKey", "onClick"]);
|
26 |
|
27 | var accordionOnClick = useAccordionToggle(eventKey, onClick);
|
28 |
|
29 | if (Component === 'button') {
|
30 | props.type = 'button';
|
31 | }
|
32 |
|
33 | return React.createElement(Component, _extends({
|
34 | ref: ref,
|
35 | onClick: accordionOnClick
|
36 | }, props), children);
|
37 | });
|
38 | export default AccordionToggle; |
\ | No newline at end of file |