UNPKG

3.35 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 _bootstrapUtils = require('./utils/bootstrapUtils');
30
31var _Collapse = require('./Collapse');
32
33var _Collapse2 = _interopRequireDefault(_Collapse);
34
35function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
36
37var propTypes = {
38 /**
39 * Callback fired before the component expands
40 */
41 onEnter: _propTypes2.default.func,
42 /**
43 * Callback fired after the component starts to expand
44 */
45 onEntering: _propTypes2.default.func,
46 /**
47 * Callback fired after the component has expanded
48 */
49 onEntered: _propTypes2.default.func,
50 /**
51 * Callback fired before the component collapses
52 */
53 onExit: _propTypes2.default.func,
54 /**
55 * Callback fired after the component starts to collapse
56 */
57 onExiting: _propTypes2.default.func,
58 /**
59 * Callback fired after the component has collapsed
60 */
61 onExited: _propTypes2.default.func
62};
63
64var contextTypes = {
65 $bs_panel: _propTypes2.default.shape({
66 headingId: _propTypes2.default.string,
67 bodyId: _propTypes2.default.string,
68 bsClass: _propTypes2.default.string,
69 expanded: _propTypes2.default.bool
70 })
71};
72
73var PanelCollapse = function (_React$Component) {
74 (0, _inherits3.default)(PanelCollapse, _React$Component);
75
76 function PanelCollapse() {
77 (0, _classCallCheck3.default)(this, PanelCollapse);
78 return (0, _possibleConstructorReturn3.default)(this, _React$Component.apply(this, arguments));
79 }
80
81 PanelCollapse.prototype.render = function render() {
82 var children = this.props.children;
83
84 var _ref = this.context.$bs_panel || {},
85 headingId = _ref.headingId,
86 bodyId = _ref.bodyId,
87 _bsClass = _ref.bsClass,
88 expanded = _ref.expanded;
89
90 var _splitBsProps = (0, _bootstrapUtils.splitBsProps)(this.props),
91 bsProps = _splitBsProps[0],
92 props = _splitBsProps[1];
93
94 bsProps.bsClass = _bsClass || bsProps.bsClass;
95
96 if (headingId && bodyId) {
97 props.id = bodyId;
98 props.role = props.role || 'tabpanel';
99 props['aria-labelledby'] = headingId;
100 }
101
102 return _react2.default.createElement(
103 _Collapse2.default,
104 (0, _extends3.default)({ 'in': expanded }, props),
105 _react2.default.createElement(
106 'div',
107 { className: (0, _bootstrapUtils.prefix)(bsProps, 'collapse') },
108 children
109 )
110 );
111 };
112
113 return PanelCollapse;
114}(_react2.default.Component);
115
116PanelCollapse.propTypes = propTypes;
117PanelCollapse.contextTypes = contextTypes;
118
119exports.default = (0, _bootstrapUtils.bsClass)('panel', PanelCollapse);
120module.exports = exports['default'];
\No newline at end of file