UNPKG

@helpscout/hsds-react

Version:

React component library for Help Scout's Design System

84 lines (61 loc) 2.83 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); exports.__esModule = true; 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 _Text = _interopRequireDefault(require("../Text")); var _classnames = _interopRequireDefault(require("classnames")); var _lodash = _interopRequireDefault(require("lodash.isstring")); var _Label = require("./Label.css"); var _jsxRuntime = require("react/jsx-runtime"); var Label = /*#__PURE__*/function (_React$PureComponent) { (0, _inheritsLoose2.default)(Label, _React$PureComponent); function Label() { return _React$PureComponent.apply(this, arguments) || this; } var _proto = Label.prototype; _proto.render = function render() { var _this$props = this.props, className = _this$props.className, children = _this$props.children, htmlFor = _this$props.for, isMarginless = _this$props.isMarginless, state = _this$props.state, rest = (0, _objectWithoutPropertiesLoose2.default)(_this$props, ["className", "children", "for", "isMarginless", "state"]); var componentClassName = (0, _classnames.default)('c-Label', isMarginless && 'is-marginless', state && "is-" + state, className); var contentMarkup = (0, _lodash.default)(children) ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_Text.default, { className: "c-Label__text", shade: "subtle", children: children }) : children; return /*#__PURE__*/(0, _jsxRuntime.jsx)(_Label.LabelUI, (0, _extends2.default)({}, (0, _getValidProps.default)(rest), { className: componentClassName, htmlFor: htmlFor, children: contentMarkup })); }; return Label; }(_react.default.PureComponent); Label.defaultProps = { 'data-cy': 'Label', isMarginless: false }; Label.propTypes = { /** Custom class names to be added to the component. */ className: _propTypes.default.string, /** Determines what the label is associated with. */ for: _propTypes.default.string, /** Changes the text color based on state. */ state: _propTypes.default.oneOf(['error', 'success', 'warning']), /** Remove bottom margin */ isMarginless: _propTypes.default.bool, /** Data attr for Cypress tests. */ 'data-cy': _propTypes.default.string }; var _default = Label; exports.default = _default;