UNPKG

3.61 kBJavaScriptView Raw
1'use strict';
2
3exports.__esModule = true;
4
5var _extends3 = require('babel-runtime/helpers/extends');
6
7var _extends4 = _interopRequireDefault(_extends3);
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 _react = require('react');
30
31var _react2 = _interopRequireDefault(_react);
32
33var _propTypes = require('prop-types');
34
35var _propTypes2 = _interopRequireDefault(_propTypes);
36
37var _warning = require('warning');
38
39var _warning2 = _interopRequireDefault(_warning);
40
41var _bootstrapUtils = require('./utils/bootstrapUtils');
42
43function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
44
45// TODO: This should probably take a single `aspectRatio` prop.
46
47var propTypes = {
48 /**
49 * This component requires a single child element
50 */
51 children: _propTypes2.default.element.isRequired,
52 /**
53 * 16by9 aspect ratio
54 */
55 a16by9: _propTypes2.default.bool,
56 /**
57 * 4by3 aspect ratio
58 */
59 a4by3: _propTypes2.default.bool
60};
61
62var defaultProps = {
63 a16by9: false,
64 a4by3: false
65};
66
67var ResponsiveEmbed = function (_React$Component) {
68 (0, _inherits3.default)(ResponsiveEmbed, _React$Component);
69
70 function ResponsiveEmbed() {
71 (0, _classCallCheck3.default)(this, ResponsiveEmbed);
72 return (0, _possibleConstructorReturn3.default)(this, _React$Component.apply(this, arguments));
73 }
74
75 ResponsiveEmbed.prototype.render = function render() {
76 var _extends2;
77
78 var _props = this.props,
79 a16by9 = _props.a16by9,
80 a4by3 = _props.a4by3,
81 className = _props.className,
82 children = _props.children,
83 props = (0, _objectWithoutProperties3.default)(_props, ['a16by9', 'a4by3', 'className', 'children']);
84
85 var _splitBsProps = (0, _bootstrapUtils.splitBsProps)(props),
86 bsProps = _splitBsProps[0],
87 elementProps = _splitBsProps[1];
88
89 process.env.NODE_ENV !== 'production' ? (0, _warning2.default)(a16by9 || a4by3, 'Either `a16by9` or `a4by3` must be set.') : void 0;
90 process.env.NODE_ENV !== 'production' ? (0, _warning2.default)(!(a16by9 && a4by3), 'Only one of `a16by9` or `a4by3` can be set.') : void 0;
91
92 var classes = (0, _extends4.default)({}, (0, _bootstrapUtils.getClassSet)(bsProps), (_extends2 = {}, _extends2[(0, _bootstrapUtils.prefix)(bsProps, '16by9')] = a16by9, _extends2[(0, _bootstrapUtils.prefix)(bsProps, '4by3')] = a4by3, _extends2));
93
94 return _react2.default.createElement(
95 'div',
96 { className: (0, _classnames2.default)(classes) },
97 (0, _react.cloneElement)(children, (0, _extends4.default)({}, elementProps, {
98 className: (0, _classnames2.default)(className, (0, _bootstrapUtils.prefix)(bsProps, 'item'))
99 }))
100 );
101 };
102
103 return ResponsiveEmbed;
104}(_react2.default.Component);
105
106ResponsiveEmbed.propTypes = propTypes;
107ResponsiveEmbed.defaultProps = defaultProps;
108
109exports.default = (0, _bootstrapUtils.bsClass)('embed-responsive', ResponsiveEmbed);
110module.exports = exports['default'];
\No newline at end of file