UNPKG

5.64 kBJavaScriptView Raw
1'use strict';
2
3exports.__esModule = true;
4
5var _extends2 = require('babel-runtime/helpers/extends');
6
7var _extends3 = _interopRequireDefault(_extends2);
8
9var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties');
10
11var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2);
12
13var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
14
15var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
16
17var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
18
19var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
20
21var _inherits2 = require('babel-runtime/helpers/inherits');
22
23var _inherits3 = _interopRequireDefault(_inherits2);
24
25var _classnames = require('classnames');
26
27var _classnames2 = _interopRequireDefault(_classnames);
28
29var _react = require('react');
30
31var _react2 = _interopRequireDefault(_react);
32
33var _propTypes = require('prop-types');
34
35var _propTypes2 = _interopRequireDefault(_propTypes);
36
37var _all = require('prop-types-extra/lib/all');
38
39var _all2 = _interopRequireDefault(_all);
40
41var _SafeAnchor = require('./SafeAnchor');
42
43var _SafeAnchor2 = _interopRequireDefault(_SafeAnchor);
44
45var _bootstrapUtils = require('./utils/bootstrapUtils');
46
47var _createChainedFunction = require('./utils/createChainedFunction');
48
49var _createChainedFunction2 = _interopRequireDefault(_createChainedFunction);
50
51function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
52
53var propTypes = {
54 /**
55 * Highlight the menu item as active.
56 */
57 active: _propTypes2.default.bool,
58
59 /**
60 * Disable the menu item, making it unselectable.
61 */
62 disabled: _propTypes2.default.bool,
63
64 /**
65 * Styles the menu item as a horizontal rule, providing visual separation between
66 * groups of menu items.
67 */
68 divider: (0, _all2.default)(_propTypes2.default.bool, function (_ref) {
69 var divider = _ref.divider,
70 children = _ref.children;
71 return divider && children ? new Error('Children will not be rendered for dividers') : null;
72 }),
73
74 /**
75 * Value passed to the `onSelect` handler, useful for identifying the selected menu item.
76 */
77 eventKey: _propTypes2.default.any,
78
79 /**
80 * Styles the menu item as a header label, useful for describing a group of menu items.
81 */
82 header: _propTypes2.default.bool,
83
84 /**
85 * HTML `href` attribute corresponding to `a.href`.
86 */
87 href: _propTypes2.default.string,
88
89 /**
90 * Callback fired when the menu item is clicked.
91 */
92 onClick: _propTypes2.default.func,
93
94 /**
95 * Callback fired when the menu item is selected.
96 *
97 * ```js
98 * (eventKey: any, event: Object) => any
99 * ```
100 */
101 onSelect: _propTypes2.default.func
102};
103
104var defaultProps = {
105 divider: false,
106 disabled: false,
107 header: false
108};
109
110var MenuItem = function (_React$Component) {
111 (0, _inherits3.default)(MenuItem, _React$Component);
112
113 function MenuItem(props, context) {
114 (0, _classCallCheck3.default)(this, MenuItem);
115
116 var _this = (0, _possibleConstructorReturn3.default)(this, _React$Component.call(this, props, context));
117
118 _this.handleClick = _this.handleClick.bind(_this);
119 return _this;
120 }
121
122 MenuItem.prototype.handleClick = function handleClick(event) {
123 var _props = this.props,
124 href = _props.href,
125 disabled = _props.disabled,
126 onSelect = _props.onSelect,
127 eventKey = _props.eventKey;
128
129
130 if (!href || disabled) {
131 event.preventDefault();
132 }
133
134 if (disabled) {
135 return;
136 }
137
138 if (onSelect) {
139 onSelect(eventKey, event);
140 }
141 };
142
143 MenuItem.prototype.render = function render() {
144 var _props2 = this.props,
145 active = _props2.active,
146 disabled = _props2.disabled,
147 divider = _props2.divider,
148 header = _props2.header,
149 onClick = _props2.onClick,
150 className = _props2.className,
151 style = _props2.style,
152 props = (0, _objectWithoutProperties3.default)(_props2, ['active', 'disabled', 'divider', 'header', 'onClick', 'className', 'style']);
153
154 var _splitBsPropsAndOmit = (0, _bootstrapUtils.splitBsPropsAndOmit)(props, ['eventKey', 'onSelect']),
155 bsProps = _splitBsPropsAndOmit[0],
156 elementProps = _splitBsPropsAndOmit[1];
157
158 if (divider) {
159 // Forcibly blank out the children; separators shouldn't render any.
160 elementProps.children = undefined;
161
162 return _react2.default.createElement('li', (0, _extends3.default)({}, elementProps, {
163 role: 'separator',
164 className: (0, _classnames2.default)(className, 'divider'),
165 style: style
166 }));
167 }
168
169 if (header) {
170 return _react2.default.createElement('li', (0, _extends3.default)({}, elementProps, {
171 role: 'heading',
172 className: (0, _classnames2.default)(className, (0, _bootstrapUtils.prefix)(bsProps, 'header')),
173 style: style
174 }));
175 }
176
177 return _react2.default.createElement(
178 'li',
179 {
180 role: 'presentation',
181 className: (0, _classnames2.default)(className, { active: active, disabled: disabled }),
182 style: style
183 },
184 _react2.default.createElement(_SafeAnchor2.default, (0, _extends3.default)({}, elementProps, {
185 role: 'menuitem',
186 tabIndex: '-1',
187 onClick: (0, _createChainedFunction2.default)(onClick, this.handleClick)
188 }))
189 );
190 };
191
192 return MenuItem;
193}(_react2.default.Component);
194
195MenuItem.propTypes = propTypes;
196MenuItem.defaultProps = defaultProps;
197
198exports.default = (0, _bootstrapUtils.bsClass)('dropdown', MenuItem);
199module.exports = exports['default'];
\No newline at end of file