BlueWallet/components/Button.tsx
Marcos Rodriguez Vélez ad9f900254
Update components/Button.tsx
Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com>
2024-09-26 21:13:41 -04:00

95 lines
2.4 KiB
TypeScript

import React, { forwardRef } from 'react';
import { ActivityIndicator, StyleProp, StyleSheet, Text, TouchableOpacity, TouchableOpacityProps, View, ViewStyle } from 'react-native';
import { Icon } from '@rneui/themed';
import { useTheme } from './themes';
interface ButtonProps extends TouchableOpacityProps {
backgroundColor?: string;
buttonTextColor?: string;
disabled?: boolean;
testID?: string;
icon?: {
name: string;
type: string;
color: string;
};
title?: string;
style?: StyleProp<ViewStyle>;
onPress?: () => void;
showActivityIndicator?: boolean;
}
export const Button = forwardRef<React.ElementRef<typeof TouchableOpacity>, ButtonProps>((props, ref) => {
const { colors } = useTheme();
let backgroundColor = props.backgroundColor ?? colors.mainColor;
let fontColor = props.buttonTextColor ?? colors.buttonTextColor;
if (props.disabled) {
backgroundColor = colors.buttonDisabledBackgroundColor;
fontColor = colors.buttonDisabledTextColor;
}
const buttonStyle = {
...styles.button,
backgroundColor,
borderColor: props.disabled ? colors.buttonDisabledBackgroundColor : 'transparent',
};
const textStyle = {
...styles.text,
color: fontColor,
};
const buttonView = props.showActivityIndicator ? (
<ActivityIndicator size="small" color={textStyle.color} />
) : (
<>
{props.icon && <Icon name={props.icon.name} type={props.icon.type} color={props.icon.color} />}
{props.title && <Text style={textStyle}>{props.title}</Text>}
</>
);
return props.onPress ? (
<TouchableOpacity
ref={ref}
testID={props.testID}
style={[buttonStyle, props.style, styles.content]}
accessibilityRole="button"
onPress={props.onPress}
disabled={props.disabled}
{...props}
>
{buttonView}
</TouchableOpacity>
) : (
<View style={[buttonStyle, props.style, styles.content]}>{buttonView}</View>
);
});
const styles = StyleSheet.create({
button: {
borderWidth: 0.7,
minHeight: 45,
height: 48,
maxHeight: 48,
borderRadius: 25,
justifyContent: 'center',
alignItems: 'center',
paddingHorizontal: 16,
flexGrow: 1,
},
content: {
flexDirection: 'row',
justifyContent: 'center',
alignItems: 'center',
},
text: {
marginHorizontal: 8,
fontSize: 16,
fontWeight: '600',
},
});
export default Button;