Skip to content

Commit

Permalink
feat: Headers and New Conversation
Browse files Browse the repository at this point in the history
Updated new conversation Handling

Moved components to be in features branch
Updated title components
Bumped RN SDK
Commented out api header work
  • Loading branch information
alexrisch committed Nov 21, 2024
1 parent 4c10269 commit 6489942
Show file tree
Hide file tree
Showing 26 changed files with 1,072 additions and 368 deletions.
68 changes: 0 additions & 68 deletions components/Conversation/ConversationTitleDumb.tsx

This file was deleted.

94 changes: 94 additions & 0 deletions components/Conversation/GroupConversationTitle.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
import React, { memo, useCallback, useMemo } from "react";
import { ConversationTitleDumb } from "../../features/conversations/components/ConversationTitleDumb";
import { useGroupNameQuery } from "@queries/useGroupNameQuery";
import { ConversationTopic } from "@xmtp/react-native-sdk";
import { useCurrentAccount } from "@data/store/accountsStore";
import { NativeStackNavigationProp } from "@react-navigation/native-stack";
import { NavigationParamList } from "@screens/Navigation/Navigation";
import { ImageStyle, Platform } from "react-native";
import { useRouter } from "@navigation/useNavigation";
import { useGroupPhotoQuery } from "@queries/useGroupPhotoQuery";
import Avatar from "@components/Avatar";
import { AvatarSizes } from "@styles/sizes";
import { ThemedStyle, useAppTheme } from "@theme/useAppTheme";
import { GroupAvatarDumb } from "@components/GroupAvatar";
import { useConversationTitleLongPress } from "../../features/conversations/hooks/useConversationTitleLongPress";
import { useGroupMembersAvatarData } from "../../features/conversations/hooks/useGroupMembersAvatarData";

type GroupConversationTitleProps = {
topic: ConversationTopic;
};

type UseUserInteractionProps = {
topic: ConversationTopic;
navigation: NativeStackNavigationProp<NavigationParamList>;
};

const useUserInteraction = ({ navigation, topic }: UseUserInteractionProps) => {
const onPress = useCallback(() => {
// textInputRef?.current?.blur();
navigation.push("Group", { topic });
}, [navigation, topic]);

const onLongPress = useConversationTitleLongPress(topic);

return { onPress, onLongPress };
};

export const GroupConversationTitle = memo(
({ topic }: GroupConversationTitleProps) => {
const currentAccount = useCurrentAccount()!;

const { data: groupName, isLoading: groupNameLoading } = useGroupNameQuery(
currentAccount,
topic!
);

const { data: groupPhoto, isLoading: groupPhotoLoading } =
useGroupPhotoQuery(currentAccount, topic!);

const { data: memberData } = useGroupMembersAvatarData({ topic });

const navigation = useRouter();

const { themed } = useAppTheme();

const { onPress, onLongPress } = useUserInteraction({
topic,
navigation,
});

const displayAvatar = !groupPhotoLoading && !groupNameLoading;

const avatarComponent = useMemo(() => {
if (displayAvatar) return null;
return groupPhoto ? (
<Avatar
uri={groupPhoto}
size={AvatarSizes.conversationTitle}
style={themed($avatar)}
/>
) : (
<GroupAvatarDumb
members={memberData}
size={AvatarSizes.conversationTitle}
style={themed($avatar)}
/>
);
}, [displayAvatar, groupPhoto, memberData, themed]);

return (
<ConversationTitleDumb
title={groupName ?? undefined}
onLongPress={onLongPress}
onPress={onPress}
avatarComponent={avatarComponent}
/>
);
}
);

const $avatar: ThemedStyle<ImageStyle> = (theme) => ({
marginRight: Platform.OS === "android" ? theme.spacing.lg : theme.spacing.xxs,
marginLeft: Platform.OS === "ios" ? theme.spacing.zero : -theme.spacing.xxs,
});
Loading

0 comments on commit 6489942

Please sign in to comment.