"use strict"; var _interopRequireWildcard = require("@babel/runtime-corejs2/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault"); exports.__esModule = true; exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/extends")); var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/objectWithoutPropertiesLoose")); var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/inheritsLoose")); var _classnames = _interopRequireDefault(require("classnames")); var _react = _interopRequireWildcard(require("react")); var _elementType = _interopRequireDefault(require("prop-types-extra/lib/elementType")); var _ListGroupItem = _interopRequireDefault(require("./ListGroupItem")); var _bootstrapUtils = require("./utils/bootstrapUtils"); var _ValidComponentChildren = _interopRequireDefault(require("./utils/ValidComponentChildren")); var propTypes = { /** * You can use a custom element type for this component. * * If not specified, it will be treated as `'li'` if every child is a * non-actionable ``, and `'div'` otherwise. */ componentClass: _elementType.default }; function getDefaultComponent(children) { if (!children) { // FIXME: This is the old behavior. Is this right? return 'div'; } if (_ValidComponentChildren.default.some(children, function (child) { return child.type !== _ListGroupItem.default || child.props.href || child.props.onClick; })) { return 'div'; } return 'ul'; } var ListGroup = /*#__PURE__*/ function (_React$Component) { (0, _inheritsLoose2.default)(ListGroup, _React$Component); function ListGroup() { return _React$Component.apply(this, arguments) || this; } var _proto = ListGroup.prototype; _proto.render = function render() { var _this$props = this.props, children = _this$props.children, _this$props$component = _this$props.componentClass, Component = _this$props$component === void 0 ? getDefaultComponent(children) : _this$props$component, className = _this$props.className, props = (0, _objectWithoutPropertiesLoose2.default)(_this$props, ["children", "componentClass", "className"]); var _splitBsProps = (0, _bootstrapUtils.splitBsProps)(props), bsProps = _splitBsProps[0], elementProps = _splitBsProps[1]; var classes = (0, _bootstrapUtils.getClassSet)(bsProps); var useListItem = Component === 'ul' && _ValidComponentChildren.default.every(children, function (child) { return child.type === _ListGroupItem.default; }); return _react.default.createElement(Component, (0, _extends2.default)({}, elementProps, { className: (0, _classnames.default)(className, classes) }), useListItem ? _ValidComponentChildren.default.map(children, function (child) { return (0, _react.cloneElement)(child, { listItem: true }); }) : children); }; return ListGroup; }(_react.default.Component); ListGroup.propTypes = propTypes; var _default = (0, _bootstrapUtils.bsClass)('list-group', ListGroup); exports.default = _default; module.exports = exports["default"];