UNPKG

@uiw/react-native

Version:
241 lines (221 loc) 24.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireDefault(require("react")); var _reactNative = require("react-native"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } class Switch extends _react.default.Component { constructor(props) { super(props); this.translateXValue = 2; this.height = 16; this.onPress = () => { const checked = !this.state.checked; this.setState({ checked }, () => { this.animatedStart(checked); this.props.onValueChange(checked); }); }; this.measureContainer = event => { const { checked } = this.state; const { translateXValue } = this.state; const { height: layoutHeight, width: layoutWidth } = event.nativeEvent.layout; const height = layoutHeight - 4; const width = height; const size = { width, height }; this.height = height / 2; const state = { containerSize: size }; this.translateXValue = layoutWidth - 2 - width; translateXValue.setValue(checked ? layoutWidth - 2 - width : 2); this.setState({ ...state }, () => { this.animatedStart(!!this.props.checked); }); }; this.state = { checked: !!this.props.checked, containerSize: { width: 0, height: 0 }, borderValue: new _reactNative.Animated.Value(0), translateXValue: new _reactNative.Animated.Value(2), bgOpacity: new _reactNative.Animated.Value(props.value ? 1 : 0) }; this.animatedStart(!!this.props.checked); } UNSAFE_componentWillReceiveProps(nextProps) { if (this.props.checked !== nextProps.checked) { this.setState({ checked: !!nextProps.checked }, () => { this.animatedStart(!!nextProps.checked); }); } } animatedStart(checked) { if (checked) { _reactNative.Animated.parallel([_reactNative.Animated.sequence([_reactNative.Animated.spring(this.state.borderValue, { toValue: this.height, overshootClamping: true, useNativeDriver: false }), _reactNative.Animated.spring(this.state.bgOpacity, { toValue: 1, overshootClamping: true, useNativeDriver: false })]), _reactNative.Animated.spring(this.state.translateXValue, { toValue: this.translateXValue, overshootClamping: true, useNativeDriver: false })]).start(); } else { _reactNative.Animated.parallel([_reactNative.Animated.sequence([_reactNative.Animated.spring(this.state.bgOpacity, { toValue: 0, overshootClamping: true, useNativeDriver: false }), _reactNative.Animated.spring(this.state.borderValue, { toValue: 2, overshootClamping: true, useNativeDriver: false })]), _reactNative.Animated.spring(this.state.translateXValue, { toValue: 2, overshootClamping: true, useNativeDriver: false })]).start(); } } render() { const { style, size, // eslint-disable-next-line @typescript-eslint/no-unused-vars checked, color, disabled, thumbColor, trackStyle, thumbStyle, ...otherProps } = this.props; const { containerSize } = this.state; const bgBorder = this.state.borderValue.interpolate({ inputRange: [2, this.height], outputRange: [2, this.height] // extrapolate: 'clamp', }); const sizeStyl = {}; switch (size) { case 'small': sizeStyl.height = 20; sizeStyl.width = 30; break; case 'large': sizeStyl.height = 30; sizeStyl.width = 48; break; default: sizeStyl.height = 26; sizeStyl.width = 38; break; } return <_reactNative.View {...otherProps} onLayout={this.measureContainer} style={[styles.warpper, sizeStyl, style]}> {disabled && <_reactNative.View style={[styles.position, styles.disabled]} />} <_reactNative.Animated.View style={[styles.bg, styles.position, trackStyle, { borderWidth: bgBorder }]} /> <_reactNative.TouchableOpacity // eslint-disable-next-line react-native/no-inline-styles style={[styles.position, { zIndex: 1 }]} onPress={this.onPress} /> <_reactNative.Animated.View style={[styles.position, // eslint-disable-next-line react-native/no-inline-styles { backgroundColor: this.state.checked ? color : '', borderRadius: 16, opacity: this.state.bgOpacity }]} /> <_reactNative.Animated.View style={[styles.grip, thumbStyle, disabled ? styles.shadowDisable : styles.shadow, { backgroundColor: thumbColor, width: containerSize.width, height: containerSize.height }, { transform: [{ translateX: this.state.translateXValue }] }]} /> </_reactNative.View>; } } exports.default = Switch; Switch.defaultProps = { checked: false, size: 'default', thumbColor: '#fff', color: '#4DD964', onValueChange: () => {} }; const styles = _reactNative.StyleSheet.create({ warpper: { position: 'relative', borderRadius: 16, backgroundColor: '#E6E6E6' }, disabled: { backgroundColor: 'rgba(255, 255, 255, 0.6)', borderRadius: 16, zIndex: 22 }, bg: { borderRadius: 16, borderWidth: 2, borderColor: '#E6E6E6' }, position: { position: 'absolute', backgroundColor: 'transparent', top: 0, bottom: 0, left: 0, right: 0 }, grip: { top: 2, borderRadius: 16 }, shadowDisable: { shadowColor: '#000', shadowOffset: { width: 10, height: 10 }, shadowOpacity: 0.3, shadowRadius: 2 }, shadow: { shadowColor: '#000', shadowOffset: { width: 4, height: 4 }, shadowOpacity: 0.2, shadowRadius: 3 } }); module.exports = exports.default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Switch/index.tsx"],"names":["Switch","React","Component","constructor","props","translateXValue","height","onPress","checked","state","setState","animatedStart","onValueChange","measureContainer","event","layoutHeight","width","layoutWidth","nativeEvent","layout","size","containerSize","setValue","borderValue","Animated","Value","bgOpacity","value","UNSAFE_componentWillReceiveProps","nextProps","parallel","sequence","spring","toValue","overshootClamping","useNativeDriver","start","render","style","color","disabled","thumbColor","trackStyle","thumbStyle","otherProps","bgBorder","interpolate","inputRange","outputRange","sizeStyl","styles","warpper","position","bg","borderWidth","zIndex","backgroundColor","borderRadius","opacity","grip","shadowDisable","shadow","transform","translateX","defaultProps","StyleSheet","create","borderColor","top","bottom","left","right","shadowColor","shadowOffset","shadowOpacity","shadowRadius"],"mappings":"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","sourcesContent":["import React from 'react';\nimport {\n  TouchableOpacity,\n  Animated,\n  SwitchProps as SwitchPropsDefault,\n  View,\n  ViewStyle,\n  LayoutChangeEvent,\n  StyleSheet,\n} from 'react-native';\n\nexport interface SwitchProps extends SwitchPropsDefault {\n  trackStyle?: ViewStyle;\n  thumbStyle?: ViewStyle;\n  checked?: boolean;\n  color?: string;\n  /**\n   * 设置大小\n   */\n  size?: 'small' | 'default' | 'large';\n}\n\nexport interface SwitchState {\n  checked: boolean;\n  borderValue: Animated.Value;\n  translateXValue: Animated.Value;\n  bgOpacity: Animated.Value;\n  containerSize: {\n    width: number;\n    height: number;\n  };\n}\n\nexport default class Switch extends React.Component<SwitchProps, SwitchState> {\n  translateXValue: number = 2;\n  height: number = 16;\n  static defaultProps: SwitchProps = {\n    checked: false,\n    size: 'default',\n    thumbColor: '#fff',\n    color: '#4DD964',\n    onValueChange: () => {},\n  };\n  constructor(props: SwitchProps) {\n    super(props);\n    this.state = {\n      checked: !!this.props.checked,\n      containerSize: { width: 0, height: 0 },\n      borderValue: new Animated.Value(0),\n      translateXValue: new Animated.Value(2),\n      bgOpacity: new Animated.Value(props.value ? 1 : 0),\n    };\n    this.animatedStart(!!this.props.checked);\n  }\n  UNSAFE_componentWillReceiveProps(nextProps: SwitchProps) {\n    if (this.props.checked !== nextProps.checked) {\n      this.setState({ checked: !!nextProps.checked }, () => {\n        this.animatedStart(!!nextProps.checked);\n      });\n    }\n  }\n  animatedStart(checked: boolean) {\n    if (checked) {\n      Animated.parallel([\n        Animated.sequence([\n          Animated.spring(this.state.borderValue, {\n            toValue: this.height,\n            overshootClamping: true,\n            useNativeDriver: false,\n          }),\n          Animated.spring(this.state.bgOpacity, {\n            toValue: 1,\n            overshootClamping: true,\n            useNativeDriver: false,\n          }),\n        ]),\n        Animated.spring(this.state.translateXValue, {\n          toValue: this.translateXValue,\n          overshootClamping: true,\n          useNativeDriver: false,\n        }),\n      ]).start();\n    } else {\n      Animated.parallel([\n        Animated.sequence([\n          Animated.spring(this.state.bgOpacity, {\n            toValue: 0,\n            overshootClamping: true,\n            useNativeDriver: false,\n          }),\n          Animated.spring(this.state.borderValue, {\n            toValue: 2,\n            overshootClamping: true,\n            useNativeDriver: false,\n          }),\n        ]),\n        Animated.spring(this.state.translateXValue, {\n          toValue: 2,\n          overshootClamping: true,\n          useNativeDriver: false,\n        }),\n      ]).start();\n    }\n  }\n  onPress = () => {\n    const checked = !this.state.checked;\n    this.setState({ checked }, () => {\n      this.animatedStart(checked);\n      this.props.onValueChange!(checked);\n    });\n  };\n  measureContainer = (event: LayoutChangeEvent) => {\n    const { checked } = this.state;\n    const { translateXValue } = this.state;\n    const { height: layoutHeight, width: layoutWidth } = event.nativeEvent.layout;\n    const height = layoutHeight - 4;\n    const width = height;\n    const size = { width, height };\n    this.height = height / 2;\n    const state = { containerSize: size };\n    this.translateXValue = layoutWidth - 2 - width;\n    translateXValue.setValue(checked ? layoutWidth - 2 - width : 2);\n    this.setState({ ...state }, () => {\n      this.animatedStart(!!this.props.checked);\n    });\n  };\n  render() {\n    const {\n      style,\n      size,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      checked,\n      color,\n      disabled,\n      thumbColor,\n      trackStyle,\n      thumbStyle,\n      ...otherProps\n    } = this.props;\n    const { containerSize } = this.state;\n    const bgBorder = this.state.borderValue.interpolate({\n      inputRange: [2, this.height],\n      outputRange: [2, this.height],\n      // extrapolate: 'clamp',\n    });\n    const sizeStyl: ViewStyle = {};\n    switch (size) {\n      case 'small':\n        sizeStyl.height = 20;\n        sizeStyl.width = 30;\n        break;\n      case 'large':\n        sizeStyl.height = 30;\n        sizeStyl.width = 48;\n        break;\n      default:\n        sizeStyl.height = 26;\n        sizeStyl.width = 38;\n        break;\n    }\n    return (\n      <View {...otherProps} onLayout={this.measureContainer} style={[styles.warpper, sizeStyl, style]}>\n        {disabled && <View style={[styles.position, styles.disabled]} />}\n        <Animated.View style={[styles.bg, styles.position, trackStyle, { borderWidth: bgBorder }]} />\n        <TouchableOpacity\n          // eslint-disable-next-line react-native/no-inline-styles\n          style={[styles.position, { zIndex: 1 }]}\n          onPress={this.onPress}\n        />\n        <Animated.View\n          style={[\n            styles.position,\n            // eslint-disable-next-line react-native/no-inline-styles\n            {\n              backgroundColor: this.state.checked ? color : '',\n              borderRadius: 16,\n              opacity: this.state.bgOpacity,\n            },\n          ]}\n        />\n        <Animated.View\n          style={[\n            styles.grip,\n            thumbStyle,\n            disabled ? styles.shadowDisable : styles.shadow,\n            {\n              backgroundColor: thumbColor,\n              width: containerSize.width,\n              height: containerSize.height,\n            },\n            {\n              transform: [{ translateX: this.state.translateXValue }],\n            },\n          ]}\n        />\n      </View>\n    );\n  }\n}\n\nconst styles = StyleSheet.create({\n  warpper: {\n    position: 'relative',\n    borderRadius: 16,\n    backgroundColor: '#E6E6E6',\n  },\n  disabled: {\n    backgroundColor: 'rgba(255, 255, 255, 0.6)',\n    borderRadius: 16,\n    zIndex: 22,\n  },\n  bg: {\n    borderRadius: 16,\n    borderWidth: 2,\n    borderColor: '#E6E6E6',\n  },\n  position: {\n    position: 'absolute',\n    backgroundColor: 'transparent',\n    top: 0,\n    bottom: 0,\n    left: 0,\n    right: 0,\n  },\n  grip: {\n    top: 2,\n    borderRadius: 16,\n  },\n  shadowDisable: {\n    shadowColor: '#000',\n    shadowOffset: {\n      width: 10,\n      height: 10,\n    },\n    shadowOpacity: 0.3,\n    shadowRadius: 2,\n  },\n  shadow: {\n    shadowColor: '#000',\n    shadowOffset: {\n      width: 4,\n      height: 4,\n    },\n    shadowOpacity: 0.2,\n    shadowRadius: 3,\n  },\n});\n"]}