UNPKG

3.26 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 _all = _interopRequireDefault(require("prop-types-extra/lib/all"));
17
18var _react = _interopRequireWildcard(require("react"));
19
20var _uncontrollable = require("uncontrollable");
21
22var _ThemeProvider = require("./ThemeProvider");
23
24var _NavbarContext = _interopRequireDefault(require("./NavbarContext"));
25
26var _CardContext = _interopRequireDefault(require("./CardContext"));
27
28var _AbstractNav = _interopRequireDefault(require("./AbstractNav"));
29
30var _NavItem = _interopRequireDefault(require("./NavItem"));
31
32var _NavLink = _interopRequireDefault(require("./NavLink"));
33
34var defaultProps = {
35 justify: false,
36 fill: false
37};
38
39var Nav = /*#__PURE__*/_react.default.forwardRef(function (uncontrolledProps, ref) {
40 var _classNames;
41
42 var _useUncontrolled = (0, _uncontrollable.useUncontrolled)(uncontrolledProps, {
43 activeKey: 'onSelect'
44 }),
45 _useUncontrolled$as = _useUncontrolled.as,
46 as = _useUncontrolled$as === void 0 ? 'div' : _useUncontrolled$as,
47 initialBsPrefix = _useUncontrolled.bsPrefix,
48 variant = _useUncontrolled.variant,
49 fill = _useUncontrolled.fill,
50 justify = _useUncontrolled.justify,
51 navbar = _useUncontrolled.navbar,
52 className = _useUncontrolled.className,
53 children = _useUncontrolled.children,
54 activeKey = _useUncontrolled.activeKey,
55 props = (0, _objectWithoutPropertiesLoose2.default)(_useUncontrolled, ["as", "bsPrefix", "variant", "fill", "justify", "navbar", "className", "children", "activeKey"]);
56
57 var bsPrefix = (0, _ThemeProvider.useBootstrapPrefix)(initialBsPrefix, 'nav');
58 var navbarBsPrefix;
59 var cardHeaderBsPrefix;
60 var isNavbar = false;
61 var navbarContext = (0, _react.useContext)(_NavbarContext.default);
62 var cardContext = (0, _react.useContext)(_CardContext.default);
63
64 if (navbarContext) {
65 navbarBsPrefix = navbarContext.bsPrefix;
66 isNavbar = navbar == null ? true : navbar;
67 } else if (cardContext) {
68 cardHeaderBsPrefix = cardContext.cardHeaderBsPrefix;
69 }
70
71 return /*#__PURE__*/_react.default.createElement(_AbstractNav.default, (0, _extends2.default)({
72 as: as,
73 ref: ref,
74 activeKey: activeKey,
75 className: (0, _classnames.default)(className, (_classNames = {}, _classNames[bsPrefix] = !isNavbar, _classNames[navbarBsPrefix + "-nav"] = isNavbar, _classNames[cardHeaderBsPrefix + "-" + variant] = !!cardHeaderBsPrefix, _classNames[bsPrefix + "-" + variant] = !!variant, _classNames[bsPrefix + "-fill"] = fill, _classNames[bsPrefix + "-justified"] = justify, _classNames))
76 }, props), children);
77});
78
79Nav.displayName = 'Nav';
80Nav.defaultProps = defaultProps;
81Nav.Item = _NavItem.default;
82Nav.Link = _NavLink.default;
83var _default = Nav;
84exports.default = _default;
85module.exports = exports["default"];
\No newline at end of file