Skip to content

Commit 0e239d3

Browse files
lidord-wixM-i-k-e-l
authored andcommitted
Fix/ support RTL in segmentedControl (#1439)
* support RTL * use isRTL from Constants (cherry picked from commit 165faee)
1 parent 0d100e1 commit 0e239d3

File tree

1 file changed

+3
-2
lines changed

1 file changed

+3
-2
lines changed

src/components/segmentedControl/index.tsx

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,7 @@ import {Colors, BorderRadiuses, Spacings} from '../../style';
66
import {asBaseComponent} from '../../commons/new';
77
import View from '../view';
88
import Segment, {SegmentedControlItemProps as SegmentProps} from './segment';
9+
import {Constants} from 'helpers';
910

1011
const {interpolate: _interpolate, interpolateNode} = Reanimated;
1112
const interpolate = interpolateNode || _interpolate;
@@ -124,7 +125,7 @@ const SegmentedControl = (props: SegmentedControlProps) => {
124125

125126
const animatedStyle = useMemo(() => {
126127
if (segmentsCounter.current === segments?.length) {
127-
const left = interpolate(animatedValue.current, {
128+
const inset = interpolate(animatedValue.current, {
128129
inputRange: _.times(segmentsCounter.current),
129130
outputRange: _.map(segmentsStyle.current, segment => segment.x - BORDER_WIDTH)
130131
});
@@ -134,7 +135,7 @@ const SegmentedControl = (props: SegmentedControlProps) => {
134135
outputRange: _.map(segmentsStyle.current, segment => segment.width)
135136
});
136137

137-
return {width, left};
138+
return [{width}, Constants.isRTL ? {right: inset} : {left: inset}];
138139
}
139140
return undefined;
140141
}, [segmentsCounter.current, segments?.length]);

0 commit comments

Comments
 (0)