1 | 'use strict';
|
2 |
|
3 | exports.__esModule = true;
|
4 |
|
5 | var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties');
|
6 |
|
7 | var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2);
|
8 |
|
9 | var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
|
10 |
|
11 | var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
|
12 |
|
13 | var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
|
14 |
|
15 | var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
|
16 |
|
17 | var _inherits2 = require('babel-runtime/helpers/inherits');
|
18 |
|
19 | var _inherits3 = _interopRequireDefault(_inherits2);
|
20 |
|
21 | var _extends2 = require('babel-runtime/helpers/extends');
|
22 |
|
23 | var _extends3 = _interopRequireDefault(_extends2);
|
24 |
|
25 | var _classnames = require('classnames');
|
26 |
|
27 | var _classnames2 = _interopRequireDefault(_classnames);
|
28 |
|
29 | var _react = require('react');
|
30 |
|
31 | var _react2 = _interopRequireDefault(_react);
|
32 |
|
33 | var _propTypes = require('prop-types');
|
34 |
|
35 | var _propTypes2 = _interopRequireDefault(_propTypes);
|
36 |
|
37 | var _Dropdown = require('./Dropdown');
|
38 |
|
39 | var _Dropdown2 = _interopRequireDefault(_Dropdown);
|
40 |
|
41 | var _splitComponentProps2 = require('./utils/splitComponentProps');
|
42 |
|
43 | var _splitComponentProps3 = _interopRequireDefault(_splitComponentProps2);
|
44 |
|
45 | var _ValidComponentChildren = require('./utils/ValidComponentChildren');
|
46 |
|
47 | var _ValidComponentChildren2 = _interopRequireDefault(_ValidComponentChildren);
|
48 |
|
49 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
50 |
|
51 | var propTypes = (0, _extends3.default)({}, _Dropdown2.default.propTypes, {
|
52 |
|
53 |
|
54 | title: _propTypes2.default.node.isRequired,
|
55 | noCaret: _propTypes2.default.bool,
|
56 | active: _propTypes2.default.bool,
|
57 | activeKey: _propTypes2.default.any,
|
58 | activeHref: _propTypes2.default.string,
|
59 |
|
60 |
|
61 | |
62 |
|
63 |
|
64 | children: _propTypes2.default.node
|
65 | });
|
66 |
|
67 | var NavDropdown = function (_React$Component) {
|
68 | (0, _inherits3.default)(NavDropdown, _React$Component);
|
69 |
|
70 | function NavDropdown() {
|
71 | (0, _classCallCheck3.default)(this, NavDropdown);
|
72 | return (0, _possibleConstructorReturn3.default)(this, _React$Component.apply(this, arguments));
|
73 | }
|
74 |
|
75 | NavDropdown.prototype.isActive = function isActive(_ref, activeKey, activeHref) {
|
76 | var props = _ref.props;
|
77 |
|
78 | var _this2 = this;
|
79 |
|
80 | if (props.active || activeKey != null && props.eventKey === activeKey || activeHref && props.href === activeHref) {
|
81 | return true;
|
82 | }
|
83 |
|
84 | if (_ValidComponentChildren2.default.some(props.children, function (child) {
|
85 | return _this2.isActive(child, activeKey, activeHref);
|
86 | })) {
|
87 | return true;
|
88 | }
|
89 |
|
90 | return props.active;
|
91 | };
|
92 |
|
93 | NavDropdown.prototype.render = function render() {
|
94 | var _this3 = this;
|
95 |
|
96 | var _props = this.props,
|
97 | title = _props.title,
|
98 | activeKey = _props.activeKey,
|
99 | activeHref = _props.activeHref,
|
100 | className = _props.className,
|
101 | style = _props.style,
|
102 | children = _props.children,
|
103 | props = (0, _objectWithoutProperties3.default)(_props, ['title', 'activeKey', 'activeHref', 'className', 'style', 'children']);
|
104 |
|
105 |
|
106 | var active = this.isActive(this, activeKey, activeHref);
|
107 | delete props.active;
|
108 | delete props.eventKey;
|
109 |
|
110 | var _splitComponentProps = (0, _splitComponentProps3.default)(props, _Dropdown2.default.ControlledComponent),
|
111 | dropdownProps = _splitComponentProps[0],
|
112 | toggleProps = _splitComponentProps[1];
|
113 |
|
114 |
|
115 |
|
116 |
|
117 | return _react2.default.createElement(
|
118 | _Dropdown2.default,
|
119 | (0, _extends3.default)({}, dropdownProps, {
|
120 | componentClass: 'li',
|
121 | className: (0, _classnames2.default)(className, { active: active }),
|
122 | style: style
|
123 | }),
|
124 | _react2.default.createElement(
|
125 | _Dropdown2.default.Toggle,
|
126 | (0, _extends3.default)({}, toggleProps, { useAnchor: true }),
|
127 | title
|
128 | ),
|
129 | _react2.default.createElement(
|
130 | _Dropdown2.default.Menu,
|
131 | null,
|
132 | _ValidComponentChildren2.default.map(children, function (child) {
|
133 | return _react2.default.cloneElement(child, {
|
134 | active: _this3.isActive(child, activeKey, activeHref)
|
135 | });
|
136 | })
|
137 | )
|
138 | );
|
139 | };
|
140 |
|
141 | return NavDropdown;
|
142 | }(_react2.default.Component);
|
143 |
|
144 | NavDropdown.propTypes = propTypes;
|
145 |
|
146 | exports.default = NavDropdown;
|
147 | module.exports = exports['default']; |
\ | No newline at end of file |