react-native-wagmi-charts
Version:
A sweet candlestick chart for React Native
130 lines (129 loc) • 3.73 kB
JavaScript
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)
);
}
import React from 'react';
import { StyleSheet } from 'react-native';
import Animated, {
useAnimatedStyle,
useDerivedValue,
useSharedValue,
} from 'react-native-reanimated';
import { CandlestickChartDimensionsContext } from './Chart';
import { useCandlestickChart } from './useCandlestickChart';
import { CandlestickChartPriceText } from './PriceText';
export const CandlestickChartCrosshairTooltipContext =
/*#__PURE__*/ React.createContext({
position: {
value: 'left',
},
});
export function CandlestickChartCrosshairTooltip({
children,
xGutter = 8,
yGutter = 8,
tooltipTextProps,
textStyle,
...props
}) {
const { width, height } = React.useContext(CandlestickChartDimensionsContext);
const { currentY } = useCandlestickChart();
const { position } = React.useContext(
CandlestickChartCrosshairTooltipContext
);
const elementHeight = useSharedValue(0);
const elementWidth = useSharedValue(0);
const handleLayout = React.useCallback(
(event) => {
elementHeight.value = event.nativeEvent.layout.height;
elementWidth.value = event.nativeEvent.layout.width;
},
[elementHeight, elementWidth]
);
const topOffset = useDerivedValue(() => {
let offset = 0;
if (currentY.value < elementHeight.value / 2 + yGutter) {
offset = currentY.value - (elementHeight.value / 2 + yGutter);
} else if (currentY.value + elementHeight.value / 2 > height - yGutter) {
offset = currentY.value + elementHeight.value / 2 - height + yGutter;
}
return offset;
}, [currentY, elementHeight, height, yGutter]);
const tooltip = useAnimatedStyle(
() => ({
backgroundColor: 'white',
position: 'absolute',
display: 'flex',
padding: 4,
}),
[]
);
const leftTooltip = useAnimatedStyle(
() => ({
left: xGutter,
top: -(elementHeight.value / 2) - topOffset.value,
opacity: position.value === 'left' ? 1 : 0,
}),
[elementHeight, position, topOffset, xGutter]
);
const rightTooltip = useAnimatedStyle(
() => ({
left: width - elementWidth.value - xGutter,
top: -(elementHeight.value / 2) - topOffset.value,
opacity: position.value === 'right' ? 1 : 0,
}),
[elementHeight, elementWidth, position, topOffset, width, xGutter]
);
return /*#__PURE__*/ React.createElement(
React.Fragment,
null,
/*#__PURE__*/ React.createElement(
Animated.View,
_extends(
{
onLayout: handleLayout,
},
props,
{
style: [tooltip, leftTooltip, props.style],
}
),
children ||
/*#__PURE__*/ React.createElement(
CandlestickChartPriceText,
_extends({}, tooltipTextProps, {
style: [styles.text, tooltipTextProps?.style, textStyle],
})
)
),
/*#__PURE__*/ React.createElement(
Animated.View,
_extends({}, props, {
style: [tooltip, rightTooltip, props.style],
}),
children ||
/*#__PURE__*/ React.createElement(
CandlestickChartPriceText,
_extends({}, tooltipTextProps, {
style: [styles.text, tooltipTextProps?.style, textStyle],
})
)
)
);
}
const styles = StyleSheet.create({
text: {
fontSize: 14,
},
});
//# sourceMappingURL=CrosshairTooltip.js.map