mirror of
https://github.com/BlueWallet/BlueWallet.git
synced 2025-01-18 21:35:21 +01:00
88 lines
2.1 KiB
TypeScript
88 lines
2.1 KiB
TypeScript
import React, { FC } from 'react';
|
|
import { StyleSheet, Text, TouchableOpacity, View } from 'react-native';
|
|
|
|
import { useTheme } from './themes';
|
|
|
|
export const StyledButtonType: Record<string, string> = { default: 'default', destroy: 'destroy', grey: 'grey' };
|
|
|
|
interface StyledButtonProps {
|
|
onPress: () => void;
|
|
text: string;
|
|
disabled?: boolean;
|
|
buttonStyle?: keyof typeof StyledButtonType;
|
|
}
|
|
|
|
const StyledButton: FC<StyledButtonProps> = ({ onPress, text, disabled = false, buttonStyle = StyledButtonType.default }) => {
|
|
const { colors } = useTheme();
|
|
const stylesHook = StyleSheet.create({
|
|
buttonGrey: {
|
|
backgroundColor: colors.lightButton,
|
|
},
|
|
textGray: {
|
|
color: colors.buttonTextColor,
|
|
},
|
|
container: {
|
|
opacity: disabled ? 0.5 : 1.0,
|
|
},
|
|
});
|
|
const textStyles = () => {
|
|
if (buttonStyle === StyledButtonType.grey) {
|
|
return stylesHook.textGray;
|
|
} else if (buttonStyle === StyledButtonType.destroy) {
|
|
return styles.textDestroy;
|
|
} else {
|
|
return styles.textDefault;
|
|
}
|
|
};
|
|
|
|
const buttonStyles = () => {
|
|
if (buttonStyle === StyledButtonType.grey) {
|
|
return stylesHook.buttonGrey;
|
|
} else if (buttonStyle === StyledButtonType.destroy) {
|
|
return styles.buttonDestroy;
|
|
} else {
|
|
return styles.buttonDefault;
|
|
}
|
|
};
|
|
|
|
return (
|
|
<TouchableOpacity accessibilityRole="button" onPress={onPress} disabled={disabled} style={stylesHook.container}>
|
|
<View style={[styles.buttonContainer, buttonStyles()]}>
|
|
<Text style={[styles.text, textStyles()]}>{text}</Text>
|
|
</View>
|
|
</TouchableOpacity>
|
|
);
|
|
};
|
|
|
|
const styles = StyleSheet.create({
|
|
buttonContainer: {
|
|
borderRadius: 9,
|
|
minHeight: 49,
|
|
paddingHorizontal: 8,
|
|
justifyContent: 'center',
|
|
alignItems: 'center',
|
|
flexDirection: 'row',
|
|
alignSelf: 'auto',
|
|
flexGrow: 1,
|
|
marginHorizontal: 4,
|
|
},
|
|
buttonDefault: {
|
|
backgroundColor: '#EBF2FB',
|
|
},
|
|
buttonDestroy: {
|
|
backgroundColor: '#FFF5F5',
|
|
},
|
|
text: {
|
|
fontWeight: '600',
|
|
fontSize: 15,
|
|
},
|
|
textDefault: {
|
|
color: '#1961B9',
|
|
},
|
|
textDestroy: {
|
|
color: '#D0021B',
|
|
},
|
|
});
|
|
|
|
export default StyledButton;
|