@uiw/react-native
Version:
UIW for React Native
153 lines (135 loc) • 15.6 kB
JavaScript
;
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; }
function MaybeTextOrView({
children,
...otherProps
}) {
if (typeof children === 'string' || children && children.type.displayName === 'Text') {
return <_reactNative.Text {...otherProps}>{children}</_reactNative.Text>;
}
return <_reactNative.View {...otherProps}>{children}</_reactNative.View>;
}
const styles = _reactNative.StyleSheet.create({
defalut: {},
checkBg: {
borderRadius: 999,
borderColor: 'rgb(189, 193, 204)',
borderWidth: 1,
justifyContent: 'center',
alignItems: 'center'
},
check: {
borderRadius: 999,
backgroundColor: '#4DD964'
},
touch: {
flexDirection: 'row',
alignItems: 'center'
},
label: {
marginLeft: 6
}
});
class Radio extends _react.Component {
constructor(props) {
super(props);
this.handlePress = event => {
const {
onPress
} = this.props;
this.setState({
checked: true
}, () => {
this.animatedStart(true);
onPress && onPress(event);
});
};
this.state = {
checked: props.checked,
sizeValue: new _reactNative.Animated.Value(0)
};
}
componentDidMount() {
// this.setState({
// checked: this.props.checked,
// });
this.animatedStart(this.props.checked);
}
UNSAFE_componentWillReceiveProps(nextProps) {
if (nextProps.checked !== this.props.checked) {
this.setState({
checked: nextProps.checked
}, () => {
this.animatedStart(nextProps.checked);
});
}
}
animatedStart(checked) {
if (checked) {
_reactNative.Animated.spring(this.state.sizeValue, {
toValue: this.props.thumbSize,
overshootClamping: true,
useNativeDriver: false
}).start();
} else {
_reactNative.Animated.spring(this.state.sizeValue, {
toValue: 0,
overshootClamping: true,
useNativeDriver: false
}).start();
}
}
render() {
const {
style,
color,
circleSize,
thumbSize,
disabled,
...otherProps
} = this.props;
const sizeValue = this.state.sizeValue.interpolate({
inputRange: [0, thumbSize],
outputRange: [0, thumbSize] // extrapolate: 'clamp',
});
const backgroundColor = disabled ? color : '#008EF0';
const borderColor = disabled ? color : '#bdc1cc';
return <_reactNative.View style={[styles.defalut, style]} {...otherProps}>
<_reactNative.TouchableOpacity disabled={disabled} style={[styles.touch]} onPress={this.handlePress}>
<_reactNative.Animated.View style={[styles.checkBg, {
width: circleSize,
height: circleSize,
borderColor
}]}>
<_reactNative.Animated.View style={[styles.check, {
width: sizeValue,
height: sizeValue,
backgroundColor
}]} />
</_reactNative.Animated.View>
{this.props.children && <MaybeTextOrView // eslint-disable-next-line react-native/no-inline-styles
style={[styles.label, {
opacity: disabled ? 0.3 : 1
}]}>
{this.props.children}
</MaybeTextOrView>}
</_reactNative.TouchableOpacity>
</_reactNative.View>;
}
}
exports.default = Radio;
Radio.defaultProps = {
checked: false,
circleSize: 20,
color: '#c3c5c7',
thumbSize: 12
};
module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Radio/index.tsx"],"names":["MaybeTextOrView","children","otherProps","type","displayName","styles","StyleSheet","create","defalut","checkBg","borderRadius","borderColor","borderWidth","justifyContent","alignItems","check","backgroundColor","touch","flexDirection","label","marginLeft","Radio","Component","constructor","props","handlePress","event","onPress","setState","checked","animatedStart","state","sizeValue","Animated","Value","componentDidMount","UNSAFE_componentWillReceiveProps","nextProps","spring","toValue","thumbSize","overshootClamping","useNativeDriver","start","render","style","color","circleSize","disabled","interpolate","inputRange","outputRange","width","height","opacity","defaultProps"],"mappings":"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","sourcesContent":["import React, { Component } from 'react';\nimport {\n  View,\n  ViewProps,\n  Animated,\n  Text,\n  TextProps,\n  TouchableOpacity,\n  GestureResponderEvent,\n  StyleSheet,\n} from 'react-native';\n\ninterface MaybeTextOrViewProps {\n  children?: React.ReactNode;\n}\n\nfunction MaybeTextOrView({ children, ...otherProps }: MaybeTextOrViewProps & TextProps & ViewProps) {\n  if (typeof children === 'string' || (children && (children as any).type.displayName === 'Text')) {\n    return <Text {...otherProps}>{children}</Text>;\n  }\n  return <View {...otherProps}>{children}</View>;\n}\n\nconst styles = StyleSheet.create({\n  defalut: {},\n  checkBg: {\n    borderRadius: 999,\n    borderColor: 'rgb(189, 193, 204)',\n    borderWidth: 1,\n    justifyContent: 'center',\n    alignItems: 'center',\n  },\n  check: {\n    borderRadius: 999,\n    backgroundColor: '#4DD964',\n  },\n  touch: {\n    flexDirection: 'row',\n    alignItems: 'center',\n  },\n  label: {\n    marginLeft: 6,\n  },\n});\n\nexport interface RadioProps extends ViewProps {\n  checked?: boolean;\n  disabled?: boolean;\n  circleSize?: number;\n  color?: string;\n  thumbSize?: number;\n  onPress?: (event: GestureResponderEvent) => void;\n}\n\nexport interface RadioState {\n  sizeValue: Animated.Value;\n  checked?: boolean;\n}\n\nexport default class Radio extends Component<RadioProps, RadioState> {\n  static defaultProps: RadioProps = {\n    checked: false,\n    circleSize: 20,\n    color: '#c3c5c7',\n    thumbSize: 12,\n  };\n  constructor(props: RadioProps) {\n    super(props);\n    this.state = {\n      checked: props.checked,\n      sizeValue: new Animated.Value(0),\n    };\n  }\n  componentDidMount() {\n    // this.setState({\n    //   checked: this.props.checked,\n    // });\n    this.animatedStart(this.props.checked);\n  }\n  UNSAFE_componentWillReceiveProps(nextProps: RadioProps) {\n    if (nextProps.checked !== this.props.checked) {\n      this.setState({ checked: nextProps.checked }, () => {\n        this.animatedStart(nextProps.checked);\n      });\n    }\n  }\n  animatedStart(checked?: boolean) {\n    if (checked) {\n      Animated.spring(this.state.sizeValue, {\n        toValue: this.props.thumbSize!,\n        overshootClamping: true,\n        useNativeDriver: false,\n      }).start();\n    } else {\n      Animated.spring(this.state.sizeValue, {\n        toValue: 0,\n        overshootClamping: true,\n        useNativeDriver: false,\n      }).start();\n    }\n  }\n  handlePress = (event: GestureResponderEvent) => {\n    const { onPress } = this.props;\n    this.setState({ checked: true }, () => {\n      this.animatedStart(true);\n      onPress && onPress(event);\n    });\n  };\n  render() {\n    const { style, color, circleSize, thumbSize, disabled, ...otherProps } = this.props;\n    const sizeValue = this.state.sizeValue.interpolate({\n      inputRange: [0, thumbSize!],\n      outputRange: [0, thumbSize!],\n      // extrapolate: 'clamp',\n    });\n    const backgroundColor = disabled ? color : '#008EF0';\n    const borderColor = disabled ? color : '#bdc1cc';\n    return (\n      <View style={[styles.defalut, style]} {...otherProps}>\n        <TouchableOpacity disabled={disabled} style={[styles.touch]} onPress={this.handlePress}>\n          <Animated.View style={[styles.checkBg, { width: circleSize, height: circleSize, borderColor }]}>\n            <Animated.View style={[styles.check, { width: sizeValue, height: sizeValue, backgroundColor }]} />\n          </Animated.View>\n          {this.props.children && (\n            <MaybeTextOrView\n              // eslint-disable-next-line react-native/no-inline-styles\n              style={[styles.label, { opacity: disabled ? 0.3 : 1 }]}\n            >\n              {this.props.children}\n            </MaybeTextOrView>\n          )}\n        </TouchableOpacity>\n      </View>\n    );\n  }\n}\n"]}