UNPKG

react-native-wagmi-charts

Version:

A sweet candlestick chart for React Native

171 lines (168 loc) 4.74 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true, }); exports.LineChartCursorCrosshair = LineChartCursorCrosshair; var _react = _interopRequireDefault(require('react')); var _reactNative = require('react-native'); var _reactNativeReanimated = _interopRequireWildcard( require('react-native-reanimated') ); var _Cursor = require('./Cursor'); var _useLineChart = require('./useLineChart'); function _interopRequireWildcard(e, t) { if ('function' == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || ('object' != typeof e && 'function' != typeof e)) return f; if ((o = t ? n : r)) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) 'default' !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : (f[t] = e[t])); return f; })(e, t); } function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } function _extends() { return ( (_extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }), _extends.apply(null, arguments) ); } /** * Delay in milliseconds before enabling spring animations on Android. This * prevents crashes that can occur when spring animations are enabled on initial * render. */ const ANDROID_SPRING_ANIMATION_DELAY_MS = 100; LineChartCursorCrosshair.displayName = 'LineChartCursorCrosshair'; function LineChartCursorCrosshair({ children, color = 'black', size = 8, outerSize = 32, crosshairWrapperProps = {}, crosshairProps = {}, crosshairOuterProps = {}, ...props }) { const { currentX, currentY, isActive } = (0, _useLineChart.useLineChart)(); // It seems that enabling spring animation on initial render on Android causes a crash. const [enableSpringAnimation, setEnableSpringAnimation] = _react.default.useState(_reactNative.Platform.OS === 'ios'); _react.default.useEffect(() => { const timer = setTimeout(() => { setEnableSpringAnimation(true); }, ANDROID_SPRING_ANIMATION_DELAY_MS); return () => clearTimeout(timer); }, []); const animatedCursorStyle = (0, _reactNativeReanimated.useAnimatedStyle)( () => ({ transform: [ { translateX: currentX.value - outerSize / 2, }, { translateY: currentY.value - outerSize / 2, }, { scale: enableSpringAnimation ? (0, _reactNativeReanimated.withSpring)(isActive.value ? 1 : 0, { damping: 10, }) : 0, }, ], }), [currentX, currentY, enableSpringAnimation, isActive, outerSize] ); return /*#__PURE__*/ _react.default.createElement( _Cursor.LineChartCursor, _extends( { type: 'crosshair', }, props ), /*#__PURE__*/ _react.default.createElement( _reactNativeReanimated.default.View, _extends({}, crosshairWrapperProps, { style: [ styles.crosshairWrapper, { width: outerSize, height: outerSize, }, animatedCursorStyle, crosshairWrapperProps.style, ], }), /*#__PURE__*/ _react.default.createElement( _reactNative.View, _extends({}, crosshairOuterProps, { style: [ styles.crosshairOuter, { backgroundColor: color, width: outerSize, height: outerSize, borderRadius: outerSize, }, crosshairOuterProps.style, ], }) ), /*#__PURE__*/ _react.default.createElement( _reactNative.View, _extends({}, crosshairProps, { style: [ { backgroundColor: color, width: size, height: size, borderRadius: size, }, crosshairProps.style, ], }) ) ), children ); } const styles = _reactNative.StyleSheet.create({ crosshairWrapper: { alignItems: 'center', justifyContent: 'center', }, crosshairOuter: { opacity: 0.1, position: 'absolute', }, }); //# sourceMappingURL=CursorCrosshair.js.map