@uiw/react-native
Version:
UIW for React Native
239 lines (207 loc) • 23.7 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _reactNative = require("react-native");
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 DEVICE_WIDTH = _reactNative.Dimensions.get('window').width;
const DEVICE_HEIGHT = _reactNative.Dimensions.get('window').height;
class Drawer extends _react.Component {
constructor(props) {
super(props);
this.onOverlayClick = e => {
const {
maskClosable
} = this.props;
if (!maskClosable) {
return false;
}
e.stopPropagation();
this.closeDrawer();
};
this.state = {
zIndexValue: 0,
overlayValue: new _reactNative.Animated.Value(0),
drawerValue: new _reactNative.Animated.ValueXY({ ...this.getInitPosition()
})
};
}
componentDidMount() {
if (this.props.isOpen) {
this.openDrawer();
}
}
UNSAFE_componentWillReceiveProps(nextProps) {
if (nextProps.isOpen !== this.props.isOpen) {
this.handleDrawer(!!nextProps.isOpen);
}
}
render() {
const {
isOpen,
style,
drawerWidth,
drawerBackgroundColor,
maskProps,
placement,
drawerHeight
} = this.props;
const {
drawerValue,
overlayValue,
zIndexValue
} = this.state;
const isTopOrBottom = placement === 'top' || placement === 'bottom';
const changeStyle = isTopOrBottom ? 'height' : 'width';
const dynamicDrawerStyles = {
backgroundColor: drawerBackgroundColor
};
if (isTopOrBottom) {
dynamicDrawerStyles.top = placement === 'top' ? 0 : null;
dynamicDrawerStyles.bottom = placement === 'bottom' ? 0 : null;
dynamicDrawerStyles.height = drawerWidth;
dynamicDrawerStyles.width = '100%';
} else {
dynamicDrawerStyles.left = placement === 'left' ? 0 : null;
dynamicDrawerStyles.right = placement === 'right' ? 0 : null;
dynamicDrawerStyles.width = drawerWidth;
}
const overlayOpacity = overlayValue.interpolate({
inputRange: [0, 1],
outputRange: [0, 0.3],
extrapolate: 'clamp'
});
return <_react.Fragment>
<_reactNative.Animated.View style={[styles.drawer, dynamicDrawerStyles, style, // eslint-disable-next-line react-native/no-inline-styles
{
[changeStyle]: isOpen ? isTopOrBottom ? drawerHeight : drawerWidth : 0,
transform: [{
translateX: drawerValue.x
}, // x轴移动
{
translateY: drawerValue.y
} // y轴移动
]
}]}>
{this.props.children}
</_reactNative.Animated.View>
<_reactNative.Animated.View pointerEvents={isOpen ? 'auto' : 'none'} style={[styles.overlay, styles.positionFull, maskProps, {
// opacity: overlayValue,
opacity: overlayOpacity,
zIndex: zIndexValue
}]}>
<_reactNative.TouchableOpacity style={[styles.positionFull, // eslint-disable-next-line react-native/no-inline-styles
{
zIndex: 3003,
position: 'absolute'
}]} onPress={this.onOverlayClick.bind(this)} />
</_reactNative.Animated.View>
</_react.Fragment>;
}
handleDrawer(isOpen) {
isOpen ? this.openDrawer() : this.closeDrawer();
}
getInitPosition() {
const {
drawerWidth,
placement,
drawerHeight
} = this.props;
const xy = {
x: 0,
y: 0
};
if (placement === 'left') {
xy.x = -(drawerWidth || 0);
}
if (placement === 'right') {
xy.x = DEVICE_WIDTH || 0;
}
if (placement === 'top') {
xy.y = -(drawerHeight || 0);
}
if (placement === 'bottom') {
xy.y = DEVICE_HEIGHT || 0;
}
return xy;
}
openDrawer() {
this.setState({
zIndexValue: 3002
});
_reactNative.Animated.parallel([_reactNative.Animated.spring(this.state.drawerValue, {
toValue: {
x: 0,
y: 0
},
overshootClamping: true,
useNativeDriver: true
}), _reactNative.Animated.spring(this.state.overlayValue, {
toValue: 0.7,
overshootClamping: true,
useNativeDriver: true
})]).start(() => {
this.props.openDrawer(true);
this.props.onChange(true);
});
}
closeDrawer() {
const {
drawerValue,
overlayValue
} = this.state;
_reactNative.Animated.parallel([_reactNative.Animated.spring(drawerValue, {
toValue: { ...this.getInitPosition()
},
overshootClamping: true,
useNativeDriver: true
}), _reactNative.Animated.spring(overlayValue, {
toValue: 0,
overshootClamping: true,
useNativeDriver: true
})]).start(() => {
this.props.closeDrawer(false);
this.props.onChange(false);
this.setState({
zIndexValue: 0
});
});
}
}
exports.default = Drawer;
Drawer.defaultProps = {
placement: 'left',
drawerBackgroundColor: '#fff',
drawerWidth: 300,
drawerHeight: 500,
maskClosable: true,
isOpen: false,
onChange: () => null,
openDrawer: () => null,
closeDrawer: () => null
};
const styles = _reactNative.StyleSheet.create({
drawer: {
position: 'absolute',
top: 0,
bottom: 0,
flex: 1,
zIndex: 3004
},
positionFull: {
position: 'absolute',
top: 0,
bottom: 0,
left: 0,
right: 0
},
overlay: {
backgroundColor: '#000',
zIndex: 3002
}
});
module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Drawer/index.tsx"],"names":["DEVICE_WIDTH","Dimensions","get","width","DEVICE_HEIGHT","height","Drawer","Component","constructor","props","onOverlayClick","e","maskClosable","stopPropagation","closeDrawer","state","zIndexValue","overlayValue","Animated","Value","drawerValue","ValueXY","getInitPosition","componentDidMount","isOpen","openDrawer","UNSAFE_componentWillReceiveProps","nextProps","handleDrawer","render","style","drawerWidth","drawerBackgroundColor","maskProps","placement","drawerHeight","isTopOrBottom","changeStyle","dynamicDrawerStyles","backgroundColor","top","bottom","left","right","overlayOpacity","interpolate","inputRange","outputRange","extrapolate","styles","drawer","transform","translateX","x","translateY","y","children","overlay","positionFull","opacity","zIndex","position","bind","xy","setState","parallel","spring","toValue","overshootClamping","useNativeDriver","start","onChange","defaultProps","StyleSheet","create","flex"],"mappings":"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","sourcesContent":["import React, { Component, Fragment } from 'react';\nimport {\n  Animated,\n  StyleSheet,\n  TouchableOpacity,\n  ViewProps,\n  ViewStyle,\n  Dimensions,\n  GestureResponderEvent,\n} from 'react-native';\n\nconst DEVICE_WIDTH = Dimensions.get('window').width;\nconst DEVICE_HEIGHT = Dimensions.get('window').height;\n\nexport interface DrawerProps extends ViewProps {\n  isOpen?: boolean;\n  maskClosable?: boolean;\n  placement?: 'right' | 'left' | 'top' | 'bottom';\n  drawerWidth?: number;\n  drawerHeight?: number;\n  maskProps?: ViewStyle;\n  drawerBackgroundColor?: string;\n  onChange?: (isOpen: boolean) => void;\n  openDrawer?: (isOpen: boolean) => void;\n  closeDrawer?: (isOpen: boolean) => void;\n}\nexport interface DrawerState {\n  drawerValue: Animated.ValueXY;\n  overlayValue: Animated.Value;\n  zIndexValue: number;\n}\n\nexport default class Drawer extends Component<DrawerProps, DrawerState> {\n  static defaultProps = {\n    placement: 'left',\n    drawerBackgroundColor: '#fff',\n    drawerWidth: 300,\n    drawerHeight: 500,\n    maskClosable: true,\n    isOpen: false,\n    onChange: () => null,\n    openDrawer: () => null,\n    closeDrawer: () => null,\n  };\n  constructor(props: DrawerProps) {\n    super(props);\n    this.state = {\n      zIndexValue: 0,\n      overlayValue: new Animated.Value(0),\n      drawerValue: new Animated.ValueXY({ ...this.getInitPosition() }),\n    };\n  }\n  componentDidMount() {\n    if (this.props.isOpen) {\n      this.openDrawer();\n    }\n  }\n  UNSAFE_componentWillReceiveProps(nextProps: DrawerProps) {\n    if (nextProps.isOpen !== this.props.isOpen) {\n      this.handleDrawer(!!nextProps.isOpen);\n    }\n  }\n  onOverlayClick = (e: GestureResponderEvent) => {\n    const { maskClosable } = this.props;\n    if (!maskClosable) {\n      return false;\n    }\n    e.stopPropagation();\n    this.closeDrawer();\n  };\n  render() {\n    const { isOpen, style, drawerWidth, drawerBackgroundColor, maskProps, placement, drawerHeight } = this.props;\n    const { drawerValue, overlayValue, zIndexValue } = this.state;\n    const isTopOrBottom = placement === 'top' || placement === 'bottom';\n    const changeStyle = isTopOrBottom ? 'height' : 'width';\n    const dynamicDrawerStyles: any = {\n      backgroundColor: drawerBackgroundColor,\n    };\n\n    if (isTopOrBottom) {\n      dynamicDrawerStyles.top = placement === 'top' ? 0 : null;\n      dynamicDrawerStyles.bottom = placement === 'bottom' ? 0 : null;\n      dynamicDrawerStyles.height = drawerWidth;\n      dynamicDrawerStyles.width = '100%';\n    } else {\n      dynamicDrawerStyles.left = placement === 'left' ? 0 : null;\n      dynamicDrawerStyles.right = placement === 'right' ? 0 : null;\n      dynamicDrawerStyles.width = drawerWidth;\n    }\n\n    const overlayOpacity = overlayValue.interpolate({\n      inputRange: [0, 1],\n      outputRange: [0, 0.3],\n      extrapolate: 'clamp',\n    });\n    return (\n      <Fragment>\n        <Animated.View\n          style={[\n            styles.drawer,\n            dynamicDrawerStyles,\n            style,\n            // eslint-disable-next-line react-native/no-inline-styles\n            {\n              [changeStyle]: isOpen ? (isTopOrBottom ? drawerHeight : drawerWidth) : 0,\n              transform: [\n                { translateX: drawerValue.x }, // x轴移动\n                { translateY: drawerValue.y }, // y轴移动\n              ],\n            },\n          ]}\n        >\n          {this.props.children}\n        </Animated.View>\n        <Animated.View\n          pointerEvents={isOpen ? 'auto' : 'none'}\n          style={[\n            styles.overlay,\n            styles.positionFull,\n            maskProps,\n            {\n              // opacity: overlayValue,\n              opacity: overlayOpacity,\n              zIndex: zIndexValue,\n            },\n          ]}\n        >\n          <TouchableOpacity\n            style={[\n              styles.positionFull,\n              // eslint-disable-next-line react-native/no-inline-styles\n              {\n                zIndex: 3003,\n                position: 'absolute',\n              },\n            ]}\n            onPress={this.onOverlayClick.bind(this)}\n          />\n        </Animated.View>\n      </Fragment>\n    );\n  }\n  handleDrawer(isOpen: boolean) {\n    isOpen ? this.openDrawer() : this.closeDrawer();\n  }\n  getInitPosition() {\n    const { drawerWidth, placement, drawerHeight } = this.props;\n    const xy = { x: 0, y: 0 };\n    if (placement === 'left') {\n      xy.x = -(drawerWidth || 0);\n    }\n    if (placement === 'right') {\n      xy.x = DEVICE_WIDTH || 0;\n    }\n    if (placement === 'top') {\n      xy.y = -(drawerHeight || 0);\n    }\n    if (placement === 'bottom') {\n      xy.y = DEVICE_HEIGHT || 0;\n    }\n    return xy;\n  }\n  openDrawer() {\n    this.setState({ zIndexValue: 3002 });\n    Animated.parallel([\n      Animated.spring(this.state.drawerValue, {\n        toValue: { x: 0, y: 0 },\n        overshootClamping: true,\n        useNativeDriver: true,\n      }),\n      Animated.spring(this.state.overlayValue, {\n        toValue: 0.7,\n        overshootClamping: true,\n        useNativeDriver: true,\n      }),\n    ]).start(() => {\n      this.props.openDrawer!(true);\n      this.props.onChange!(true);\n    });\n  }\n  closeDrawer() {\n    const { drawerValue, overlayValue } = this.state;\n    Animated.parallel([\n      Animated.spring(drawerValue, {\n        toValue: { ...this.getInitPosition() },\n        overshootClamping: true,\n        useNativeDriver: true,\n      }),\n      Animated.spring(overlayValue, {\n        toValue: 0,\n        overshootClamping: true,\n        useNativeDriver: true,\n      }),\n    ]).start(() => {\n      this.props.closeDrawer!(false);\n      this.props.onChange!(false);\n      this.setState({ zIndexValue: 0 });\n    });\n  }\n}\n\nconst styles = StyleSheet.create({\n  drawer: {\n    position: 'absolute',\n    top: 0,\n    bottom: 0,\n    flex: 1,\n    zIndex: 3004,\n  },\n  positionFull: {\n    position: 'absolute',\n    top: 0,\n    bottom: 0,\n    left: 0,\n    right: 0,\n  },\n  overlay: {\n    backgroundColor: '#000',\n    zIndex: 3002,\n  },\n});\n"]}