Skip to content

Commit

Permalink
feat: vertical and horizontal lines (#45)
Browse files Browse the repository at this point in the history
  • Loading branch information
dynamichny authored Oct 25, 2021
1 parent d8a7fb8 commit 71c578d
Show file tree
Hide file tree
Showing 7 changed files with 125 additions and 2 deletions.
7 changes: 7 additions & 0 deletions .prettierrc.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
module.exports = {
arrowParens: 'avoid',
bracketSpacing: true,
bracketSameLine: false,
singleQuote: true,
trailingComma: 'es5',
};
13 changes: 13 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,19 @@ Labels are useful while moving finger through the chart to show the exact value
| `format` | reanimated worklet | `a => a` | Worklet for formatting data from the chart. It can be useful when your data is a timestamp or currency. |
| ...props | `object` | `{}` | Rest of the props applied to `TextInput` including `style` |

### `CurrentPositionVerticalLine` & `OpeningPositionHorizontalLine`
CurrentPositionVerticalLine is a vertical line moving with user's finger through chart.

OpeningPositionHorizontalLine is a horizontal static line on height of the first point.

| Prop name | type | default | description |
|--------------|----------------------|----------|-------------|
| `color` | `string` | `#000000`| Color of the line. |
| `thickness` | `number` | `2` | Thickness of the line. |
| `length` | `number` | `null` | Length of the line. |
| ...props | `object` | `{}` | Rest of the props applied to svg's `Line`. |

![](gifs/lines.png)


### Candle Charts
Expand Down
Binary file added gifs/lines.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
58 changes: 58 additions & 0 deletions src/charts/linear/ChartLines.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
import React, { useContext } from 'react';
import Animated from 'react-native-reanimated';
import { Svg, Line } from 'react-native-svg';
import ChartContext from '../../helpers/ChartContext';
import withReanimatedFallback from '../../helpers/withReanimatedFallback';

function ChartLineFactory(orientation) {
const isVertical = orientation == 'vertical';
return function ChartLine({
color = '#000000',
thickness = 2,
length,
...props
}) {
const {
currentPositionVerticalLineStyle,
openingPositionHorizontalLineStyle,
} = useContext(ChartContext);
return (
<Animated.View
pointerEvents="none"
style={[
isVertical
? currentPositionVerticalLineStyle
: openingPositionHorizontalLineStyle,
{
height: isVertical ? length + 20 : thickness,
position: 'absolute',
left: 0,
top: 0,
width: isVertical ? thickness : length,
zIndex: -1,
},
]}
>
<Svg>
<Line
stroke={color}
strokeWidth={thickness}
strokeDasharray={10}
x1={0}
y1={0}
x2={isVertical ? 0 : length}
y2={isVertical ? length + 20 : 0}
{...props}
/>
</Svg>
</Animated.View>
);
};
}

export const CurrentPositionVerticalLine = withReanimatedFallback(
ChartLineFactory('vertical')
);
export const OpeningPositionHorizontalLine = withReanimatedFallback(
ChartLineFactory('horizontal')
);
2 changes: 2 additions & 0 deletions src/charts/linear/ChartPath.js
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,7 @@ export default function ChartPathProvider({
state,
setContextValue = () => {},
providedData = rawData,
proceededData,
} = useContext(ChartContext) || generateValues();

const prevData = useSharedValue(valuesStore.current.prevData, 'prevData');
Expand Down Expand Up @@ -218,6 +219,7 @@ export default function ChartPathProvider({
return;
}
const [parsedData] = parse(data.points, data.yRange);
proceededData.value = parsedData;
const [parsedoriginalData, newExtremes] = parse(
data.nativePoints || data.points
);
Expand Down
43 changes: 41 additions & 2 deletions src/charts/linear/ChartPathProvider.js
Original file line number Diff line number Diff line change
@@ -1,10 +1,15 @@
import React, { useMemo, useState } from 'react';
import { useAnimatedStyle } from 'react-native-reanimated';
import {
useAnimatedStyle,
useSharedValue,
withTiming,
} from 'react-native-reanimated';

import ChartContext, { useGenerateValues } from '../../helpers/ChartContext';

export default function ChartPathProvider({ data: providedData, children }) {
const values = useGenerateValues();
const proceededData = useSharedValue(null);
const dotStyle = useAnimatedStyle(
() => ({
opacity: values.dotScale.value,
Expand All @@ -16,16 +21,50 @@ export default function ChartPathProvider({ data: providedData, children }) {
}),
[]
);

const currentPositionVerticalLineStyle = useAnimatedStyle(
() => ({
opacity: values.dotScale.value,
transform: [{ translateX: values.positionX.value }],
}),
[]
);

const openingPositionHorizontalLineStyle = useAnimatedStyle(() => {
return {
opacity: proceededData == null ? 0 : 1,
transform: [
{
translateY: withTiming(
proceededData?.value?.[0].y * values?.layoutSize?.value?.height +
10 || 0
),
},
],
};
}, [proceededData]);

const [contextReanimatedValue, setContextValue] = useState({});
const contextValue = useMemo(
() => ({
dotStyle,
currentPositionVerticalLineStyle,
openingPositionHorizontalLineStyle,
...values,
...contextReanimatedValue,
providedData,
proceededData,
setContextValue,
}),
[dotStyle, values, contextReanimatedValue, providedData]
[
dotStyle,
currentPositionVerticalLineStyle,
openingPositionHorizontalLineStyle,
values,
contextReanimatedValue,
providedData,
proceededData,
]
);

return (
Expand Down
4 changes: 4 additions & 0 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,10 @@ Animated.addWhitelistedNativeProps({ text: true });

export { default as ChartPathProvider } from './charts/linear/ChartPathProvider';
export { default as ChartDot } from './charts/linear/ChartDot';
export {
CurrentPositionVerticalLine,
OpeningPositionHorizontalLine,
} from './charts/linear/ChartLines';
export { ChartYLabel, ChartXLabel } from './charts/linear/ChartLabels';
export { default as ChartPath } from './charts/linear/ChartPath';
export { default as useChartData } from './helpers/useChartData';
Expand Down

0 comments on commit 71c578d

Please sign in to comment.