UNPKG

3.11 kBJavaScriptView Raw
1'use strict';
2
3exports.__esModule = true;
4
5var _extends2 = require('babel-runtime/helpers/extends');
6
7var _extends3 = _interopRequireDefault(_extends2);
8
9var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
10
11var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
12
13var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
14
15var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
16
17var _inherits2 = require('babel-runtime/helpers/inherits');
18
19var _inherits3 = _interopRequireDefault(_inherits2);
20
21var _propTypes = require('prop-types');
22
23var _propTypes2 = _interopRequireDefault(_propTypes);
24
25var _react = require('react');
26
27var _react2 = _interopRequireDefault(_react);
28
29var _classnames = require('classnames');
30
31var _classnames2 = _interopRequireDefault(_classnames);
32
33var _bootstrapUtils = require('./utils/bootstrapUtils');
34
35var _PanelCollapse = require('./PanelCollapse');
36
37var _PanelCollapse2 = _interopRequireDefault(_PanelCollapse);
38
39function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
40
41var propTypes = {
42 /**
43 * A convenience prop that renders a Collapse component around the Body for
44 * situations when the parent Panel only contains a single Panel.Body child.
45 *
46 * renders:
47 * ```jsx
48 * <Panel.Collapse>
49 * <Panel.Body />
50 * </Panel.Collapse>
51 * ```
52 */
53 collapsible: _propTypes2.default.bool.isRequired
54};
55
56var defaultProps = {
57 collapsible: false
58};
59
60var contextTypes = {
61 $bs_panel: _propTypes2.default.shape({
62 bsClass: _propTypes2.default.string
63 })
64};
65
66var PanelBody = function (_React$Component) {
67 (0, _inherits3.default)(PanelBody, _React$Component);
68
69 function PanelBody() {
70 (0, _classCallCheck3.default)(this, PanelBody);
71 return (0, _possibleConstructorReturn3.default)(this, _React$Component.apply(this, arguments));
72 }
73
74 PanelBody.prototype.render = function render() {
75 var _props = this.props,
76 children = _props.children,
77 className = _props.className,
78 collapsible = _props.collapsible;
79
80 var _ref = this.context.$bs_panel || {},
81 _bsClass = _ref.bsClass;
82
83 var _splitBsPropsAndOmit = (0, _bootstrapUtils.splitBsPropsAndOmit)(this.props, ['collapsible']),
84 bsProps = _splitBsPropsAndOmit[0],
85 elementProps = _splitBsPropsAndOmit[1];
86
87 bsProps.bsClass = _bsClass || bsProps.bsClass;
88
89 var body = _react2.default.createElement(
90 'div',
91 (0, _extends3.default)({}, elementProps, { className: (0, _classnames2.default)(className, (0, _bootstrapUtils.prefix)(bsProps, 'body')) }),
92 children
93 );
94
95 if (collapsible) {
96 body = _react2.default.createElement(
97 _PanelCollapse2.default,
98 null,
99 body
100 );
101 }
102
103 return body;
104 };
105
106 return PanelBody;
107}(_react2.default.Component);
108
109PanelBody.propTypes = propTypes;
110PanelBody.defaultProps = defaultProps;
111PanelBody.contextTypes = contextTypes;
112
113exports.default = (0, _bootstrapUtils.bsClass)('panel', PanelBody);
114module.exports = exports['default'];
\No newline at end of file