UNPKG

@helpscout/hsds-react

Version:

React component library for Help Scout's Design System

86 lines (62 loc) 2.73 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); exports.__esModule = true; exports.variantClassNames = variantClassNames; exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose")); var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/inheritsLoose")); var _react = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _getValidProps = _interopRequireDefault(require("@helpscout/react-utils/dist/getValidProps")); var _classnames = _interopRequireDefault(require("classnames")); var _GridCol = require("./Grid.Col.css"); var _jsxRuntime = require("react/jsx-runtime"); var GridCol = /*#__PURE__*/function (_React$PureComponent) { (0, _inheritsLoose2.default)(GridCol, _React$PureComponent); function GridCol() { return _React$PureComponent.apply(this, arguments) || this; } var _proto = GridCol.prototype; _proto.render = function render() { var _this$props = this.props, className = _this$props.className, children = _this$props.children, size = _this$props.size, rest = (0, _objectWithoutPropertiesLoose2.default)(_this$props, ["className", "children", "size"]); var sizeClassName = size ? variantClassNames('is', size) : null; var componentClassName = (0, _classnames.default)('c-Col', sizeClassName, className); return /*#__PURE__*/(0, _jsxRuntime.jsx)(_GridCol.ColUI, (0, _extends2.default)({}, (0, _getValidProps.default)(rest), { className: componentClassName, children: children })); }; return GridCol; }(_react.default.PureComponent); GridCol.defaultProps = { 'data-cy': 'GridCol' }; GridCol.propTypes = { /** Custom class names to be added to the component. */ className: _propTypes.default.string, /** Adds fluid styles to the component. */ isFluid: _propTypes.default.bool, /** Adds responsive styles to the component. */ isResponsive: _propTypes.default.bool, /** Column size */ size: _propTypes.default.string, /** Data attr for Cypress tests. */ 'data-cy': _propTypes.default.string }; function variantClassNames(className, variant) { if (variant === void 0) { variant = ''; } if (typeof className !== 'string' || !className.length) return ''; if (variant && typeof variant !== 'string') return className; return variant.trim().split(/[ ,]+/).map(function (o) { return className + "-" + o; }).join(' '); } var _default = GridCol; exports.default = _default;