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; onPress?: () => void; showActivityIndicator?: boolean; } export const Button = forwardRef, 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 ? ( ) : ( <> {props.icon && } {props.title && {props.title}} ); return props.onPress ? ( {buttonView} ) : ( {buttonView} ); }); 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;