UNPKG

@uiw/react-native

Version:
357 lines (312 loc) 41.7 kB
"use strict"; 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; } const TRACK_SIZE = 4; const THUMB_SIZE = 20; const DEFAULT_ANIMATION_CONFIGS = { spring: { friction: 7, tension: 100 }, timing: { duration: 150, easing: _reactNative.Easing.inOut(_reactNative.Easing.ease), delay: 0 } }; const getBoundedValue = ({ value, maxValue, minValue }) => value > maxValue ? maxValue : value < minValue ? minValue : value; class Slider extends _react.Component { constructor(props) { super(props); this.panResponder = void 0; this._previousLeft = 0; this.getCurrentValue = () => this.state.value.__getValue(); this.handlePanResponderGrant = () => { if (this.props.disabled) { return; } this._previousLeft = this.getThumbLeft(this.getCurrentValue()); this.props.onSlidingStart(this.getCurrentValue()); }; this.handlePanResponderEnd = () => { if (this.props.disabled) { return; } this.props.onSlidingComplete(this.getCurrentValue()); }; this.handlePanResponderMove = (_, gestureState) => { if (this.props.disabled) { return; } const value = this.getValue(gestureState); this.state.value.setValue(value); this.props.onChange(this.getCurrentValue()); }; this.measureContainer = event => this.handleMeasure('containerSize', event); this.measureThumb = event => this.handleMeasure('thumbSize', event); this.state = { containerSize: { width: 0, height: 0 }, trackSize: { width: 0, height: 0 }, thumbSize: props.thumbSize || { width: 0, height: 0 }, value: new _reactNative.Animated.Value(getBoundedValue(props)) }; this.panResponder = _reactNative.PanResponder.create({ onPanResponderTerminationRequest: () => false, onStartShouldSetPanResponder: () => true, onStartShouldSetPanResponderCapture: () => true, onMoveShouldSetPanResponder: () => false, onPanResponderGrant: this.handlePanResponderGrant, onPanResponderMove: this.handlePanResponderMove, onPanResponderRelease: this.handlePanResponderEnd, onPanResponderTerminate: this.handlePanResponderEnd }); } componentDidUpdate(prevProps) { const newValue = getBoundedValue(this.props); if (prevProps.value !== newValue) { if (this.props.animateTransitions) { this.setCurrentValueAnimated(newValue); } else { this.setCurrentValue(newValue); } } } setCurrentValue(value) { this.state.value.setValue(value); } setCurrentValueAnimated(value) { const { animationType } = this.props; if (!animationType) { return; } const animationConfig = Object.assign({}, DEFAULT_ANIMATION_CONFIGS[animationType], this.props.animationConfig, { toValue: value }); _reactNative.Animated[animationType](this.state.value, animationConfig).start(); } getThumbLeft(value) { const ratio = (value - this.props.minValue) / (this.props.maxValue - this.props.minValue); return ratio * (this.state.containerSize.width - this.state.thumbSize.width); } getValue(gestureState) { const { vertical, minValue, maxValue } = this.props; const length = this.state.containerSize.width - this.state.thumbSize.width; const thumbLeft = this._previousLeft + (vertical ? gestureState.dy : gestureState.dx); const ratio = thumbLeft / length; if (this.props.step) { return Math.max(minValue, Math.min(maxValue, minValue + Math.round(ratio * (maxValue - minValue) / this.props.step) * this.props.step)); } return Math.max(minValue, Math.min(maxValue, ratio * (maxValue - minValue) + minValue)); } handleMeasure(name, event) { const { width: layoutWidth, height: layoutHeight } = event.nativeEvent.layout; const { vertical } = this.props; const { containerSize, trackSize, thumbSize } = this.state; const width = vertical ? layoutHeight : layoutWidth; const height = vertical ? layoutWidth : layoutHeight; const size = { width, height }; const state = { containerSize, trackSize, thumbSize }; if (state[name]) { state[name] = size; } this.setState({ ...state }); } getMinimumTrackStyles(thumbStart) { const { thumbSize, trackSize } = this.state; const minimumTrackStyle = { position: 'absolute' }; if (this.props.vertical) { minimumTrackStyle.height = _reactNative.Animated.add(thumbStart, thumbSize.height / 2); minimumTrackStyle.marginLeft = -trackSize.width; } else { minimumTrackStyle.width = _reactNative.Animated.add(thumbStart, thumbSize.width / 2); minimumTrackStyle.marginTop = -trackSize.height; } return minimumTrackStyle; } getThumbPositionStyles(thumbStart) { if (this.props.vertical) { return [{ translateX: -(this.state.trackSize.height + this.state.thumbSize.height) / 2 }, { translateY: thumbStart }]; } return [{ translateX: thumbStart }, { translateY: -(this.state.trackSize.height + this.state.thumbSize.height) / 2 }]; } render() { const { style, vertical, // eslint-disable-next-line @typescript-eslint/no-unused-vars step, maxValue, minValue, disabled, shownThumb, // eslint-disable-next-line @typescript-eslint/no-unused-vars animationType, // eslint-disable-next-line @typescript-eslint/no-unused-vars animateTransitions, // eslint-disable-next-line @typescript-eslint/no-unused-vars animationConfig, trackStyle, thumbStyle, minimumTrackTintColor, maximumTrackTintColor, thumbTintColor, // eslint-disable-next-line @typescript-eslint/no-unused-vars onChange, // eslint-disable-next-line @typescript-eslint/no-unused-vars onSlidingComplete, // eslint-disable-next-line @typescript-eslint/no-unused-vars onSlidingStart, ...otherProps } = this.props; const { value, thumbSize, containerSize } = this.state; const touchOverflowStyle = {}; const thumbStart = value.interpolate({ inputRange: [minValue, maxValue], outputRange: [0, containerSize.width - thumbSize.width] // extrapolate: 'clamp', }); const minimumTrackStyle = { ...this.getMinimumTrackStyles(thumbStart), backgroundColor: disabled ? '#a0a5b1' : minimumTrackTintColor }; const valueVisibleStyle = {}; const thumbStyleTransform = thumbStyle && thumbStyle.transform || []; const thumbTrackStyle = {}; if (vertical) { thumbTrackStyle.left = 16 + (trackStyle && trackStyle.width ? (trackStyle.width - 4) / 2 : 0); touchOverflowStyle.height = '100%'; touchOverflowStyle.width = 30; } else { thumbTrackStyle.top = 16 + (trackStyle && trackStyle.height ? (trackStyle.height - 4) / 2 : 0); touchOverflowStyle.height = 30; } return <_reactNative.View onLayout={this.measureContainer} {...otherProps} style={_reactNative.StyleSheet.flatten([vertical ? styles.containerVertical : styles.containerHorizontal, style])}> <_reactNative.View style={_reactNative.StyleSheet.flatten([styles.track, vertical ? { ...styles.trackVertical, height: '100%' } : { ...styles.trackHorizontal, width: '100%' }, trackStyle, { backgroundColor: maximumTrackTintColor, position: 'absolute' }])} /> <_reactNative.Animated.View style={_reactNative.StyleSheet.flatten([styles.track, vertical ? styles.trackVertical : styles.trackHorizontal, trackStyle, minimumTrackStyle])} /> {shownThumb && <_reactNative.Animated.View onLayout={this.measureThumb} style={_reactNative.StyleSheet.flatten([{ backgroundColor: thumbTintColor }, styles.thumb, thumbTrackStyle, thumbStyle, { transform: [...this.getThumbPositionStyles(thumbStart), ...thumbStyleTransform], ...valueVisibleStyle }])} />} <_reactNative.View style={_reactNative.StyleSheet.flatten([styles.touchArea, touchOverflowStyle])} {...this.panResponder.panHandlers} /> </_reactNative.View>; } } exports.default = Slider; Slider.defaultProps = { value: 0, step: 0, maxValue: 1, minValue: 0, height: 6, vertical: false, shownThumb: true, thumbSize: { width: 20, height: 20 }, maximumTrackTintColor: '#cacaca', minimumTrackTintColor: '#008EF0', thumbTintColor: '#fff', animationType: 'timing', onChange: () => {}, onSlidingComplete: () => {}, onSlidingStart: () => {} }; const styles = _reactNative.StyleSheet.create({ containerHorizontal: { height: 30, justifyContent: 'center' }, containerVertical: { width: 30, flexDirection: 'column', alignItems: 'center' }, track: { borderRadius: TRACK_SIZE / 2 }, trackHorizontal: { height: TRACK_SIZE }, trackVertical: { flex: 1, width: TRACK_SIZE }, thumb: { position: 'absolute', width: THUMB_SIZE, height: THUMB_SIZE, borderRadius: THUMB_SIZE / 2 }, touchArea: { backgroundColor: 'transparent' } }); module.exports = exports.default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Slider/index.tsx"],"names":["TRACK_SIZE","THUMB_SIZE","DEFAULT_ANIMATION_CONFIGS","spring","friction","tension","timing","duration","easing","Easing","inOut","ease","delay","getBoundedValue","value","maxValue","minValue","Slider","Component","constructor","props","panResponder","_previousLeft","getCurrentValue","state","__getValue","handlePanResponderGrant","disabled","getThumbLeft","onSlidingStart","handlePanResponderEnd","onSlidingComplete","handlePanResponderMove","_","gestureState","getValue","setValue","onChange","measureContainer","event","handleMeasure","measureThumb","containerSize","width","height","trackSize","thumbSize","Animated","Value","PanResponder","create","onPanResponderTerminationRequest","onStartShouldSetPanResponder","onStartShouldSetPanResponderCapture","onMoveShouldSetPanResponder","onPanResponderGrant","onPanResponderMove","onPanResponderRelease","onPanResponderTerminate","componentDidUpdate","prevProps","newValue","animateTransitions","setCurrentValueAnimated","setCurrentValue","animationType","animationConfig","Object","assign","toValue","start","ratio","vertical","length","thumbLeft","dy","dx","step","Math","max","min","round","name","layoutWidth","layoutHeight","nativeEvent","layout","size","setState","getMinimumTrackStyles","thumbStart","minimumTrackStyle","position","add","marginLeft","marginTop","getThumbPositionStyles","translateX","translateY","render","style","shownThumb","trackStyle","thumbStyle","minimumTrackTintColor","maximumTrackTintColor","thumbTintColor","otherProps","touchOverflowStyle","interpolate","inputRange","outputRange","backgroundColor","valueVisibleStyle","thumbStyleTransform","transform","thumbTrackStyle","left","top","StyleSheet","flatten","styles","containerVertical","containerHorizontal","track","trackVertical","trackHorizontal","thumb","touchArea","panHandlers","defaultProps","justifyContent","flexDirection","alignItems","borderRadius","flex"],"mappings":"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","sourcesContent":["import React, { Component } from 'react';\nimport {\n  View,\n  ViewProps,\n  TransformsStyle,\n  ViewStyle,\n  Easing,\n  LayoutChangeEvent,\n  Animated,\n  PanResponder,\n  PanResponderInstance,\n  PanResponderGestureState,\n  StyleSheet,\n} from 'react-native';\n\nconst TRACK_SIZE = 4;\nconst THUMB_SIZE = 20;\n\nconst DEFAULT_ANIMATION_CONFIGS = {\n  spring: {\n    friction: 7,\n    tension: 100,\n  },\n  timing: {\n    duration: 150,\n    easing: Easing.inOut(Easing.ease),\n    delay: 0,\n  },\n};\n\ntype BoundedValue = {\n  value?: number;\n  maxValue?: number;\n  minValue?: number;\n};\n\nconst getBoundedValue = ({ value, maxValue, minValue }: BoundedValue) =>\n  value! > maxValue! ? maxValue : value! < minValue! ? minValue : value;\n\nexport interface RectProps {\n  width: number;\n  height: number;\n}\n\nexport interface SliderProps extends ViewProps {\n  value?: number;\n  step?: number;\n  maxValue?: number;\n  minValue?: number;\n  /**\n   * 值为 `true` 时，Slider 为垂直方向\n   */\n  vertical?: boolean;\n  /**\n   * 是否禁用\n   */\n  disabled?: boolean;\n  shownThumb?: boolean;\n  thumbSize?: RectProps;\n  animationType?: keyof typeof DEFAULT_ANIMATION_CONFIGS;\n  maximumTrackTintColor?: string;\n  minimumTrackTintColor?: string;\n  thumbTintColor?: string;\n  trackStyle?: ViewStyle;\n  thumbStyle?: ViewStyle;\n  animateTransitions?: boolean;\n  animationConfig?: Animated.SpringAnimationConfig;\n  onChange?: (value: number) => void;\n  onSlidingComplete?: (value: number) => void;\n  onSlidingStart?: (value: number) => void;\n}\nexport interface SliderState {\n  containerSize: RectProps;\n  trackSize: RectProps;\n  thumbSize: RectProps;\n  value: Animated.Value;\n}\n\nexport default class Slider extends Component<SliderProps, SliderState> {\n  panResponder: PanResponderInstance;\n  _previousLeft: number = 0;\n  static defaultProps = {\n    value: 0,\n    step: 0,\n    maxValue: 1,\n    minValue: 0,\n    height: 6,\n    vertical: false,\n    shownThumb: true,\n    thumbSize: { width: 20, height: 20 },\n    maximumTrackTintColor: '#cacaca',\n    minimumTrackTintColor: '#008EF0',\n    thumbTintColor: '#fff',\n    animationType: 'timing',\n    onChange: () => {},\n    onSlidingComplete: () => {},\n    onSlidingStart: () => {},\n  };\n  constructor(props: SliderProps) {\n    super(props);\n    this.state = {\n      containerSize: { width: 0, height: 0 },\n      trackSize: { width: 0, height: 0 },\n      thumbSize: props.thumbSize || { width: 0, height: 0 },\n      value: new Animated.Value(getBoundedValue(props) as number),\n    };\n    this.panResponder = PanResponder.create({\n      onPanResponderTerminationRequest: () => false,\n      onStartShouldSetPanResponder: () => true,\n      onStartShouldSetPanResponderCapture: () => true,\n      onMoveShouldSetPanResponder: () => false,\n      onPanResponderGrant: this.handlePanResponderGrant,\n      onPanResponderMove: this.handlePanResponderMove,\n      onPanResponderRelease: this.handlePanResponderEnd,\n      onPanResponderTerminate: this.handlePanResponderEnd,\n    });\n  }\n  componentDidUpdate(prevProps: SliderProps) {\n    const newValue = getBoundedValue(this.props);\n\n    if (prevProps.value !== newValue) {\n      if (this.props.animateTransitions) {\n        this.setCurrentValueAnimated(newValue!);\n      } else {\n        this.setCurrentValue(newValue!);\n      }\n    }\n  }\n\n  setCurrentValue(value: number) {\n    this.state.value.setValue(value);\n  }\n\n  setCurrentValueAnimated(value: number) {\n    const { animationType } = this.props;\n    if (!animationType) {\n      return;\n    }\n    const animationConfig: Animated.SpringAnimationConfig = Object.assign(\n      {},\n      DEFAULT_ANIMATION_CONFIGS[animationType],\n      this.props.animationConfig,\n      {\n        toValue: value,\n      },\n    );\n\n    Animated[animationType](this.state.value, animationConfig).start();\n  }\n  getThumbLeft(value: number) {\n    const ratio = (value - this.props.minValue!) / (this.props.maxValue! - this.props.minValue!);\n    return ratio * (this.state.containerSize.width - this.state.thumbSize.width);\n  }\n  getCurrentValue = () => (this.state.value as any).__getValue();\n  handlePanResponderGrant = () => {\n    if (this.props.disabled) {\n      return;\n    }\n    this._previousLeft = this.getThumbLeft(this.getCurrentValue());\n    this.props.onSlidingStart!(this.getCurrentValue());\n  };\n  handlePanResponderEnd = () => {\n    if (this.props.disabled) {\n      return;\n    }\n    this.props.onSlidingComplete!(this.getCurrentValue());\n  };\n  handlePanResponderMove = (_: any, gestureState: PanResponderGestureState) => {\n    if (this.props.disabled) {\n      return;\n    }\n    const value = this.getValue(gestureState);\n    this.state.value.setValue(value);\n    this.props.onChange!(this.getCurrentValue());\n  };\n  getValue(gestureState: PanResponderGestureState) {\n    const { vertical, minValue, maxValue } = this.props;\n    const length = this.state.containerSize.width - this.state.thumbSize.width;\n    const thumbLeft = this._previousLeft + (vertical ? gestureState.dy : gestureState.dx);\n    const ratio = thumbLeft / length;\n    if (this.props.step) {\n      return Math.max(\n        minValue!,\n        Math.min(\n          maxValue!,\n          minValue! + Math.round((ratio * (maxValue! - minValue!)) / this.props.step) * this.props.step,\n        ),\n      );\n    }\n    return Math.max(minValue!, Math.min(maxValue!, ratio * (maxValue! - minValue!) + minValue!));\n  }\n\n  handleMeasure(name: string, event: LayoutChangeEvent) {\n    const { width: layoutWidth, height: layoutHeight } = event.nativeEvent.layout;\n    const { vertical } = this.props;\n    const { containerSize, trackSize, thumbSize } = this.state;\n    const width = vertical ? layoutHeight : layoutWidth;\n    const height = vertical ? layoutWidth : layoutHeight;\n    const size = { width, height };\n    const state = { containerSize, trackSize, thumbSize };\n    if (state[name as keyof typeof state]) {\n      state[name as keyof typeof state] = size;\n    }\n    this.setState({ ...state });\n  }\n  measureContainer = (event: LayoutChangeEvent) => this.handleMeasure('containerSize', event);\n  measureThumb = (event: LayoutChangeEvent) => this.handleMeasure('thumbSize', event);\n  getMinimumTrackStyles(thumbStart: Animated.AnimatedInterpolation) {\n    const { thumbSize, trackSize } = this.state;\n    const minimumTrackStyle: {\n      position: ViewStyle['position'];\n      height?: Animated.AnimatedAddition;\n      width?: Animated.AnimatedAddition;\n      marginLeft?: ViewStyle['marginLeft'];\n      marginTop?: ViewStyle['marginTop'];\n    } = { position: 'absolute' };\n\n    if (this.props.vertical) {\n      minimumTrackStyle.height = Animated.add(thumbStart, thumbSize.height / 2);\n      minimumTrackStyle.marginLeft = -trackSize.width;\n    } else {\n      minimumTrackStyle.width = Animated.add(thumbStart, thumbSize.width / 2);\n      minimumTrackStyle.marginTop = -trackSize.height;\n    }\n    return minimumTrackStyle;\n  }\n  getThumbPositionStyles(thumbStart: Animated.AnimatedInterpolation) {\n    if (this.props.vertical) {\n      return [\n        {\n          translateX: -(this.state.trackSize.height + this.state.thumbSize.height) / 2,\n        },\n        { translateY: thumbStart },\n      ];\n    }\n    return [\n      { translateX: thumbStart },\n      {\n        translateY: -(this.state.trackSize.height + this.state.thumbSize.height) / 2,\n      },\n    ];\n  }\n  render() {\n    const {\n      style,\n      vertical,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      step,\n      maxValue,\n      minValue,\n      disabled,\n      shownThumb,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      animationType,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      animateTransitions,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      animationConfig,\n      trackStyle,\n      thumbStyle,\n      minimumTrackTintColor,\n      maximumTrackTintColor,\n      thumbTintColor,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      onChange,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      onSlidingComplete,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      onSlidingStart,\n      ...otherProps\n    } = this.props;\n    const { value, thumbSize, containerSize } = this.state;\n    const touchOverflowStyle = {} as ViewStyle;\n    const thumbStart = value.interpolate({\n      inputRange: [minValue!, maxValue!],\n      outputRange: [0, containerSize.width - thumbSize.width],\n      // extrapolate: 'clamp',\n    });\n    const minimumTrackStyle = {\n      ...this.getMinimumTrackStyles(thumbStart),\n      backgroundColor: disabled ? '#a0a5b1' : minimumTrackTintColor,\n    };\n    const valueVisibleStyle = {};\n    const thumbStyleTransform = (thumbStyle && (thumbStyle as TransformsStyle).transform) || [];\n    const thumbTrackStyle = {} as ViewStyle;\n    if (vertical) {\n      thumbTrackStyle.left = 16 + (trackStyle && trackStyle.width ? ((trackStyle.width as number) - 4) / 2 : 0);\n      touchOverflowStyle.height = '100%';\n      touchOverflowStyle.width = 30;\n    } else {\n      thumbTrackStyle.top = 16 + (trackStyle && trackStyle.height ? ((trackStyle.height as number) - 4) / 2 : 0);\n      touchOverflowStyle.height = 30;\n    }\n    return (\n      <View\n        onLayout={this.measureContainer}\n        {...otherProps}\n        style={StyleSheet.flatten([vertical ? styles.containerVertical : styles.containerHorizontal, style])}\n      >\n        <View\n          style={StyleSheet.flatten([\n            styles.track,\n            vertical ? { ...styles.trackVertical, height: '100%' } : { ...styles.trackHorizontal, width: '100%' },\n            trackStyle,\n            { backgroundColor: maximumTrackTintColor, position: 'absolute' },\n          ])}\n        />\n        <Animated.View\n          style={StyleSheet.flatten([\n            styles.track,\n            vertical ? styles.trackVertical : styles.trackHorizontal,\n            trackStyle,\n            minimumTrackStyle,\n          ])}\n        />\n        {shownThumb && (\n          <Animated.View\n            onLayout={this.measureThumb}\n            style={StyleSheet.flatten([\n              { backgroundColor: thumbTintColor },\n              styles.thumb,\n              thumbTrackStyle,\n              thumbStyle,\n              {\n                transform: [...this.getThumbPositionStyles(thumbStart), ...thumbStyleTransform],\n                ...valueVisibleStyle,\n              },\n            ])}\n          />\n        )}\n        <View style={StyleSheet.flatten([styles.touchArea, touchOverflowStyle])} {...this.panResponder.panHandlers} />\n      </View>\n    );\n  }\n}\n\nconst styles = StyleSheet.create({\n  containerHorizontal: {\n    height: 30,\n    justifyContent: 'center',\n  },\n  containerVertical: {\n    width: 30,\n    flexDirection: 'column',\n    alignItems: 'center',\n  },\n  track: {\n    borderRadius: TRACK_SIZE / 2,\n  },\n  trackHorizontal: {\n    height: TRACK_SIZE,\n  },\n  trackVertical: {\n    flex: 1,\n    width: TRACK_SIZE,\n  },\n  thumb: {\n    position: 'absolute',\n    width: THUMB_SIZE,\n    height: THUMB_SIZE,\n    borderRadius: THUMB_SIZE / 2,\n  },\n  touchArea: {\n    backgroundColor: 'transparent',\n  },\n});\n"]}