BlueWallet/components/ArrowPicker.tsx

97 lines
2.6 KiB
TypeScript
Raw Normal View History

2021-09-09 13:00:11 +02:00
/* eslint react/prop-types: "off", react-native/no-inline-styles: "off" */
import { StyleSheet, Pressable, View, Keyboard } from 'react-native';
import { Text, Icon } from 'react-native-elements';
import React, { useState } from 'react';
import loc from '../loc';
2023-10-24 03:28:44 +02:00
import { useTheme } from './themes';
2021-09-09 13:00:11 +02:00
interface IHash {
[key: string]: string;
}
type ArrowPickerProps = {
onChange: (key: string) => void;
items: IHash;
isItemUnknown: boolean;
};
export const ArrowPicker = (props: ArrowPickerProps) => {
const keys = Object.keys(props.items);
const [keyIndex, setKeyIndex] = useState(0);
const { colors } = useTheme();
const stylesHook = {
text: {
color: colors.foregroundColor,
},
};
return (
<View style={{ flexDirection: 'row', alignItems: 'center' }}>
<Pressable
accessibilityRole="button"
accessibilityLabel={loc.send.dynamic_prev}
2021-09-09 13:00:11 +02:00
onPress={() => {
Keyboard.dismiss();
let newIndex = keyIndex;
if (keyIndex <= 0) {
newIndex = keys.length - 1;
} else {
newIndex--;
}
setKeyIndex(newIndex);
props.onChange(keys[newIndex]);
}}
style={({ pressed }) => [
{
backgroundColor: pressed ? 'rgb(210, 230, 255)' : 'white',
},
styles.wrapperCustom,
]}
>
2023-03-04 22:09:25 +01:00
{/*
// @ts-ignore: Ignore */}
2022-02-11 12:47:06 +01:00
<Icon size={24} name="chevron-left" type="ionicons" tvParallaxProperties={undefined} />
2021-09-09 13:00:11 +02:00
</Pressable>
<View style={{ width: 200 }}>
<Text style={[styles.text, stylesHook.text]}>{props.isItemUnknown ? loc.send.fee_custom : keys[keyIndex]}</Text>
</View>
<Pressable
accessibilityRole="button"
accessibilityLabel={loc.send.dynamic_next}
2021-09-09 13:00:11 +02:00
onPress={() => {
Keyboard.dismiss();
let newIndex = keyIndex;
if (keyIndex + 1 >= keys.length) {
newIndex = 0;
} else {
newIndex++;
}
setKeyIndex(newIndex);
props.onChange(keys[newIndex]);
}}
style={({ pressed }) => [
{
backgroundColor: pressed ? 'rgb(210, 230, 255)' : 'white',
},
styles.wrapperCustom,
]}
>
2023-03-04 22:09:25 +01:00
{/*
// @ts-ignore: Ignore */}
2022-02-11 12:47:06 +01:00
<Icon size={24} name="chevron-right" type="ionicons" tvParallaxProperties={undefined} />
2021-09-09 13:00:11 +02:00
</Pressable>
</View>
);
};
const styles = StyleSheet.create({
wrapperCustom: {
borderRadius: 8,
padding: 5,
marginLeft: 20,
marginRight: 20,
},
text: { fontWeight: 'bold', fontSize: 12, textAlign: 'center' },
});