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;