@uiw/react-native
Version:
UIW for React Native
137 lines (118 loc) • 12 kB
JavaScript
;
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":";;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;;;AAae,MAAMA,YAAN,SAA2BC,eAAMC,SAAjC,CAA8D;AAAA;AAAA;AAAA,SAO3EC,KAP2E,GAO3D;AACdC,MAAAA,OAAO,EAAE,MADK;AAEdC,MAAAA,WAAW,EAAE,KAFC;AAGdC,MAAAA,eAAe,EAAE,IAAIC,sBAASC,KAAb,CAAmB,CAAnB,CAHH;AAIdC,MAAAA,UAAU,EAAE;AAJE,KAP2D;;AAAA,SAc3EC,aAd2E,GAc3D,MAAM;AACpB,YAAM;AAAEL,QAAAA;AAAF,UAAkB,KAAKF,KAA7B;AACA,WAAKQ,QAAL,CAAc;AACZN,QAAAA,WAAW,EAAE,CAACA,WADF;AAEZD,QAAAA,OAAO,EAAEC,WAAW,GAAG,MAAH,GAAY;AAFpB,OAAd;;AAIA,UAAIA,WAAJ,EAAiB;AACf,aAAKO,YAAL;AACD,OAFD,MAEO;AACL,aAAKC,YAAL;AACD;AACF,KAzB0E;;AAAA,SA2B3EA,YA3B2E,GA2B5D,MAAM;AACnBN,4BAASO,MAAT,CAAgB,KAAKX,KAAL,CAAWG,eAA3B,EAA4C;AAC1CS,QAAAA,OAAO,EAAE,CADiC;AAE1CC,QAAAA,QAAQ,EAAE,GAFgC;AAG1CC,QAAAA,eAAe,EAAE,KAHyB,CAGlB;;AAHkB,OAA5C,EAIGC,KAJH;AAKD,KAjC0E;;AAAA,SAmC3EN,YAnC2E,GAmC5D,MAAM;AACnB,WAAKD,QAAL,CAAc;AACZL,QAAAA,eAAe,EAAE,IAAIC,sBAASC,KAAb,CAAmB,CAAnB;AADL,OAAd;AAGD,KAvC0E;;AAAA,SAyC3EW,aAzC2E,GAyC1DC,KAAD,IAA8B;AAC5C,YAAM;AAAEC,QAAAA;AAAF,UAAaD,KAAK,CAACE,WAAN,CAAkBC,MAArC;AACA,WAAKZ,QAAL,CAAc;AACZF,QAAAA,UAAU,EAAEY;AADA,OAAd;AAGD,KA9C0E;AAAA;;AAgD3EG,EAAAA,MAAM,GAAG;AACP,UAAM;AAAEC,MAAAA,KAAF;AAASC,MAAAA,QAAT;AAAmBC,MAAAA,IAAnB;AAAyB,SAAGC;AAA5B,QAAyC,KAAKC,KAApD;AAEA,UAAM;AAAEzB,MAAAA,OAAF;AAAWE,MAAAA,eAAX;AAA4BG,MAAAA;AAA5B,QAA2C,KAAKN,KAAtD;AACA,WACE,mBAAM,MAAM,CAAC2B,MAAM,CAACC,OAAR,CAAZ;AACN,QAAQ,iBAAQ,IAAIH,QAAJ,CAAR,CAAsB,QAAQ,CAAC,KAAKlB,aAAN,CAA9B,CAAmD,KAAK,CAACiB,IAAD,CAAxD;AACR,UAAU,mBAAM,CAACF,KAAD,CAAO;AACvB,UAAU,eAAM,KAAK,CAACrB,OAAD,CAAX,CAAqB,KAAK,CAAC,EAAD,CAA1B;AACV,QAAQ;AACR,QAAQ;AAAC;AACT;AADQ;AAER,QAAQ,CAAC,sBAAS,IAAV,CACE,MAAM,CAAC,CACL0B,MAAM,CAACE,IADF,EAEL;AACA;AACEC,QAAAA,OAAO,EAAE3B,eADX;AAEEe,QAAAA,MAAM,EAAEf,eAAe,CAAC4B,WAAhB,CAA4B;AAClCC,UAAAA,UAAU,EAAE,CAAC,CAAD,EAAI,CAAJ,CADsB;AAElCC,UAAAA,WAAW,EAAE,CAAC,CAAD,EAAI3B,UAAU,IAAI,CAAlB;AAFqB,SAA5B,CAFV;AAME4B,QAAAA,GAAG,EAAEV,IAAI,KAAK,OAAT,GAAmB,EAAnB,GAAwBA,IAAI,KAAK,OAAT,GAAmB,EAAnB,GAAwB;AANvD,OAHK,CAAD,CADR;AAcR,UAAU,mBAAM,SAAS,CAAC,KAAKR,aAAN,CAAf,CAAoC,CAACO,QAAD,CAAU;AACxD,QAAQ,EAAE,sBAAS,IAAX;AACR,QAAQ;AAAC;AAAD;AACR,MAAM,oBAzBF;AA2BD;;AA/E0E;;;AAAxD1B,Y,CACZsC,Y,GAAkC;AACvCb,EAAAA,KAAK,EAAE;AADgC,C;AADtBzB,Y,CAKZuC,I;AA6ETvC,YAAY,CAACuC,IAAb,GAAoBA,aAApB;;AAEA,MAAMT,MAAM,GAAGU,wBAAWC,MAAX,CAAkB;AAC/BV,EAAAA,OAAO,EAAE,EADsB;AAE/BC,EAAAA,IAAI,EAAE;AACJU,IAAAA,QAAQ,EAAE,UADN;AAEJC,IAAAA,MAAM,EAAE,IAFJ;AAGJC,IAAAA,IAAI,EAAE,CAHF;AAIJC,IAAAA,KAAK,EAAE,CAJH;AAKJR,IAAAA,GAAG,EAAE,CALD;AAMJhB,IAAAA,MAAM,EAAE,GANJ;AAOJyB,IAAAA,SAAS,EAAE,EAPP;AAQJC,IAAAA,WAAW,EAAE,MART;AASJC,IAAAA,WAAW,EAAE,CATT;AAUJC,IAAAA,YAAY,EAAE,CAVV;AAWJC,IAAAA,eAAe,EAAE,MAXb;AAYJC,IAAAA,QAAQ,EAAE;AAZN;AAFyB,CAAlB,CAAf","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"]}