UNPKG

2.13 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6
7var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
8
9var _react = require('react');
10
11var _react2 = _interopRequireDefault(_react);
12
13var _classnames = require('classnames');
14
15var _classnames2 = _interopRequireDefault(_classnames);
16
17function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
18
19function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
20
21var propTypes = {
22 tag: _react.PropTypes.oneOfType([_react.PropTypes.func, _react.PropTypes.string]),
23 active: _react.PropTypes.bool,
24 disabled: _react.PropTypes.bool,
25 color: _react.PropTypes.string,
26 action: _react.PropTypes.bool,
27 className: _react.PropTypes.any
28};
29
30var defaultProps = {
31 tag: 'li'
32};
33
34var handleDisabledOnClick = function handleDisabledOnClick(e) {
35 e.preventDefault();
36};
37
38var ListGroupItem = function ListGroupItem(props) {
39 var className = props.className,
40 Tag = props.tag,
41 active = props.active,
42 disabled = props.disabled,
43 action = props.action,
44 color = props.color,
45 attributes = _objectWithoutProperties(props, ['className', 'tag', 'active', 'disabled', 'action', 'color']);
46
47 var classes = (0, _classnames2.default)(className, active ? 'active' : false, disabled ? 'disabled' : false, action ? 'list-group-item-action' : false, color ? 'list-group-item-' + color : false, 'list-group-item');
48
49 // Prevent click event when disabled.
50 if (disabled) {
51 attributes.onClick = handleDisabledOnClick;
52 }
53 return _react2.default.createElement(Tag, _extends({}, attributes, { className: classes }));
54};
55
56ListGroupItem.propTypes = propTypes;
57ListGroupItem.defaultProps = defaultProps;
58
59exports.default = ListGroupItem;
\No newline at end of file