UNPKG

test-nut-ui

Version:

<p align="center"> <img alt="logo" src="https://img11.360buyimg.com/imagetools/jfs/t1/211965/25/7152/22022/61b16785E433119bb/aa41d7a9f7e823f3.png" width="150" style="margin-bottom: 10px;"> </p>

99 lines (98 loc) 4.26 kB
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties"; import _defineProperty from "@babel/runtime/helpers/defineProperty"; var _excluded = ["children", "zIndex", "duration", "className", "closeOnOverlayClick", "visible", "bgColor", "lockScroll", "style", "afterShow", "afterClose", "onClick"]; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function(sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), true).forEach(function(key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function(key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } import React__default, { useRef, useEffect } from "react"; import classNames from "classnames"; import { C as ComponentDefaults } from "./typings.js"; var defaultOverlayProps = _objectSpread(_objectSpread({}, ComponentDefaults), {}, { zIndex: 1e3, duration: 0.3, closeOnOverlayClick: true, visible: false, lockScroll: true, onClick: function onClick(event) { } }); var Overlay = function Overlay2(props) { var _defaultOverlayProps$ = _objectSpread(_objectSpread({}, defaultOverlayProps), props), children = _defaultOverlayProps$.children, zIndex = _defaultOverlayProps$.zIndex, duration = _defaultOverlayProps$.duration, className = _defaultOverlayProps$.className, closeOnOverlayClick = _defaultOverlayProps$.closeOnOverlayClick, visible = _defaultOverlayProps$.visible, bgColor = _defaultOverlayProps$.bgColor, lockScroll = _defaultOverlayProps$.lockScroll, style = _defaultOverlayProps$.style, afterShow = _defaultOverlayProps$.afterShow, afterClose = _defaultOverlayProps$.afterClose, onClick2 = _defaultOverlayProps$.onClick, rest = _objectWithoutProperties(_defaultOverlayProps$, _excluded); var classPrefix = "nut-overlay"; var renderRef = useRef(true); var intervalCloseRef = useRef(0); var intervalShowRef = useRef(0); useEffect(function() { if (visible) { intervalShowRef.current = window.setTimeout(function() { afterShow && afterShow(); }, duration * 1e3 * 0.8); } lock(); }, [visible]); useEffect(function() { return function() { clearTimeout(intervalCloseRef.current); clearTimeout(intervalShowRef.current); document.body.classList.remove("nut-overflow-hidden"); }; }, []); var classes = classNames({ "nut-overlay-fade-leave-active": !renderRef.current && !visible, "nut-overlay-fade-enter-active": visible, "nut-overlay-first-render": renderRef.current && !visible, "nut-overlay-hidden-render": !visible }, className, classPrefix); var styles = _objectSpread({ zIndex, animationDuration: "".concat(props.duration, "s") }, style); var lock = function lock2() { if (lockScroll && visible) { document.body.classList.add("nut-overflow-hidden"); } else { document.body.classList.remove("nut-overflow-hidden"); } }; var handleClick = function handleClick2(e) { if (closeOnOverlayClick) { onClick2 && onClick2(e); renderRef.current = false; intervalCloseRef.current = window.setTimeout(function() { afterClose && afterClose(); }, duration * 1e3 * 0.8); } }; return React__default.createElement(React__default.Fragment, null, React__default.createElement("div", _objectSpread(_objectSpread({ className: classes, style: _objectSpread(_objectSpread({}, styles), {}, { "--nutui-overlay-bg-color": bgColor }) }, rest), {}, { onClick: handleClick }), children)); }; Overlay.defaultProps = defaultOverlayProps; Overlay.displayName = "NutOverlay"; export { Overlay as O, defaultOverlayProps as d };