UNPKG

@uiw/react-native

Version:
107 lines (93 loc) 13.2 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _reactNative = require("react-native"); var _utils = require("../utils"); function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } const styles = _reactNative.StyleSheet.create({ position: { position: 'absolute', backgroundColor: 'transparent', top: 0, bottom: 0, left: 0, right: 0, zIndex: 9998 }, backdrop: { backgroundColor: '#000' }, content: { backgroundColor: '#fff', position: 'absolute' } }); var _default = (props = {}) => { const { maskClosable = true, children, // eslint-disable-next-line @typescript-eslint/no-unused-vars visible: _vis, opacity = 0.6, onDismiss, animatedParallelShow = [], animatedParallelHide = [], ...otherProps } = props; const [visible, setVisible] = (0, _react.useState)(!!props.visible); const preVisible = (0, _utils.usePrevious)(props.visible); const [visibleModal, setVisibleModal] = (0, _react.useState)(false); const [bgOpacity] = (0, _react.useState)(new _reactNative.Animated.Value(0)); (0, _react.useMemo)(() => { if (preVisible !== props.visible && props.visible) { setVisible(!!props.visible); setVisibleModal(false); _reactNative.Animated.parallel([_reactNative.Animated.spring(bgOpacity, { toValue: opacity, overshootClamping: true, useNativeDriver: true }), ...animatedParallelShow]).start(); } else if (preVisible !== props.visible && !props.visible) { _reactNative.Animated.parallel([_reactNative.Animated.spring(bgOpacity, { toValue: 0, overshootClamping: true, useNativeDriver: true }), ...animatedParallelHide]).start(() => { setVisible(!!props.visible); setVisibleModal(true); }); } // eslint-disable-next-line react-hooks/exhaustive-deps }, [props.visible]); const backdropContent = <_reactNative.Animated.View style={[styles.position, styles.backdrop, { opacity: bgOpacity }]} />; let backdrop = <_reactNative.TouchableOpacity activeOpacity={1} style={[styles.position]} onPress={() => onDismiss && onDismiss()}> {backdropContent} </_reactNative.TouchableOpacity>; let isTrue = visible || false; if (!visible && visibleModal) { isTrue = false; } return <_reactNative.Modal transparent={true} animationType="none" {...otherProps} visible={isTrue}> {maskClosable ? backdrop : backdropContent} {children && _react.default.Children.toArray(children).map(child => { if (!_react.default.isValidElement(child)) { return; } return _react.default.cloneElement(child, { ...child.props, ...{ style: [{ zIndex: 9999 }, child.props.style] } }); })} </_reactNative.Modal>; }; exports.default = _default; module.exports = exports.default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/MaskLayer/index.tsx"],"names":["styles","StyleSheet","create","position","backgroundColor","top","bottom","left","right","zIndex","backdrop","content","props","maskClosable","children","visible","_vis","opacity","onDismiss","animatedParallelShow","animatedParallelHide","otherProps","setVisible","preVisible","visibleModal","setVisibleModal","bgOpacity","Animated","Value","parallel","spring","toValue","overshootClamping","useNativeDriver","start","backdropContent","isTrue","React","Children","toArray","map","child","isValidElement","cloneElement","style"],"mappings":"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","sourcesContent":["import React, { useState, useMemo } from 'react';\nimport { Modal, ModalProps as RNModalProps, Animated, TouchableOpacity, StyleSheet } from 'react-native';\nimport { usePrevious } from '../utils';\n\nconst styles = StyleSheet.create({\n  position: {\n    position: 'absolute',\n    backgroundColor: 'transparent',\n    top: 0,\n    bottom: 0,\n    left: 0,\n    right: 0,\n    zIndex: 9998,\n  },\n  backdrop: {\n    backgroundColor: '#000',\n  },\n  content: {\n    backgroundColor: '#fff',\n    position: 'absolute',\n  },\n});\n\nexport interface MaskLayerProps extends RNModalProps {\n  /**\n   * 遮罩层是否禁止点击\n   * defult: `true`\n   */\n  maskClosable?: boolean;\n  /**\n   * 是否隐藏\n   */\n  visible?: boolean;\n  /**\n   * 遮罩层透明度\n   * defult: `0.6`\n   */\n  opacity?: number;\n  /**\n   * 隐藏消除回调事件\n   */\n  onDismiss?: () => void;\n  animatedParallelShow?: Animated.CompositeAnimation[];\n  animatedParallelHide?: Animated.CompositeAnimation[];\n  children?: JSX.Element;\n}\n\nexport default (props: MaskLayerProps = {}) => {\n  const {\n    maskClosable = true,\n    children,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    visible: _vis,\n    opacity = 0.6,\n    onDismiss,\n    animatedParallelShow = [],\n    animatedParallelHide = [],\n    ...otherProps\n  } = props;\n  const [visible, setVisible] = useState(!!props.visible);\n  const preVisible = usePrevious<boolean | undefined>(props.visible);\n  const [visibleModal, setVisibleModal] = useState(false);\n  const [bgOpacity] = useState(new Animated.Value(0));\n  useMemo(() => {\n    if (preVisible !== props.visible && props.visible) {\n      setVisible(!!props.visible);\n      setVisibleModal(false);\n      Animated.parallel([\n        Animated.spring(bgOpacity, {\n          toValue: opacity,\n          overshootClamping: true,\n          useNativeDriver: true,\n        }),\n        ...animatedParallelShow,\n      ]).start();\n    } else if (preVisible !== props.visible && !props.visible) {\n      Animated.parallel([\n        Animated.spring(bgOpacity, {\n          toValue: 0,\n          overshootClamping: true,\n          useNativeDriver: true,\n        }),\n        ...animatedParallelHide,\n      ]).start(() => {\n        setVisible(!!props.visible);\n        setVisibleModal(true);\n      });\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [props.visible]);\n  const backdropContent = <Animated.View style={[styles.position, styles.backdrop, { opacity: bgOpacity }]} />;\n  let backdrop = (\n    <TouchableOpacity activeOpacity={1} style={[styles.position]} onPress={() => onDismiss && onDismiss()}>\n      {backdropContent}\n    </TouchableOpacity>\n  );\n  let isTrue = visible || false;\n  if (!visible && visibleModal) {\n    isTrue = false;\n  }\n  return (\n    <Modal transparent={true} animationType=\"none\" {...otherProps} visible={isTrue}>\n      {maskClosable ? backdrop : backdropContent}\n      {children &&\n        React.Children.toArray(children).map((child) => {\n          if (!React.isValidElement(child)) {\n            return;\n          }\n          return React.cloneElement(child, {\n            ...child.props,\n            ...{ style: [{ zIndex: 9999 }, child.props.style] },\n          });\n        })}\n    </Modal>\n  );\n};\n"]}