Я использую реагирующие нативные контакты, и мне нужно показать, что все числа принадлежат каждому человеку в отдельных строках, независимо от того, совпадает ли имя контакта. Как мне это сделать?
Например, если для контакта 'x' сохранено 5 номеров, я хотел бы иметь пять строк под именем 'x', но с разными телефонными номерами.
это мой render () в App.js:
render() {
return (
{this.state.contacts.map(contact => {
return (
<ListItem
key={contact.recordId}
title={`${contact.givenName} ${
contact.familyName}`}
description={contact.phoneNumbers.map(phone => (
<Text style={styles.phones}>
{phone.number} -
</Text>
))}
/>
);
})}
, а вот ListItem.js:
import PropTypes from 'prop-types';
import {RectButton} from 'react-native-gesture-handler';
import Swipeable from 'react-native-gesture-handler/Swipeable';
class ListItem extends Component {
static propTypes = {
leftElement: PropTypes.element,
title: PropTypes.string,
description: PropTypes.string,
rightElement: PropTypes.element,
rightText: PropTypes.string,
onPress: PropTypes.func,
onDelete: PropTypes.func,
onLongPress: PropTypes.func,
disabled: PropTypes.bool,
};
renderRightAction = (iconName, color, x, progress) => {
const trans = progress.interpolate({
inputRange: [0, 1],
outputRange: [x, 0],
});
const pressHandler = () => {
const {onDelete} = this.props;
if (onDelete) onDelete();
this.close();
};
return (
<Animated.View style={{flex: 1, transform: [{translateX: trans}]}}>
<RectButton
style={[styles.rightAction, {backgroundColor: color}]}
onPress={pressHandler}>
<Text style={{color: '#fff'}}>Delete</Text>
</RectButton>
</Animated.View>
);
};
renderRightActions = progress => (
<View style={{width: 64, flexDirection: 'row'}}>
{this.renderRightAction('trash', '#ef5350', 64, progress)}
</View>
);
renderRightActions = progress => (
<View style={{width: 64, flexDirection: 'row'}}>
{this.renderRightAction('trash', '#ef5350', 64, progress)}
</View>
);
updateRef = ref => {
this.swipeableRow = ref;
};
close = () => {
this.swipeableRow.close();
};
render() {
const {
leftElement,
title,
description,
rightElement,
rightText,
onPress,
onLongPress,
disabled,
} = this.props;
const Component = onPress || onLongPress ? TouchableHighlight : View;
const {
itemContainer,
leftElementContainer,
rightSectionContainer,
mainTitleContainer,
rightElementContainer,
rightTextContainer,
titleStyle,
descriptionStyle,
} = styles;
return (
<Swipeable
ref={this.updateRef}
friction={1}
renderRightActions={this.renderRightActions}>
<Component
onPress={onPress}
onLongPress={onLongPress}
disabled={disabled}
underlayColor="#f2f3f5">
<View style={itemContainer}>
{leftElement ? (
<View style={leftElementContainer}>{leftElement}</View>
) : (
<View />
)}
<View style={rightSectionContainer}>
<View style={mainTitleContainer}>
<Text style={titleStyle}>{title}</Text>
{description ? (
<Text style={descriptionStyle}>{description}</Text>
) : (
<View />
)}
</View>
<View style={rightTextContainer}>
{rightText ? <Text>{rightText}</Text> : <View />}
</View>
{rightElement ? (
<View style={rightElementContainer}>{rightElement}</View>
) : (
<View />
)}
</View>
</View>
</Component>
</Swipeable>
);
}
}
...
export default ListItem;
Любая помощь будет принята с благодарностью.