swimtracker-app/components/IconCard.js

49 lines
1.4 KiB
JavaScript
Raw Normal View History

2019-09-17 20:24:01 +02:00
import React from 'react';
2020-05-16 12:36:05 +02:00
import { View, StyleSheet, Text } from 'react-native';
import EntypoIcon from "react-native-vector-icons/Entypo";
import AntDesignIcon from "react-native-vector-icons/AntDesign";
import Fa5Icon from "react-native-vector-icons/FontAwesome5";
2019-09-17 20:24:01 +02:00
const IconCard = props => {
let iconClass;
if (props.iconType === "AntDesign") {
iconClass = AntDesignIcon;
}
else if (props.iconType === "FontAwesome5") {
iconClass = Fa5Icon;
} else if (props.iconType === "Entypo") {
iconClass = EntypoIcon;
}
2019-09-17 20:24:01 +02:00
return (
<View style={styles.card}>
2020-06-02 17:19:09 +02:00
<View style={{ paddingLeft: 20 }}>
<Text style={{ color: 'white', fontSize: props.fontSize, textAlign: "center" }}> {props.value}</Text>
</View>
<View style={{ alignItems: 'center', justifyContent: 'center', paddingLeft: 20 }}>
<iconClass style={{ color: 'white', fontSize: 40 }} name={props.iconName} />
2020-05-16 12:36:05 +02:00
<Text style={{ color: 'white', marginTop: 5 }}> {props.label}</Text>
2019-09-17 20:24:01 +02:00
</View>
</View>
);
};
const styles = StyleSheet.create({
2020-05-16 12:36:05 +02:00
card: {
2019-09-17 20:24:01 +02:00
flexDirection: 'row',
2020-07-15 15:53:16 +02:00
backgroundColor: 'rgba(0, 0, 0, 0.3)',
2019-09-17 20:24:01 +02:00
margin: 5,
padding: 5,
2020-07-15 15:53:16 +02:00
borderRadius: 6,
2019-09-17 20:24:01 +02:00
justifyContent: 'space-between',
}
});
2020-05-16 12:36:05 +02:00
IconCard.defaultProps = {
2020-06-30 18:06:37 +02:00
fontSize: 65,
2020-06-02 17:19:09 +02:00
flex: 1
2019-09-17 20:24:01 +02:00
};
export default IconCard;