UNPKG

1.72 kBJavaScriptView Raw
1import _extends from "@babel/runtime/helpers/esm/extends";
2import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
3var _excluded = ["bsPrefix", "split", "className", "childBsPrefix", "as"];
4import classNames from 'classnames';
5import isRequiredForA11y from 'prop-types-extra/lib/isRequiredForA11y';
6import React from 'react';
7import { useDropdownToggle } from 'react-overlays/DropdownToggle';
8import useMergedRefs from '@restart/hooks/useMergedRefs';
9import Button from './Button';
10import { useBootstrapPrefix } from './ThemeProvider';
11import useWrappedRefWithWarning from './useWrappedRefWithWarning';
12var DropdownToggle = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
13 var bsPrefix = _ref.bsPrefix,
14 split = _ref.split,
15 className = _ref.className,
16 childBsPrefix = _ref.childBsPrefix,
17 _ref$as = _ref.as,
18 Component = _ref$as === void 0 ? Button : _ref$as,
19 props = _objectWithoutPropertiesLoose(_ref, _excluded);
20
21 var prefix = useBootstrapPrefix(bsPrefix, 'dropdown-toggle');
22
23 if (childBsPrefix !== undefined) {
24 props.bsPrefix = childBsPrefix;
25 }
26
27 var _useDropdownToggle = useDropdownToggle(),
28 toggleProps = _useDropdownToggle[0];
29
30 toggleProps.ref = useMergedRefs(toggleProps.ref, useWrappedRefWithWarning(ref, 'DropdownToggle')); // This intentionally forwards size and variant (if set) to the
31 // underlying component, to allow it to render size and style variants.
32
33 return /*#__PURE__*/React.createElement(Component, _extends({
34 className: classNames(className, prefix, split && prefix + "-split")
35 }, toggleProps, props));
36});
37DropdownToggle.displayName = 'DropdownToggle';
38export default DropdownToggle;
\No newline at end of file