@uiw/react-native
Version:
UIW for React Native
241 lines (221 loc) • 24.8 kB
JavaScript
"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"]}