UNPKG

@pluve/ace

Version:

一套React版本的 Taro UI 组件库

49 lines 3.47 kB
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