| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231 |
- import {
- type FC
- } from "react";
- import {
- TouchableOpacity,
- View
- } from "react-native";
- import type IRowCardProps from "./type";
- import stylesheet, {
- useStyles
- } from "./stylesheet";
- import {
- NCoreUIKitTheme
- } from "../../core/hooks";
- import Text from "../text";
- const RowCard: FC<IRowCardProps> = ({
- rightSubTitleVariant = "labelLargeSize",
- rightTitleVariant = "labelLargeSize",
- subTitleVariant = "labelLargeSize",
- titleVariant = "labelLargeSize",
- rightContentContainerStyle,
- rightIcon: CustomRightIcon,
- leftContentContainerStyle,
- isTransparentBackground,
- type = "first-based",
- rightContainerStyle,
- rightSubTitleStyle,
- leftContainerStyle,
- rightSubTitleColor,
- leftSubTitleStyle,
- icon: CustomIcon,
- rightTitleColor,
- rightTitleStyle,
- rightIconStyle,
- leftTitleStyle,
- subTitleColor,
- rightSubTitle,
- customTheme,
- titleColor,
- rightTitle,
- iconStyle,
- subTitle,
- onPress,
- style,
- title
- }) => {
- const {
- radiuses,
- colors,
- spaces
- } = NCoreUIKitTheme.useContext(customTheme);
- const {
- rightIconContainer: rightIconContainerDynamicStyle,
- rightContainer: rightContainerDynamicStyle,
- leftContainer: leftContainerDynamicStyle,
- iconContainer: iconContainerDynamicStyle,
- rightSubTitle: rightSubTitleDynamicStyle,
- rightTitle: rightTitleDynamicStyle,
- container: containerDynamicStyle,
- subTitle: subTitleDynamicStyle,
- title: titleDynamicStyle
- } = useStyles({
- isTransparentBackground,
- radiuses,
- subTitle,
- spaces,
- colors,
- type
- });
- const renderRightIcon = () => {
- if(!CustomRightIcon) {
- return null;
- }
- return <View
- style={[
- rightIconStyle,
- stylesheet.rightIconContainer,
- rightIconContainerDynamicStyle
- ]}
- >
- <CustomRightIcon
- color="default"
- size={18}
- />
- </View>;
- };
- const renderLeftIcon = () => {
- if(!CustomIcon) {
- return null;
- }
- return <View
- style={[
- iconStyle,
- stylesheet.iconContainer,
- iconContainerDynamicStyle
- ]}
- >
- <CustomIcon
- color="default"
- size={18}
- />
- </View>;
- };
- const renderLeftSubTitle = () => {
- if(!subTitle) {
- return null;
- }
- return <Text
- color={subTitleColor ? subTitleColor : "low"}
- variant={subTitleVariant}
- style={[
- leftSubTitleStyle,
- stylesheet.subTitle,
- subTitleDynamicStyle
- ]}
- >
- {subTitle}
- </Text>;
- };
- const renderLeftContent = () => {
- return <View
- style={[
- leftContentContainerStyle
- ]}
- >
- <Text
- variant={titleVariant}
- color={titleColor}
- style={[
- leftTitleStyle,
- stylesheet.title,
- titleDynamicStyle
- ]}
- >
- {title}
- </Text>
- {renderLeftSubTitle()}
- </View>;
- };
- const renderLeft = () => {
- return <View
- style={[
- leftContainerStyle,
- stylesheet.leftContainer,
- leftContainerDynamicStyle
- ]}
- >
- {renderLeftContent()}
- </View>;
- };
- const renderRightSubTitle = () => {
- if(!rightSubTitle) {
- return null;
- }
- return <Text
- color={rightSubTitleColor? rightSubTitleColor : "low"}
- variant={rightSubTitleVariant}
- style={[
- rightSubTitleStyle,
- stylesheet.rightSubTitle,
- rightSubTitleDynamicStyle
- ]}
- >
- {rightSubTitle}
- </Text>;
- };
- const renderRightContent = () => {
- return <View
- style={[
- rightContentContainerStyle
- ]}
- >
- <Text
- variant={rightTitleVariant}
- color={rightTitleColor}
- style={[
- rightTitleStyle,
- stylesheet.rightTitle,
- rightTitleDynamicStyle
- ]}
- >
- {rightTitle}
- </Text>
- {renderRightSubTitle()}
- </View>;
- };
- const renderRight = () => {
- return <View
- style={[
- rightContainerStyle,
- stylesheet.rightContainer,
- rightContainerDynamicStyle
- ]}
- >
- {renderRightContent()}
- </View>;
- };
- return <TouchableOpacity
- style={[
- style,
- stylesheet.container,
- containerDynamicStyle
- ]}
- onPress={() => {
- if(onPress) {
- onPress();
- }
- }}
- >
- {renderLeftIcon()}
- {renderLeft()}
- {renderRight()}
- {renderRightIcon()}
- </TouchableOpacity>;
- };
- export default RowCard;
|