import React from 'react'; import PropTypes from 'prop-types'; import { View, Text, StyleSheet } from 'react-native'; import moment from 'moment'; import { themes } from '../../constants/colors'; import { withTheme } from '../../theme'; import MessageError from './MessageError'; import sharedStyles from '../../views/Styles'; import messageStyles from './styles'; const styles = StyleSheet.create({ container: { flex: 1, flexDirection: 'row', alignItems: 'center' }, username: { fontSize: 16, lineHeight: 22, ...sharedStyles.textMedium }, titleContainer: { flex: 1, flexDirection: 'row', alignItems: 'center' }, alias: { fontSize: 14, ...sharedStyles.textRegular } }); const User = React.memo(({ isHeader, useRealName, author, alias, ts, timeFormat, hasError, theme, ...props }) => { if (isHeader || hasError) { const username = (useRealName && author.name) || author.username; const aliasUsername = alias ? (<Text style={[styles.alias, { color: themes[theme].auxiliaryText }]}> @{username}</Text>) : null; const time = moment(ts).format(timeFormat); return ( <View style={styles.container}> <View style={styles.titleContainer}> <Text style={[styles.username, { color: themes[theme].titleText }]} numberOfLines={1}> {alias || username} {aliasUsername} </Text> </View> <Text style={[messageStyles.time, { color: themes[theme].auxiliaryText }]}>{time}</Text> { hasError && <MessageError hasError={hasError} theme={theme} {...props} /> } </View> ); } return null; }); User.propTypes = { isHeader: PropTypes.bool, hasError: PropTypes.bool, useRealName: PropTypes.bool, author: PropTypes.object, alias: PropTypes.string, ts: PropTypes.instanceOf(Date), timeFormat: PropTypes.string, theme: PropTypes.string }; User.displayName = 'MessageUser'; export default withTheme(User);