125 lines
3.6 KiB
TypeScript
125 lines
3.6 KiB
TypeScript
import React from 'react'
|
|
import {
|
|
StyleProp,
|
|
StyleSheet,
|
|
View,
|
|
ViewStyle,
|
|
TouchableOpacity,
|
|
} from 'react-native'
|
|
import {Text} from '../util/text/Text'
|
|
import {usePalette} from 'lib/hooks/usePalette'
|
|
import {colors, s} from 'lib/styles'
|
|
import {UserAvatar} from '../util/UserAvatar'
|
|
import {Button} from '../util/forms/Button'
|
|
import {observer} from 'mobx-react-lite'
|
|
import {AlgoItemModel} from 'state/models/feeds/algo/algo-item'
|
|
import {useNavigation} from '@react-navigation/native'
|
|
import {NavigationProp} from 'lib/routes/types'
|
|
import {useStores} from 'state/index'
|
|
import {HeartIconSolid} from 'lib/icons'
|
|
|
|
const AlgoItem = observer(
|
|
({item, style}: {item: AlgoItemModel; style?: StyleProp<ViewStyle>}) => {
|
|
const store = useStores()
|
|
const pal = usePalette('default')
|
|
const navigation = useNavigation<NavigationProp>()
|
|
|
|
return (
|
|
<TouchableOpacity
|
|
accessibilityRole="button"
|
|
style={[styles.container, style]}
|
|
onPress={() => {
|
|
navigation.navigate('CustomFeed', {
|
|
name: item.data.displayName,
|
|
rkey: item.data.uri,
|
|
})
|
|
}}
|
|
key={item.data.uri}>
|
|
<View style={[styles.headerContainer]}>
|
|
<View style={[s.mr10]}>
|
|
<UserAvatar size={36} avatar={item.data.avatar} s />
|
|
</View>
|
|
<View style={[styles.headerTextContainer]}>
|
|
<Text style={[pal.text, s.bold]}>
|
|
{item.data.displayName ?? 'Feed name'}
|
|
</Text>
|
|
<Text style={[pal.textLight, styles.description]}>
|
|
{item.data.description ?? 'Feed description'}
|
|
</Text>
|
|
</View>
|
|
</View>
|
|
|
|
<View style={styles.bottomContainer}>
|
|
<View style={styles.likedByContainer}>
|
|
{/* <View style={styles.likedByAvatars}>
|
|
<UserAvatar size={24} avatar={item.data.avatar} />
|
|
<UserAvatar size={24} avatar={item.data.avatar} />
|
|
<UserAvatar size={24} avatar={item.data.avatar} />
|
|
</View> */}
|
|
|
|
<HeartIconSolid size={16} style={[s.mr2, {color: colors.red3}]} />
|
|
<Text style={[pal.text, pal.textLight]}>
|
|
{item.data.likeCount && item.data.likeCount > 1
|
|
? `Liked by ${item.data.likeCount} others`
|
|
: 'Be the first to like this'}
|
|
</Text>
|
|
</View>
|
|
<View>
|
|
<Button
|
|
type="inverted"
|
|
onPress={() => {
|
|
if (item.data.viewer?.saved) {
|
|
item.unsave()
|
|
store.me.savedFeeds.removeFeed(item.data.uri)
|
|
} else {
|
|
item.save()
|
|
store.me.savedFeeds.addFeed(item)
|
|
}
|
|
}}
|
|
label={item.data.viewer?.saved ? 'Unsave' : 'Save'}
|
|
/>
|
|
</View>
|
|
</View>
|
|
</TouchableOpacity>
|
|
)
|
|
},
|
|
)
|
|
export default AlgoItem
|
|
|
|
const styles = StyleSheet.create({
|
|
container: {
|
|
paddingHorizontal: 18,
|
|
paddingVertical: 20,
|
|
flexDirection: 'column',
|
|
flex: 1,
|
|
borderTopWidth: 1,
|
|
borderTopColor: '#E5E5E5',
|
|
gap: 18,
|
|
},
|
|
headerContainer: {
|
|
flexDirection: 'row',
|
|
},
|
|
headerTextContainer: {
|
|
flexDirection: 'column',
|
|
columnGap: 4,
|
|
flex: 1,
|
|
},
|
|
description: {
|
|
flex: 1,
|
|
flexWrap: 'wrap',
|
|
},
|
|
bottomContainer: {
|
|
flexDirection: 'row',
|
|
justifyContent: 'space-between',
|
|
alignItems: 'center',
|
|
},
|
|
likedByContainer: {
|
|
flexDirection: 'row',
|
|
alignItems: 'center',
|
|
gap: 2,
|
|
},
|
|
likedByAvatars: {
|
|
flexDirection: 'row',
|
|
gap: -12,
|
|
},
|
|
})
|