UNPKG

3.18 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 = _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 bsPrefix = _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 bsPrefix = (0, _ThemeProvider.useBootstrapPrefix)(bsPrefix, 'nav');
58 var navbarBsPrefix, cardHeaderBsPrefix;
59 var navbarContext = (0, _react.useContext)(_NavbarContext.default);
60 var cardContext = (0, _react.useContext)(_CardContext.default);
61
62 if (navbarContext) {
63 navbarBsPrefix = navbarContext.bsPrefix;
64 navbar = navbar == null ? true : navbar;
65 } else if (cardContext) {
66 cardHeaderBsPrefix = cardContext.cardHeaderBsPrefix;
67 }
68
69 return _react.default.createElement(_AbstractNav.default, (0, _extends2.default)({
70 as: as,
71 ref: ref,
72 activeKey: activeKey,
73 className: (0, _classnames.default)(className, (_classNames = {}, _classNames[bsPrefix] = !navbar, _classNames[navbarBsPrefix + "-nav"] = navbar, _classNames[cardHeaderBsPrefix + "-" + variant] = !!cardHeaderBsPrefix, _classNames[bsPrefix + "-" + variant] = !!variant, _classNames[bsPrefix + "-fill"] = fill, _classNames[bsPrefix + "-justified"] = justify, _classNames))
74 }, props), children);
75});
76
77Nav.displayName = 'Nav';
78Nav.defaultProps = defaultProps;
79Nav.Item = _NavItem.default;
80Nav.Link = _NavLink.default;
81var _default = Nav;
82exports.default = _default;
83module.exports = exports["default"];
\No newline at end of file