@pluve/ace
Version:
一套React版本的 Taro UI 组件库
49 lines • 3.47 kB
JavaScript
import React, { useEffect, useState, useRef } from 'react';
import { View } from '@tarojs/components';
const closeIcon =
// eslint-disable-next-line max-len
'';
const Container = ({ children, visible = false }) => {
return visible ? React.createElement(View, null, children) : null;
};
const Popup = ({ title = '', bodyClassName = '', visible: inputVisible = false, maskClosable = true, onClose, children, topRightView, }) => {
const [cut, setCut] = useState('');
const [visible, setVisible] = useState(false);
const timerRef = useRef(null);
const selfOnClose = () => {
setCut('leave');
if (timerRef.current) {
clearTimeout(timerRef.current);
timerRef.current = null;
}
timerRef.current = setTimeout(() => {
setVisible(false);
if (onClose) {
onClose();
}
}, 300);
};
const onMaskClick = () => {
if (maskClosable) {
selfOnClose();
}
};
useEffect(() => {
setVisible(inputVisible);
if (inputVisible) {
setCut('enter');
}
return () => {
setCut('');
};
}, [inputVisible]);
return (React.createElement(Container, { visible: visible },
React.createElement(View, { className: `ace-popup ${cut ? `ace-popup__${cut}` : ''}` },
React.createElement(View, { onClick: onMaskClick, className: "ace-popup-mask" }),
React.createElement(View, { className: "ace-popup-container" },
topRightView ? (React.createElement(View, { className: "ace-popup-right-view" }, topRightView)) : (React.createElement(View, { onClick: selfOnClose, className: "ace-popup-close", style: { backgroundImage: `url(${closeIcon})` } })),
title && React.createElement(View, { className: "ace-popup-title" }, title),
React.createElement(View, { className: `ace-popup-body ${bodyClassName}` }, children)))));
};
export default Popup;
//# sourceMappingURL=index.js.map