123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- 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;
|