react-native-wagmi-charts
Version:
A sweet candlestick chart for React Native
45 lines • 1.2 kB
JavaScript
import * as React from 'react';
import { useSharedValue } from 'react-native-reanimated';
import { getDomain } from './utils';
export const CandlestickChartContext = /*#__PURE__*/React.createContext({
currentX: {
value: -1
},
currentY: {
value: -1
},
data: [],
height: 0,
width: 0,
domain: [0, 0],
step: 0,
setWidth: () => undefined,
setHeight: () => undefined
});
export function CandlestickChartProvider({
children,
data = [],
valueRangeY
}) {
const [width, setWidth] = React.useState(0);
const [height, setHeight] = React.useState(0);
const currentX = useSharedValue(-1);
const currentY = useSharedValue(-1);
const domain = React.useMemo(() => valueRangeY ?? getDomain(data), [data, valueRangeY]);
const step = React.useMemo(() => width / data.length, [data.length, width]);
const contextValue = React.useMemo(() => ({
currentX,
currentY,
data,
width,
height,
domain,
step,
setWidth,
setHeight
}), [currentX, currentY, data, domain, height, step, width]);
return /*#__PURE__*/React.createElement(CandlestickChartContext.Provider, {
value: contextValue
}, children);
}
//# sourceMappingURL=Context.js.map