UNPKG

3.39 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 _propTypes = require('prop-types');
30
31var _propTypes2 = _interopRequireDefault(_propTypes);
32
33var _react = require('react');
34
35var _react2 = _interopRequireDefault(_react);
36
37var _elementType = require('react-prop-types/lib/elementType');
38
39var _elementType2 = _interopRequireDefault(_elementType);
40
41var _bootstrapUtils = require('./utils/bootstrapUtils');
42
43var _PanelToggle = require('./PanelToggle');
44
45var _PanelToggle2 = _interopRequireDefault(_PanelToggle);
46
47function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
48
49var propTypes = {
50 componentClass: _elementType2.default,
51 /**
52 * A convenience prop that renders the Panel.Title as a panel collapse toggle component
53 * for the common use-case.
54 */
55 toggle: _propTypes2.default.bool
56};
57
58var contextTypes = {
59 $bs_panel: _propTypes2.default.shape({
60 bsClass: _propTypes2.default.string
61 })
62};
63
64var defaultProps = {
65 componentClass: 'div'
66};
67
68var PanelTitle = function (_React$Component) {
69 (0, _inherits3.default)(PanelTitle, _React$Component);
70
71 function PanelTitle() {
72 (0, _classCallCheck3.default)(this, PanelTitle);
73 return (0, _possibleConstructorReturn3.default)(this, _React$Component.apply(this, arguments));
74 }
75
76 PanelTitle.prototype.render = function render() {
77 var _props = this.props,
78 children = _props.children,
79 className = _props.className,
80 toggle = _props.toggle,
81 Component = _props.componentClass,
82 props = (0, _objectWithoutProperties3.default)(_props, ['children', 'className', 'toggle', 'componentClass']);
83
84 var _ref = this.context.$bs_panel || {},
85 _bsClass = _ref.bsClass;
86
87 var _splitBsProps = (0, _bootstrapUtils.splitBsProps)(props),
88 bsProps = _splitBsProps[0],
89 elementProps = _splitBsProps[1];
90
91 bsProps.bsClass = _bsClass || bsProps.bsClass;
92
93 if (toggle) {
94 children = _react2.default.createElement(
95 _PanelToggle2.default,
96 null,
97 children
98 );
99 }
100
101 return _react2.default.createElement(
102 Component,
103 (0, _extends3.default)({}, elementProps, {
104 className: (0, _classnames2.default)(className, (0, _bootstrapUtils.prefix)(bsProps, 'title'))
105 }),
106 children
107 );
108 };
109
110 return PanelTitle;
111}(_react2.default.Component);
112
113PanelTitle.propTypes = propTypes;
114PanelTitle.defaultProps = defaultProps;
115PanelTitle.contextTypes = contextTypes;
116
117exports.default = (0, _bootstrapUtils.bsClass)('panel', PanelTitle);
118module.exports = exports['default'];
\No newline at end of file