芝麻web文件管理V1.00
编辑当前文件:/home/freeclou/app.optimyar.com/backend/node_modules/reactstrap/src/Col.js
import React from 'react'; import PropTypes from 'prop-types'; import classNames from 'classnames'; import { mapToCssModules, tagPropType, isObject } from './utils'; const colWidths = ['xs', 'sm', 'md', 'lg', 'xl']; const stringOrNumberProp = PropTypes.oneOfType([PropTypes.number, PropTypes.string]); const columnProps = PropTypes.oneOfType([ PropTypes.bool, PropTypes.number, PropTypes.string, PropTypes.shape({ size: PropTypes.oneOfType([PropTypes.bool, PropTypes.number, PropTypes.string]), order: stringOrNumberProp, offset: stringOrNumberProp }) ]); const propTypes = { tag: tagPropType, xs: columnProps, sm: columnProps, md: columnProps, lg: columnProps, xl: columnProps, className: PropTypes.string, cssModule: PropTypes.object, widths: PropTypes.array, }; const defaultProps = { tag: 'div', widths: colWidths, }; const getColumnSizeClass = (isXs, colWidth, colSize) => { if (colSize === true || colSize === '') { return isXs ? 'col' : `col-${colWidth}`; } else if (colSize === 'auto') { return isXs ? 'col-auto' : `col-${colWidth}-auto`; } return isXs ? `col-${colSize}` : `col-${colWidth}-${colSize}`; }; const Col = (props) => { const { className, cssModule, widths, tag: Tag, ...attributes } = props; const colClasses = []; widths.forEach((colWidth, i) => { let columnProp = props[colWidth]; delete attributes[colWidth]; if (!columnProp && columnProp !== '') { return; } const isXs = !i; if (isObject(columnProp)) { const colSizeInterfix = isXs ? '-' : `-${colWidth}-`; const colClass = getColumnSizeClass(isXs, colWidth, columnProp.size); colClasses.push(mapToCssModules(classNames({ [colClass]: columnProp.size || columnProp.size === '', [`order${colSizeInterfix}${columnProp.order}`]: columnProp.order || columnProp.order === 0, [`offset${colSizeInterfix}${columnProp.offset}`]: columnProp.offset || columnProp.offset === 0 }), cssModule)); } else { const colClass = getColumnSizeClass(isXs, colWidth, columnProp); colClasses.push(colClass); } }); if (!colClasses.length) { colClasses.push('col'); } const classes = mapToCssModules(classNames( className, colClasses ), cssModule); return (
); }; Col.propTypes = propTypes; Col.defaultProps = defaultProps; export default Col;