UNPKG

@uiw/react-native

Version:
137 lines (118 loc) 12 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireDefault(require("react")); var _reactNative = require("react-native"); var _item = _interopRequireDefault(require("./item")); var _Button = _interopRequireDefault(require("../Button")); var _Icon = _interopRequireDefault(require("../Icon")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } class MenuDropdown extends _react.default.Component { constructor(...args) { super(...args); this.state = { btnIcon: 'down', visibleMenu: false, listHeightValue: new _reactNative.Animated.Value(0), listHeight: 0 }; this.handleonPress = () => { const { visibleMenu } = this.state; this.setState({ visibleMenu: !visibleMenu, btnIcon: visibleMenu ? 'down' : 'up' }); if (visibleMenu) { this.animateClose(); } else { this.animateStart(); } }; this.animateStart = () => { _reactNative.Animated.timing(this.state.listHeightValue, { toValue: 1, duration: 500, useNativeDriver: false // 动画值在不同的驱动方式之间是不能兼容的。因此如果你在某个动画中启用了原生驱动,那么所有和此动画依赖相同动画值的其他动画也必须启用原生驱动。 }).start(); }; this.animateClose = () => { this.setState({ listHeightValue: new _reactNative.Animated.Value(0) }); }; this.menuContainer = event => { const { height } = event.nativeEvent.layout; this.setState({ listHeight: height }); }; } render() { const { title, children, size, ...btnProps } = this.props; const { btnIcon, listHeightValue, listHeight } = this.state; return <_reactNative.View style={styles.menuBox}> <_Button.default {...btnProps} onPress={this.handleonPress} size={size}> <_reactNative.Text>{title}</_reactNative.Text> <_Icon.default name={btnIcon} size={17} /> </_Button.default> { /* { visibleMenu && */ } <_reactNative.Animated.View style={[styles.list, // eslint-disable-next-line react-native/no-inline-styles { opacity: listHeightValue, height: listHeightValue.interpolate({ inputRange: [0, 1], outputRange: [0, listHeight || 5] }), top: size === 'large' ? 35 : size === 'small' ? 21 : 30 }]}> <_reactNative.View onLayout={this.menuContainer}>{children}</_reactNative.View> </_reactNative.Animated.View> { /* } */ } </_reactNative.View>; } } exports.default = MenuDropdown; MenuDropdown.defaultProps = { title: '菜单' }; MenuDropdown.Item = void 0; MenuDropdown.Item = _item.default; const styles = _reactNative.StyleSheet.create({ menuBox: {}, list: { position: 'absolute', zIndex: 1000, left: 0, right: 0, top: 0, height: 100, marginTop: 10, borderColor: '#ddd', borderWidth: 1, borderRadius: 1, backgroundColor: '#fff', overflow: 'hidden' } }); module.exports = exports.default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/MenuDropdown/index.tsx"],"names":["MenuDropdown","React","Component","state","btnIcon","visibleMenu","listHeightValue","Animated","Value","listHeight","handleonPress","setState","animateClose","animateStart","timing","toValue","duration","useNativeDriver","start","menuContainer","event","height","nativeEvent","layout","render","title","children","size","btnProps","props","styles","menuBox","list","opacity","interpolate","inputRange","outputRange","top","defaultProps","Item","StyleSheet","create","position","zIndex","left","right","marginTop","borderColor","borderWidth","borderRadius","backgroundColor","overflow"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { View, StyleSheet, Text, Animated, LayoutChangeEvent, Easing } from 'react-native';\nimport Item from './item';\nimport Button, { ButtonProps } from '../Button';\nimport Icon, { IconsName } from '../Icon';\n\nexport interface MenuDropdownProps extends ButtonProps {\n  title: string;\n}\n\ninterface IState {\n  btnIcon: IconsName;\n  visibleMenu: Boolean;\n  listHeightValue: Animated.Value;\n  listHeight: number;\n}\n\nexport default class MenuDropdown extends React.Component<MenuDropdownProps> {\n  static defaultProps: MenuDropdownProps = {\n    title: '菜单',\n  };\n\n  static Item: typeof Item;\n\n  state: IState = {\n    btnIcon: 'down',\n    visibleMenu: false,\n    listHeightValue: new Animated.Value(0),\n    listHeight: 0,\n  };\n\n  handleonPress = () => {\n    const { visibleMenu } = this.state;\n    this.setState({\n      visibleMenu: !visibleMenu,\n      btnIcon: visibleMenu ? 'down' : 'up',\n    });\n    if (visibleMenu) {\n      this.animateClose();\n    } else {\n      this.animateStart();\n    }\n  };\n\n  animateStart = () => {\n    Animated.timing(this.state.listHeightValue, {\n      toValue: 1,\n      duration: 500,\n      useNativeDriver: false, // 动画值在不同的驱动方式之间是不能兼容的。因此如果你在某个动画中启用了原生驱动，那么所有和此动画依赖相同动画值的其他动画也必须启用原生驱动。\n    }).start();\n  };\n\n  animateClose = () => {\n    this.setState({\n      listHeightValue: new Animated.Value(0),\n    });\n  };\n\n  menuContainer = (event: LayoutChangeEvent) => {\n    const { height } = event.nativeEvent.layout;\n    this.setState({\n      listHeight: height,\n    });\n  };\n\n  render() {\n    const { title, children, size, ...btnProps } = this.props;\n\n    const { btnIcon, listHeightValue, listHeight } = this.state;\n    return (\n      <View style={styles.menuBox}>\n        <Button {...btnProps} onPress={this.handleonPress} size={size}>\n          <Text>{title}</Text>\n          <Icon name={btnIcon} size={17} />\n        </Button>\n        {/* {\n        visibleMenu && */}\n        <Animated.View\n          style={[\n            styles.list,\n            // eslint-disable-next-line react-native/no-inline-styles\n            {\n              opacity: listHeightValue,\n              height: listHeightValue.interpolate({\n                inputRange: [0, 1],\n                outputRange: [0, listHeight || 5],\n              }),\n              top: size === 'large' ? 35 : size === 'small' ? 21 : 30,\n            },\n          ]}\n        >\n          <View onLayout={this.menuContainer}>{children}</View>\n        </Animated.View>\n        {/* } */}\n      </View>\n    );\n  }\n}\n\nMenuDropdown.Item = Item;\n\nconst styles = StyleSheet.create({\n  menuBox: {},\n  list: {\n    position: 'absolute',\n    zIndex: 1000,\n    left: 0,\n    right: 0,\n    top: 0,\n    height: 100,\n    marginTop: 10,\n    borderColor: '#ddd',\n    borderWidth: 1,\n    borderRadius: 1,\n    backgroundColor: '#fff',\n    overflow: 'hidden',\n  },\n});\n"]}