Files
JKVideo/components/CommentItem.tsx
Developer 3f82646496 init
2026-03-26 12:15:40 +08:00

43 lines
1.9 KiB
TypeScript

import React from 'react';
import { View, Text, StyleSheet } from 'react-native';
import { Image } from 'expo-image';
import { Ionicons } from '@expo/vector-icons';
import type { Comment } from '../services/types';
import { formatTime } from '../utils/format';
import { proxyImageUrl } from '../utils/imageUrl';
import { useTheme } from '../utils/theme';
interface Props { item: Comment; }
export function CommentItem({ item }: Props) {
const theme = useTheme();
return (
<View style={[styles.row, { borderBottomColor: theme.border }]}>
<Image source={{ uri: proxyImageUrl(item.member.avatar) }} style={styles.avatar} />
<View style={styles.content}>
<Text style={styles.username}>{item.member.uname}</Text>
<Text style={[styles.message, { color: theme.text }]}>{item.content.message}</Text>
<View style={styles.footer}>
<Text style={[styles.time, { color: theme.textSub }]}>{formatTime(item.ctime)}</Text>
<View style={styles.likeRow}>
<Ionicons name="thumbs-up-outline" size={12} color={theme.textSub} />
<Text style={[styles.likeCount, { color: theme.textSub }]}>{item.like > 0 ? item.like : ''}</Text>
</View>
</View>
</View>
</View>
);
}
const styles = StyleSheet.create({
row: { flexDirection: 'row', paddingHorizontal: 16, paddingVertical: 10, borderBottomWidth: StyleSheet.hairlineWidth, borderBottomColor: '#eee' },
avatar: { width: 34, height: 34, borderRadius: 17, marginRight: 10 },
content: { flex: 1 },
username: { fontSize: 12, color: '#00AEEC', marginBottom: 3 },
message: { fontSize: 14, color: '#212121', lineHeight: 20 },
footer: { flexDirection: 'row', justifyContent: 'space-between', marginTop: 4 },
time: { fontSize: 11, color: '#bbb' },
likeRow: { flexDirection: 'row', alignItems: 'center', gap: 2 },
likeCount: { fontSize: 11, color: '#999' },
});