48 lines
1.8 KiB
JavaScript
48 lines
1.8 KiB
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
import classNames from 'classnames';
|
|
import React from 'react';
|
|
import { useBootstrapPrefix } from './ThemeProvider';
|
|
var DEVICE_SIZES = ['xl', 'lg', 'md', 'sm', 'xs'];
|
|
var Col = React.forwardRef( // Need to define the default "as" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595
|
|
function (_ref, ref) {
|
|
var bsPrefix = _ref.bsPrefix,
|
|
className = _ref.className,
|
|
_ref$as = _ref.as,
|
|
Component = _ref$as === void 0 ? 'div' : _ref$as,
|
|
props = _objectWithoutPropertiesLoose(_ref, ["bsPrefix", "className", "as"]);
|
|
|
|
var prefix = useBootstrapPrefix(bsPrefix, 'col');
|
|
var spans = [];
|
|
var classes = [];
|
|
DEVICE_SIZES.forEach(function (brkPoint) {
|
|
var propValue = props[brkPoint];
|
|
delete props[brkPoint];
|
|
var span, offset, order;
|
|
|
|
if (propValue != null && typeof propValue === 'object') {
|
|
var _propValue$span = propValue.span;
|
|
span = _propValue$span === void 0 ? true : _propValue$span;
|
|
offset = propValue.offset;
|
|
order = propValue.order;
|
|
} else {
|
|
span = propValue;
|
|
}
|
|
|
|
var infix = brkPoint !== 'xs' ? "-" + brkPoint : '';
|
|
if (span != null) spans.push(span === true ? "" + prefix + infix : "" + prefix + infix + "-" + span);
|
|
if (order != null) classes.push("order" + infix + "-" + order);
|
|
if (offset != null) classes.push("offset" + infix + "-" + offset);
|
|
});
|
|
|
|
if (!spans.length) {
|
|
spans.push(prefix); // plain 'col'
|
|
}
|
|
|
|
return React.createElement(Component, _extends({}, props, {
|
|
ref: ref,
|
|
className: classNames.apply(void 0, [className].concat(spans, classes))
|
|
}));
|
|
});
|
|
Col.displayName = 'Col';
|
|
export default Col; |