UNPKG

@helpscout/hsds-react

Version:

React component library for Help Scout's Design System

106 lines (80 loc) 3.6 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 _Animate = _interopRequireDefault(require("../Animate")); var _Overlay = _interopRequireDefault(require("../Overlay")); var _classnames = _interopRequireDefault(require("classnames")); var _jsxRuntime = require("react/jsx-runtime"); var ModalOverlay = /*#__PURE__*/function (_React$PureComponent) { (0, _inheritsLoose2.default)(ModalOverlay, _React$PureComponent); function ModalOverlay() { return _React$PureComponent.apply(this, arguments) || this; } var _proto = ModalOverlay.prototype; _proto.render = function render() { var _this$props = this.props, className = _this$props.className, children = _this$props.children, onClick = _this$props.onClick, isOpen = _this$props.isOpen, isHsApp = _this$props.isHsApp, overlayAnimationDelay = _this$props.overlayAnimationDelay, overlayAnimationDuration = _this$props.overlayAnimationDuration, overlayAnimationSequence = _this$props.overlayAnimationSequence, rest = (0, _objectWithoutPropertiesLoose2.default)(_this$props, ["className", "children", "onClick", "isOpen", "isHsApp", "overlayAnimationDelay", "overlayAnimationDuration", "overlayAnimationSequence"]); var componentClassName = (0, _classnames.default)('c-ModalOverlay', 'c-Modal__Overlay', // Legacy className); return /*#__PURE__*/(0, _jsxRuntime.jsx)(_Animate.default, { delay: overlayAnimationDelay, duration: overlayAnimationDuration, in: isOpen, sequence: overlayAnimationSequence, children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_Overlay.default, (0, _extends2.default)({}, (0, _getValidProps.default)(rest), { isHsApp: isHsApp, className: componentClassName, onClick: onClick, role: "presentation" })) }); }; return ModalOverlay; }(_react.default.PureComponent); function noop() {} ModalOverlay.defaultProps = { 'data-cy': 'ModalOverlay', onClick: noop, isOpen: true, isHsApp: false, overlayAnimationDelay: 0, overlayAnimationDuration: 200, overlayAnimationEasing: 'ease', overlayAnimationSequence: 'fade' }; ModalOverlay.propTypes = { /** Custom class names to be added to the component. */ className: _propTypes.default.string, /** Data attr for Cypress tests. */ 'data-cy': _propTypes.default.string, /** Callback on click */ onClick: _propTypes.default.func, isHsApp: _propTypes.default.bool, /** Shows/hides the component. */ isOpen: _propTypes.default.bool, /** Custom animation delay */ overlayAnimationDelay: _propTypes.default.number, /** Custom animation duration */ overlayAnimationDuration: _propTypes.default.number, /** Custom animation easing */ overlayAnimationEasing: _propTypes.default.string, /** Custom animation sequence */ overlayAnimationSequence: _propTypes.default.any }; var _default = ModalOverlay; exports.default = _default;