UNPKG

2.22 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
5var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
7exports.__esModule = true;
8exports.default = void 0;
9
10var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
12var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
13
14var _classnames = _interopRequireDefault(require("classnames"));
15
16var _react = _interopRequireWildcard(require("react"));
17
18var _useEventCallback = _interopRequireDefault(require("@restart/hooks/useEventCallback"));
19
20var _ThemeProvider = require("./ThemeProvider");
21
22var _NavbarContext = _interopRequireDefault(require("./NavbarContext"));
23
24var defaultProps = {
25 label: 'Toggle navigation'
26};
27
28var NavbarToggle = _react.default.forwardRef(function (_ref, ref) {
29 var bsPrefix = _ref.bsPrefix,
30 className = _ref.className,
31 children = _ref.children,
32 label = _ref.label,
33 _ref$as = _ref.as,
34 Component = _ref$as === void 0 ? 'button' : _ref$as,
35 onClick = _ref.onClick,
36 props = (0, _objectWithoutPropertiesLoose2.default)(_ref, ["bsPrefix", "className", "children", "label", "as", "onClick"]);
37 bsPrefix = (0, _ThemeProvider.useBootstrapPrefix)(bsPrefix, 'navbar-toggler');
38
39 var _ref2 = (0, _react.useContext)(_NavbarContext.default) || {},
40 onToggle = _ref2.onToggle,
41 expanded = _ref2.expanded;
42
43 var handleClick = (0, _useEventCallback.default)(function (e) {
44 if (onClick) onClick(e);
45 if (onToggle) onToggle();
46 });
47
48 if (Component === 'button') {
49 props.type = 'button';
50 }
51
52 return _react.default.createElement(Component, (0, _extends2.default)({}, props, {
53 ref: ref,
54 onClick: handleClick,
55 "aria-label": label,
56 className: (0, _classnames.default)(className, bsPrefix, !expanded && 'collapsed')
57 }), children || _react.default.createElement("span", {
58 className: bsPrefix + "-icon"
59 }));
60});
61
62NavbarToggle.displayName = 'NavbarToggle';
63NavbarToggle.defaultProps = defaultProps;
64var _default = NavbarToggle;
65exports.default = _default;
66module.exports = exports["default"];
\No newline at end of file