UNPKG

@helpscout/hsds-react

Version:

React component library for Help Scout's Design System

107 lines (82 loc) 3.38 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); exports.__esModule = true; exports.default = exports.CloseButton = 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 _CloseButton = require("./CloseButton.css"); var _jsxRuntime = require("react/jsx-runtime"); function noop() {} var CloseButton = /*#__PURE__*/function (_React$PureComponent) { (0, _inheritsLoose2.default)(CloseButton, _React$PureComponent); function CloseButton() { return _React$PureComponent.apply(this, arguments) || this; } var _proto = CloseButton.prototype; _proto.renderIcon = function renderIcon() { var size = this.props.size; var isTiny = size === 'tiny'; var iconName = !isTiny ? 'cross-large' : 'cross-small'; return /*#__PURE__*/(0, _jsxRuntime.jsx)(_CloseButton.IconUI, { center: true, className: "c-CloseButton__icon", ignoreClick: true, name: iconName, title: "Close" }); }; _proto.render = function render() { var _this$props = this.props, children = _this$props.children, className = _this$props.className, innerRef = _this$props.innerRef, seamless = _this$props.seamless, size = _this$props.size, rest = (0, _objectWithoutPropertiesLoose2.default)(_this$props, ["children", "className", "innerRef", "seamless", "size"]); var componentClassName = (0, _classnames.default)('c-CloseButton', seamless && 'is-seamless', size && "is-" + size, className); return /*#__PURE__*/(0, _jsxRuntime.jsx)(_CloseButton.CloseButtonUI, (0, _extends2.default)({ "aria-label": "Close" }, (0, _getValidProps.default)(rest), { className: componentClassName, ref: innerRef, children: this.renderIcon() })); }; return CloseButton; }(_react.default.PureComponent); exports.CloseButton = CloseButton; CloseButton.defaultProps = { 'data-cy': 'CloseButton', innerRef: noop, onBlur: noop, onClick: noop, onFocus: noop, seamless: false, title: 'Close' }; CloseButton.propTypes = { /** Custom class names to be added to the component. */ className: _propTypes.default.string, children: _propTypes.default.any, innerRef: _propTypes.default.func, /** Callback when button is blurred. */ onBlur: _propTypes.default.func, /** Callback when button is clicked. */ onClick: _propTypes.default.func, /** Callback when button is focused. */ onFocus: _propTypes.default.func, /** Applies a seamless style to the component. */ seamless: _propTypes.default.bool, size: _propTypes.default.string, /** Custom title for the button. */ title: _propTypes.default.string, /** Data attr for Cypress tests. */ 'data-cy': _propTypes.default.string }; var _default = CloseButton; exports.default = _default;