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
JavaScript
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
};