@uiw/react-native
Version:
UIW for React Native
148 lines (122 loc) • 14.1 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _reactNative = require("react-native");
var _MaskLayer = _interopRequireDefault(require("../MaskLayer"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
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; }
var _default = (props = {}) => {
const {
onClosed,
visible,
children,
placement = 'bottom',
...otherProps
} = props;
const [display] = (0, _react.useState)('none');
let [layoutHeight, setLayoutHeight] = (0, _react.useState)(0);
let [layoutWidth, setLayoutWidth] = (0, _react.useState)(0);
const [translateValue] = (0, _react.useState)(new _reactNative.Animated.Value(0));
const isVertical = /^(top|bottom)$/.test(placement);
const isHorizontal = /^(left|right)$/.test(placement);
function onDismiss() {
onClosed && onClosed();
}
function measureContainer(event) {
const {
height,
width
} = event.nativeEvent.layout;
if (!layoutHeight && isVertical) {
setLayoutHeight(height);
}
if (!layoutWidth && isHorizontal) {
setLayoutWidth(width);
}
}
function getTransformSize() {
if (placement === 'top') {
return -layoutHeight;
}
if (placement === 'bottom') {
return layoutHeight;
}
if (placement === 'left') {
return -layoutWidth;
}
if (placement === 'right') {
return layoutWidth;
}
return 0;
}
(0, _react.useMemo)(() => {
if (visible && (layoutHeight !== 0 || layoutWidth !== 0)) {
translateValue.setValue(getTransformSize());
_reactNative.Animated.parallel([_reactNative.Animated.spring(translateValue, {
toValue: 0,
overshootClamping: true,
useNativeDriver: true
})]).start();
} else if (layoutHeight !== 0 || layoutWidth !== 0) {
_reactNative.Animated.parallel([_reactNative.Animated.spring(translateValue, {
toValue: getTransformSize(),
overshootClamping: true,
useNativeDriver: true
})]).start();
} // eslint-disable-next-line react-hooks/exhaustive-deps
}, [visible, layoutHeight]);
const translateStyle = {};
if (isVertical) {
translateStyle.translateY = translateValue;
}
if (isHorizontal) {
translateStyle.translateX = translateValue;
}
const child = <_reactNative.Animated.View onLayout={measureContainer} style={[styles.content, placement && styles[placement], !layoutHeight && isVertical ? {
display: display
} : {}, !layoutWidth && isHorizontal ? {
display: display
} : {}, // // getTransformStyle(),
{
transform: [translateStyle]
}]}>
{children}
</_reactNative.Animated.View>;
return <_MaskLayer.default {...otherProps} visible={visible} onDismiss={onDismiss}>
{child}
</_MaskLayer.default>;
};
exports.default = _default;
const styles = _reactNative.StyleSheet.create({
content: {
backgroundColor: '#fff',
position: 'absolute',
zIndex: 9999
},
top: {
top: 0,
left: 0,
right: 0
},
bottom: {
bottom: 0,
left: 0,
right: 0
},
left: {
bottom: 0,
top: 0,
left: 0
},
right: {
bottom: 0,
top: 0,
right: 0
}
});
module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Modal/index.tsx"],"names":["props","onClosed","visible","children","placement","otherProps","display","layoutHeight","setLayoutHeight","layoutWidth","setLayoutWidth","translateValue","Animated","Value","isVertical","test","isHorizontal","onDismiss","measureContainer","event","height","width","nativeEvent","layout","getTransformSize","setValue","parallel","spring","toValue","overshootClamping","useNativeDriver","start","translateStyle","translateY","translateX","child","styles","content","transform","StyleSheet","create","backgroundColor","position","zIndex","top","left","right","bottom"],"mappings":"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","sourcesContent":["import React, { useState, useMemo } from 'react';\nimport { Animated, StyleSheet, LayoutChangeEvent } from 'react-native';\nimport MaskLayer, { MaskLayerProps } from '../MaskLayer';\n\nexport interface ModalProps extends MaskLayerProps {\n  placement?: 'top' | 'right' | 'bottom' | 'left';\n  onClosed?: () => void;\n}\n\nexport default (props: ModalProps = {}) => {\n  const { onClosed, visible, children, placement = 'bottom', ...otherProps } = props;\n  const [display] = useState<'none' | 'flex'>('none');\n  let [layoutHeight, setLayoutHeight] = useState(0);\n  let [layoutWidth, setLayoutWidth] = useState(0);\n  const [translateValue] = useState(new Animated.Value(0));\n  const isVertical = /^(top|bottom)$/.test(placement);\n  const isHorizontal = /^(left|right)$/.test(placement);\n  function onDismiss() {\n    onClosed && onClosed();\n  }\n  function measureContainer(event: LayoutChangeEvent) {\n    const { height, width } = event.nativeEvent.layout;\n    if (!layoutHeight && isVertical) {\n      setLayoutHeight(height);\n    }\n    if (!layoutWidth && isHorizontal) {\n      setLayoutWidth(width);\n    }\n  }\n  function getTransformSize() {\n    if (placement === 'top') {\n      return -layoutHeight;\n    }\n    if (placement === 'bottom') {\n      return layoutHeight;\n    }\n    if (placement === 'left') {\n      return -layoutWidth;\n    }\n    if (placement === 'right') {\n      return layoutWidth;\n    }\n    return 0;\n  }\n  useMemo(() => {\n    if (visible && (layoutHeight !== 0 || layoutWidth !== 0)) {\n      translateValue.setValue(getTransformSize());\n      Animated.parallel([\n        Animated.spring(translateValue, {\n          toValue: 0,\n          overshootClamping: true,\n          useNativeDriver: true,\n        }),\n      ]).start();\n    } else if (layoutHeight !== 0 || layoutWidth !== 0) {\n      Animated.parallel([\n        Animated.spring(translateValue, {\n          toValue: getTransformSize(),\n          overshootClamping: true,\n          useNativeDriver: true,\n        }),\n      ]).start();\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [visible, layoutHeight]);\n  const translateStyle = {} as {\n    translateY: Animated.Value;\n    translateX: Animated.Value;\n  };\n  if (isVertical) {\n    translateStyle.translateY = translateValue;\n  }\n  if (isHorizontal) {\n    translateStyle.translateX = translateValue;\n  }\n  const child = (\n    <Animated.View\n      onLayout={measureContainer}\n      style={[\n        styles.content,\n        placement && styles[placement],\n        !layoutHeight && isVertical ? { display: display } : {},\n        !layoutWidth && isHorizontal ? { display: display } : {},\n        // // getTransformStyle(),\n        { transform: [translateStyle] },\n      ]}\n    >\n      {children}\n    </Animated.View>\n  );\n  return (\n    <MaskLayer {...otherProps} visible={visible} onDismiss={onDismiss}>\n      {child}\n    </MaskLayer>\n  );\n};\n\nconst styles = StyleSheet.create({\n  content: {\n    backgroundColor: '#fff',\n    position: 'absolute',\n    zIndex: 9999,\n  },\n  top: {\n    top: 0,\n    left: 0,\n    right: 0,\n  },\n  bottom: {\n    bottom: 0,\n    left: 0,\n    right: 0,\n  },\n  left: {\n    bottom: 0,\n    top: 0,\n    left: 0,\n  },\n  right: {\n    bottom: 0,\n    top: 0,\n    right: 0,\n  },\n});\n"]}