diff options
author | Paul Frazee <pfrazee@gmail.com> | 2023-05-18 15:12:18 -0500 |
---|---|---|
committer | Paul Frazee <pfrazee@gmail.com> | 2023-05-18 15:12:18 -0500 |
commit | 84990c509e9feb0cd44921a318aedcbad92b1da7 (patch) | |
tree | 56de2d6d8d9b7196a1940d8f37430d6bb1e68e8f /src/view/com/posts/CustomFeedEmptyState.tsx | |
parent | 2f4408582bf27a83ba8d22605077d067f8433d7c (diff) | |
download | voidsky-84990c509e9feb0cd44921a318aedcbad92b1da7.tar.zst |
Drop the hard-coded what's hot algo
Diffstat (limited to 'src/view/com/posts/CustomFeedEmptyState.tsx')
-rw-r--r-- | src/view/com/posts/CustomFeedEmptyState.tsx | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/src/view/com/posts/CustomFeedEmptyState.tsx b/src/view/com/posts/CustomFeedEmptyState.tsx new file mode 100644 index 000000000..69dd79902 --- /dev/null +++ b/src/view/com/posts/CustomFeedEmptyState.tsx @@ -0,0 +1,97 @@ +import React from 'react' +import {StyleSheet, View} from 'react-native' +import {useNavigation} from '@react-navigation/native' +import { + FontAwesomeIcon, + FontAwesomeIconStyle, +} from '@fortawesome/react-native-fontawesome' +import {Text} from '../util/text/Text' +import {Button} from '../util/forms/Button' +import {MagnifyingGlassIcon} from 'lib/icons' +import {NavigationProp} from 'lib/routes/types' +import {useStores} from 'state/index' +import {usePalette} from 'lib/hooks/usePalette' +import {s} from 'lib/styles' + +export function CustomFeedEmptyState() { + const pal = usePalette('default') + const palInverted = usePalette('inverted') + const store = useStores() + const navigation = useNavigation<NavigationProp>() + + const onPressFindAccounts = React.useCallback(() => { + navigation.navigate('SearchTab') + navigation.popToTop() + }, [navigation]) + + const onPressSettings = React.useCallback(() => { + store.shell.openModal({name: 'content-languages-settings'}) + }, [store]) + + return ( + <View style={styles.emptyContainer}> + <View style={styles.emptyIconContainer}> + <MagnifyingGlassIcon style={[styles.emptyIcon, pal.text]} size={62} /> + </View> + <Text type="xl-medium" style={[s.textCenter, pal.text]}> + This feed is empty! You may need to follow more users or tune your + language settings. + </Text> + <Button + type="inverted" + style={styles.emptyBtn} + onPress={onPressFindAccounts}> + <Text type="lg-medium" style={palInverted.text}> + Find accounts to follow + </Text> + <FontAwesomeIcon + icon="angle-right" + style={palInverted.text as FontAwesomeIconStyle} + size={14} + /> + </Button> + <Button type="inverted" style={styles.emptyBtn} onPress={onPressSettings}> + <Text type="lg-medium" style={palInverted.text}> + Update my settings + </Text> + <FontAwesomeIcon + icon="angle-right" + style={palInverted.text as FontAwesomeIconStyle} + size={14} + /> + </Button> + </View> + ) +} +const styles = StyleSheet.create({ + emptyContainer: { + height: '100%', + paddingVertical: 40, + paddingHorizontal: 30, + }, + emptyIconContainer: { + marginBottom: 16, + }, + emptyIcon: { + marginLeft: 'auto', + marginRight: 'auto', + }, + emptyBtn: { + marginVertical: 20, + flexDirection: 'row', + alignItems: 'center', + justifyContent: 'space-between', + paddingVertical: 18, + paddingHorizontal: 24, + borderRadius: 30, + }, + + feedsTip: { + position: 'absolute', + left: 22, + }, + feedsTipArrow: { + marginLeft: 32, + marginTop: 8, + }, +}) |