From 521344de952a8fc946d0176bfddde5f7669a4658 Mon Sep 17 00:00:00 2001 From: hyochan Date: Fri, 27 Sep 2024 19:27:45 +0900 Subject: [PATCH] fix: user details page --- app/(home)/(tabs)/my.tsx | 2 +- app/(home)/_layout.tsx | 1 + app/(home)/onboarding.tsx | 1 + app/(home)/post/[id]/index.tsx | 5 +- app/(home)/post/[id]/update.tsx | 6 +- app/(home)/post/write.tsx | 6 +- app/(home)/settings/profile-update.tsx | 6 +- app/{ => (home)/user}/[displayName].tsx | 115 ++++++++++++++---------- src/components/uis/ReplyItem.tsx | 2 +- 9 files changed, 87 insertions(+), 57 deletions(-) rename app/{ => (home)/user}/[displayName].tsx (74%) diff --git a/app/(home)/(tabs)/my.tsx b/app/(home)/(tabs)/my.tsx index bb00ee0..3c565c8 100644 --- a/app/(home)/(tabs)/my.tsx +++ b/app/(home)/(tabs)/my.tsx @@ -27,7 +27,7 @@ const ProfileHeader = styled.View` `; const Content = styled.View` - padding: 24px; + padding: 16px; `; const UserAvatar = styled.Image` diff --git a/app/(home)/_layout.tsx b/app/(home)/_layout.tsx index 8daea0f..f4ae138 100644 --- a/app/(home)/_layout.tsx +++ b/app/(home)/_layout.tsx @@ -46,6 +46,7 @@ export default function Layout() { : css` border-radius: 48px; margin-left: -8px; + margin-top: 4px; ` } > diff --git a/app/(home)/onboarding.tsx b/app/(home)/onboarding.tsx index a3c0d1e..60036bb 100644 --- a/app/(home)/onboarding.tsx +++ b/app/(home)/onboarding.tsx @@ -214,6 +214,7 @@ export default function Onboarding(): JSX.Element { top: 8, }} style={css` + margin-top: 4px; align-items: center; justify-content: center; padding: 2px; diff --git a/app/(home)/post/[id]/index.tsx b/app/(home)/post/[id]/index.tsx index a927caf..f4e80d8 100644 --- a/app/(home)/post/[id]/index.tsx +++ b/app/(home)/post/[id]/index.tsx @@ -138,7 +138,7 @@ export default function PostDetails(): JSX.Element { const handlePressUser = useCallback(() => { if (post?.user.display_name) { push({ - pathname: `/[displayName]`, + pathname: `/user/[displayName]`, params: {displayName: `@${post.user.display_name}`}, }); } @@ -331,7 +331,7 @@ export default function PostDetails(): JSX.Element { authId ? ( {isSubmitting ? ( diff --git a/app/(home)/post/write.tsx b/app/(home)/post/write.tsx index c5d7abc..e67440e 100644 --- a/app/(home)/post/write.tsx +++ b/app/(home)/post/write.tsx @@ -125,10 +125,12 @@ export default function PostWrite(): JSX.Element { onPress={handleSubmit(handleWritePost)} activeOpacity={0} style={css` - align-items: center; - justify-content: center; + margin-top: 4px; margin-right: -4px; border-radius: 99px; + + align-items: center; + justify-content: center; `} hitSlop={{ bottom: 8, diff --git a/app/(home)/settings/profile-update.tsx b/app/(home)/settings/profile-update.tsx index d3877e9..df8bf7a 100644 --- a/app/(home)/settings/profile-update.tsx +++ b/app/(home)/settings/profile-update.tsx @@ -565,10 +565,12 @@ export default function ProfileUpdate(): JSX.Element { onPress={handleSubmit(handleProfileUpdate)} hitSlop={{bottom: 8, left: 8, right: 8, top: 8}} style={css` - align-items: center; - justify-content: center; + margin-top: 4px; margin-right: -4px; border-radius: 99px; + + align-items: center; + justify-content: center; `} > {isSubmitting ? ( diff --git a/app/[displayName].tsx b/app/(home)/user/[displayName].tsx similarity index 74% rename from app/[displayName].tsx rename to app/(home)/user/[displayName].tsx index 0d27d1f..1074dfa 100644 --- a/app/[displayName].tsx +++ b/app/(home)/user/[displayName].tsx @@ -1,26 +1,26 @@ -import React, {useEffect, useState} from 'react'; +import React, {useCallback, useEffect, useState} from 'react'; import styled from '@emotion/native'; import {Stack, useLocalSearchParams} from 'expo-router'; import {Button, Icon, Typography, useDooboo} from 'dooboo-ui'; import {css} from '@emotion/native'; -import {Pressable} from 'react-native'; +import {Pressable, RefreshControl} from 'react-native'; import ErrorBoundary from 'react-native-error-boundary'; -import FallbackComponent from '../src/components/uis/FallbackComponent'; -import CustomScrollView from '../src/components/uis/CustomScrollView'; -import {IC_ICON} from '../src/icons'; -import {openURL, removeLeadingAt} from '../src/utils/common'; -import DoobooStats from '../src/components/fragments/DoobooStats'; -import {t} from '../src/STRINGS'; -import {fetchUserWithDisplayName} from '../src/apis/profileQueries'; -import CustomLoadingIndicator from '../src/components/uis/CustomLoadingIndicator'; +import FallbackComponent from '../../../src/components/uis/FallbackComponent'; +import CustomScrollView from '../../../src/components/uis/CustomScrollView'; +import {IC_ICON} from '../../../src/icons'; +import {openURL, removeLeadingAt} from '../../../src/utils/common'; +import DoobooStats from '../../../src/components/fragments/DoobooStats'; +import {t} from '../../../src/STRINGS'; +import {fetchUserWithDisplayName} from '../../../src/apis/profileQueries'; +import CustomLoadingIndicator from '../../../src/components/uis/CustomLoadingIndicator'; import {useRecoilValue} from 'recoil'; -import {authRecoilState} from '../src/recoil/atoms'; +import {authRecoilState} from '../../../src/recoil/atoms'; import { fetchFollowCounts, fetchFollowUser, fetchIsAFollowing, -} from '../src/apis/followQueries'; -import useSupabase from '../src/hooks/useSupabase'; +} from '../../../src/apis/followQueries'; +import useSupabase from '../../../src/hooks/useSupabase'; const Container = styled.SafeAreaView` flex: 1; @@ -36,7 +36,7 @@ const ProfileHeader = styled.View` `; const Content = styled.View` - padding: 24px; + padding: 16px; `; const UserAvatar = styled.Image` @@ -148,52 +148,61 @@ export default function DisplayName(): JSX.Element { } }; - useEffect(() => { - async function fetchData() { - if (!supabase) return; - - try { - const {profile, userTags} = await fetchUserWithDisplayName({ - displayName, - supabase, - }); + const fetchData = useCallback(async () => { + if (!supabase) return; - setUser(profile); - setTags(userTags); - - // Check if the current user is following this profile - if (authId) { - if (profile.id !== authId) { - const isUserFollowing = await fetchIsAFollowing({ - authId, - followingId: profile.id, - supabase, - }); + try { + const {profile, userTags} = await fetchUserWithDisplayName({ + displayName, + supabase, + }); - setIsFollowing(isUserFollowing); - } + setUser(profile); + setTags(userTags); - const followingsData = await fetchFollowCounts({ - userId: profile.id, + // Check if the current user is following this profile + if (authId) { + if (profile.id !== authId) { + const isUserFollowing = await fetchIsAFollowing({ + authId, + followingId: profile.id, supabase, }); - setFollowingCount(followingsData.followingCount); + setIsFollowing(isUserFollowing); } - } catch (err: any) { - throw new Error(err.message); - } finally { - setLoading(false); + + const followingsData = await fetchFollowCounts({ + userId: profile.id, + supabase, + }); + + setFollowingCount(followingsData.followerCount); } + } catch (err: any) { + throw new Error(err.message); + } finally { + setLoading(false); } + }, [supabase, displayName, authId]); + const onRefresh = async () => { + fetchData(); + }; + + useEffect(() => { fetchData(); - }, [authId, displayName, supabase]); + }, [fetchData]); if (loading) { return ( <> - + ); @@ -201,9 +210,21 @@ export default function DisplayName(): JSX.Element { return ( - - + + + ), + }} + > { push({ - pathname: `/[displayName]`, + pathname: `/user/[displayName]`, params: {displayName: `@${item.user.display_name}`}, }); }}