import React from 'react'; import { StyleSheet, Text, View } from 'react-native'; import moment from 'moment'; import { connect } from 'react-redux'; import { MarkdownPreview } from '../markdown'; import { CustomIcon } from '../../lib/Icons'; import sharedStyles from '../../views/Styles'; import { themes } from '../../lib/constants'; import { IMessage } from '../../definitions/IMessage'; import { useTheme } from '../../theme'; import { IApplicationState } from '../../definitions'; const styles = StyleSheet.create({ container: { flexDirection: 'row', paddingTop: 10 }, messageContainer: { flex: 1, marginHorizontal: 10, paddingHorizontal: 15, paddingVertical: 10, borderRadius: 4 }, header: { flexDirection: 'row', alignItems: 'center' }, username: { fontSize: 16, ...sharedStyles.textMedium }, time: { fontSize: 12, lineHeight: 16, marginLeft: 6, ...sharedStyles.textRegular, fontWeight: '300' }, close: { marginRight: 10 } }); interface IMessageBoxReplyPreview { replying: boolean; message: IMessage; Message_TimeFormat: string; close(): void; baseUrl: string; username: string; getCustomEmoji: Function; useRealName: boolean; } const ReplyPreview = React.memo( ({ message, Message_TimeFormat, replying, close, useRealName }: IMessageBoxReplyPreview) => { const { theme } = useTheme(); if (!replying) { return null; } const time = moment(message.ts).format(Message_TimeFormat); return ( {useRealName ? message.u?.name : message.u?.username} {time} ); }, (prevProps: IMessageBoxReplyPreview, nextProps: IMessageBoxReplyPreview) => prevProps.replying === nextProps.replying && prevProps.message.id === nextProps.message.id ); const mapStateToProps = (state: IApplicationState) => ({ Message_TimeFormat: state.settings.Message_TimeFormat as string, baseUrl: state.server.server, useRealName: state.settings.UI_Use_Real_Name as boolean }); export default connect(mapStateToProps)(ReplyPreview);