diff options
author | Paul Frazee <pfrazee@gmail.com> | 2023-03-31 13:17:26 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-03-31 13:17:26 -0500 |
commit | a3334a01a221877d3e06e02f960fda441f3460bd (patch) | |
tree | 64cdbb1232d1a3c00750c346b6e3ae529b51d1b0 /src/view/com/post-thread/PostVotedBy.tsx | |
parent | 19f3a2fa92a61ddb785fc4e42d73792c1d0e772c (diff) | |
download | voidsky-a3334a01a221877d3e06e02f960fda441f3460bd.tar.zst |
Lex refactor (#362)
* Remove the hackcheck for upgrades * Rename the PostEmbeds folder to match the codebase style * Updates to latest lex refactor * Update to use new bsky agent * Update to use api package's richtext library * Switch to upsertProfile * Add TextEncoder/TextDecoder polyfill * Add Intl.Segmenter polyfill * Update composer to calculate lengths by grapheme * Fix detox * Fix login in e2e * Create account e2e passing * Implement an e2e mocking framework * Don't use private methods on mobx models as mobx can't track them * Add tooling for e2e-specific builds and add e2e media-picker mock * Add some tests and fix some bugs around profile editing * Add shell tests * Add home screen tests * Add thread screen tests * Add tests for other user profile screens * Add search screen tests * Implement profile imagery change tools and tests * Update to new embed behaviors * Add post tests * Fix to profile-screen test * Fix session resumption * Update web composer to new api * 1.11.0 * Fix pagination cursor parameters * Add quote posts to notifications * Fix embed layouts * Remove youtube inline player and improve tap handling on link cards * Reset minimal shell mode on all screen loads and feed swipes (close #299) * Update podfile.lock * Improve post notfound UI (close #366) * Bump atproto packages
Diffstat (limited to 'src/view/com/post-thread/PostVotedBy.tsx')
-rw-r--r-- | src/view/com/post-thread/PostVotedBy.tsx | 99 |
1 files changed, 0 insertions, 99 deletions
diff --git a/src/view/com/post-thread/PostVotedBy.tsx b/src/view/com/post-thread/PostVotedBy.tsx deleted file mode 100644 index f86798097..000000000 --- a/src/view/com/post-thread/PostVotedBy.tsx +++ /dev/null @@ -1,99 +0,0 @@ -import React, {useEffect} from 'react' -import {observer} from 'mobx-react-lite' -import {ActivityIndicator, RefreshControl, StyleSheet, View} from 'react-native' -import {CenteredView, FlatList} from '../util/Views' -import {VotesViewModel, VoteItem} from 'state/models/votes-view' -import {ErrorMessage} from '../util/error/ErrorMessage' -import {ProfileCardWithFollowBtn} from '../profile/ProfileCard' -import {useStores} from 'state/index' -import {usePalette} from 'lib/hooks/usePalette' - -export const PostVotedBy = observer(function PostVotedBy({ - uri, - direction, -}: { - uri: string - direction: 'up' | 'down' -}) { - const pal = usePalette('default') - const store = useStores() - const view = React.useMemo( - () => new VotesViewModel(store, {uri, direction}), - [store, uri, direction], - ) - - useEffect(() => { - view.loadMore().catch(err => store.log.error('Failed to fetch votes', err)) - }, [view, store.log]) - - const onRefresh = () => { - view.refresh() - } - const onEndReached = () => { - view - .loadMore() - .catch(err => view?.rootStore.log.error('Failed to load more votes', err)) - } - - if (!view.hasLoaded) { - return ( - <CenteredView> - <ActivityIndicator /> - </CenteredView> - ) - } - - // error - // = - if (view.hasError) { - return ( - <CenteredView> - <ErrorMessage message={view.error} onPressTryAgain={onRefresh} /> - </CenteredView> - ) - } - - // loaded - // = - const renderItem = ({item}: {item: VoteItem}) => ( - <ProfileCardWithFollowBtn - key={item.actor.did} - did={item.actor.did} - declarationCid={item.actor.declaration.cid} - handle={item.actor.handle} - displayName={item.actor.displayName} - avatar={item.actor.avatar} - isFollowedBy={!!item.actor.viewer?.followedBy} - /> - ) - return ( - <FlatList - data={view.votes} - keyExtractor={item => item.actor.did} - refreshControl={ - <RefreshControl - refreshing={view.isRefreshing} - onRefresh={onRefresh} - tintColor={pal.colors.text} - titleColor={pal.colors.text} - /> - } - onEndReached={onEndReached} - renderItem={renderItem} - initialNumToRender={15} - ListFooterComponent={() => ( - <View style={styles.footer}> - {view.isLoading && <ActivityIndicator />} - </View> - )} - extraData={view.isLoading} - /> - ) -}) - -const styles = StyleSheet.create({ - footer: { - height: 200, - paddingTop: 20, - }, -}) |