98 lines
2.2 KiB
TypeScript
98 lines
2.2 KiB
TypeScript
import React from 'react'
|
|
import {StyleSheet, TouchableOpacity, View} from 'react-native'
|
|
import {Link} from '../util/Link'
|
|
import {Text} from '../util/text/Text'
|
|
import {UserAvatar} from '../util/UserAvatar'
|
|
import {s} from '../../lib/styles'
|
|
import {usePalette} from '../../lib/hooks/usePalette'
|
|
|
|
export function ProfileCard({
|
|
handle,
|
|
displayName,
|
|
avatar,
|
|
renderButton,
|
|
onPressButton,
|
|
}: {
|
|
handle: string
|
|
displayName?: string
|
|
avatar?: string
|
|
renderButton?: () => JSX.Element
|
|
onPressButton?: () => void
|
|
}) {
|
|
const pal = usePalette('default')
|
|
return (
|
|
<Link
|
|
style={[styles.outer, pal.view, pal.border]}
|
|
href={`/profile/${handle}`}
|
|
title={handle}
|
|
noFeedback>
|
|
<View style={styles.layout}>
|
|
<View style={styles.layoutAvi}>
|
|
<UserAvatar
|
|
size={40}
|
|
displayName={displayName}
|
|
handle={handle}
|
|
avatar={avatar}
|
|
/>
|
|
</View>
|
|
<View style={styles.layoutContent}>
|
|
<Text style={[s.bold, pal.text]} numberOfLines={1}>
|
|
{displayName || handle}
|
|
</Text>
|
|
<Text type="body2" style={[pal.textLight]} numberOfLines={1}>
|
|
@{handle}
|
|
</Text>
|
|
</View>
|
|
{renderButton ? (
|
|
<View style={styles.layoutButton}>
|
|
<TouchableOpacity
|
|
onPress={onPressButton}
|
|
style={[styles.btn, pal.btn]}>
|
|
{renderButton()}
|
|
</TouchableOpacity>
|
|
</View>
|
|
) : undefined}
|
|
</View>
|
|
</Link>
|
|
)
|
|
}
|
|
|
|
const styles = StyleSheet.create({
|
|
outer: {
|
|
borderTopWidth: 1,
|
|
},
|
|
layout: {
|
|
flexDirection: 'row',
|
|
alignItems: 'center',
|
|
},
|
|
layoutAvi: {
|
|
width: 60,
|
|
paddingLeft: 10,
|
|
paddingTop: 10,
|
|
paddingBottom: 10,
|
|
},
|
|
avi: {
|
|
width: 40,
|
|
height: 40,
|
|
borderRadius: 20,
|
|
resizeMode: 'cover',
|
|
},
|
|
layoutContent: {
|
|
flex: 1,
|
|
paddingRight: 10,
|
|
paddingTop: 12,
|
|
paddingBottom: 10,
|
|
},
|
|
layoutButton: {
|
|
paddingRight: 10,
|
|
},
|
|
btn: {
|
|
flexDirection: 'row',
|
|
alignItems: 'center',
|
|
justifyContent: 'center',
|
|
paddingVertical: 7,
|
|
paddingHorizontal: 14,
|
|
borderRadius: 50,
|
|
marginLeft: 6,
|
|
},
|
|
})
|