UNPKG

@nutui/nutui-react

Version:

京东风格的轻量级移动端 React 组件库,支持一套代码生成 H5 和小程序

70 lines (69 loc) 2.78 kB
import { _ as _object_spread } from "@swc/helpers/_/_object_spread"; import { _ as _object_spread_props } from "@swc/helpers/_/_object_spread_props"; import { _ as _object_without_properties } from "@swc/helpers/_/_object_without_properties"; import { _ as _sliced_to_array } from "@swc/helpers/_/_sliced_to_array"; import React, { useEffect, useRef, useState } from "react"; import { CSSTransition } from "react-transition-group"; import classNames from "classnames"; import { ComponentDefaults } from "../../utils/typings"; import { useLockScroll } from "../../hooks/use-lock-scroll"; export var defaultOverlayProps = _object_spread_props(_object_spread({}, ComponentDefaults), { zIndex: 1000, duration: 300, closeOnOverlayClick: true, visible: false, lockScroll: true, onClick: function() {}, afterShow: function() {}, afterClose: function() {} }); export var Overlay = function(props) { var _ref = _object_spread({}, defaultOverlayProps, props), children = _ref.children, zIndex = _ref.zIndex, duration = _ref.duration, className = _ref.className, closeOnOverlayClick = _ref.closeOnOverlayClick, visible = _ref.visible, lockScroll = _ref.lockScroll, style = _ref.style, afterShow = _ref.afterShow, afterClose = _ref.afterClose, onClick = _ref.onClick, rest = _object_without_properties(_ref, [ "children", "zIndex", "duration", "className", "closeOnOverlayClick", "visible", "lockScroll", "style", "afterShow", "afterClose", "onClick" ]); var classPrefix = 'nut-overlay'; var _useState = _sliced_to_array(useState(visible), 2), innerVisible = _useState[0], setInnerVisible = _useState[1]; var nodeRef = useRef(null); useEffect(function() { setInnerVisible(visible); }, [ visible ]); var shouldLockScroll = !innerVisible ? false : lockScroll; useLockScroll(nodeRef, shouldLockScroll); var classes = classNames(classPrefix, className); var styles = _object_spread_props(_object_spread({}, style), { zIndex: zIndex }); var handleClick = function(e) { if (closeOnOverlayClick) { onClick && onClick(e); } }; return /*#__PURE__*/ React.createElement(CSSTransition, { nodeRef: nodeRef, classNames: "".concat(classPrefix, "-slide"), unmountOnExit: true, timeout: duration, in: innerVisible, onEntered: afterShow, onExited: afterClose }, /*#__PURE__*/ React.createElement("div", _object_spread_props(_object_spread({ ref: nodeRef, className: classes, style: styles }, rest), { onClick: handleClick }), children)); }; Overlay.displayName = 'NutOverlay';